@designtools/shadows 0.1.3 → 0.1.5
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/dist/cli.js +33 -115
- package/package.json +1 -1
- package/src/client/app.tsx +0 -2
- package/src/client/components/shadow-controls.tsx +1 -1
- package/src/client/dist/assets/{index-DL62bVtu.css → index-Bb9AiwJs.css} +1 -1
- package/src/client/dist/assets/index-DuqoHhIQ.js +49 -0
- package/src/client/dist/index.html +2 -2
- package/src/client/dist/assets/index-B06i4I-S.js +0 -49
package/dist/cli.js
CHANGED
|
@@ -174,8 +174,8 @@ async function bootstrap(config) {
|
|
|
174
174
|
}
|
|
175
175
|
|
|
176
176
|
// src/server/index.ts
|
|
177
|
-
import
|
|
178
|
-
import
|
|
177
|
+
import path9 from "path";
|
|
178
|
+
import fs10 from "fs";
|
|
179
179
|
import { fileURLToPath } from "url";
|
|
180
180
|
|
|
181
181
|
// ../core/src/server/create-server.ts
|
|
@@ -274,6 +274,9 @@ async function createToolServer(config) {
|
|
|
274
274
|
wsProxy.on("error", (err) => {
|
|
275
275
|
console.error("WS proxy error:", err.message);
|
|
276
276
|
});
|
|
277
|
+
if (config.setupRoutes) {
|
|
278
|
+
config.setupRoutes(app, projectRoot);
|
|
279
|
+
}
|
|
277
280
|
const vite = await createViteServer({
|
|
278
281
|
configFile: false,
|
|
279
282
|
root: config.clientRoot,
|
|
@@ -788,100 +791,14 @@ function detectColorFormat(value) {
|
|
|
788
791
|
return null;
|
|
789
792
|
}
|
|
790
793
|
|
|
791
|
-
// ../core/src/scanner/
|
|
794
|
+
// ../core/src/scanner/detect-styling.ts
|
|
792
795
|
import fs7 from "fs/promises";
|
|
793
796
|
import path6 from "path";
|
|
794
|
-
async function scanRoutes(projectRoot, framework) {
|
|
795
|
-
if (framework.name === "nextjs") {
|
|
796
|
-
return scanNextJsRoutes(projectRoot, framework.appDir);
|
|
797
|
-
}
|
|
798
|
-
return scanGenericRoutes(projectRoot, framework.appDir);
|
|
799
|
-
}
|
|
800
|
-
async function scanNextJsRoutes(projectRoot, appDir) {
|
|
801
|
-
const routes = [];
|
|
802
|
-
const fullAppDir = path6.join(projectRoot, appDir);
|
|
803
|
-
try {
|
|
804
|
-
await scanNextJsDir(fullAppDir, appDir, "", routes);
|
|
805
|
-
} catch {
|
|
806
|
-
}
|
|
807
|
-
return { routes };
|
|
808
|
-
}
|
|
809
|
-
async function scanNextJsDir(fullDir, appDir, urlPrefix, routes) {
|
|
810
|
-
let entries;
|
|
811
|
-
try {
|
|
812
|
-
entries = await fs7.readdir(fullDir, { withFileTypes: true });
|
|
813
|
-
} catch {
|
|
814
|
-
return;
|
|
815
|
-
}
|
|
816
|
-
const hasPage = entries.some(
|
|
817
|
-
(e) => e.isFile() && (e.name === "page.tsx" || e.name === "page.jsx")
|
|
818
|
-
);
|
|
819
|
-
if (hasPage) {
|
|
820
|
-
const pageFile = entries.find(
|
|
821
|
-
(e) => e.name === "page.tsx" || e.name === "page.jsx"
|
|
822
|
-
);
|
|
823
|
-
routes.push({
|
|
824
|
-
urlPath: urlPrefix || "/",
|
|
825
|
-
filePath: path6.join(
|
|
826
|
-
appDir,
|
|
827
|
-
urlPrefix.replace(/^\//, ""),
|
|
828
|
-
pageFile.name
|
|
829
|
-
)
|
|
830
|
-
});
|
|
831
|
-
}
|
|
832
|
-
for (const entry of entries) {
|
|
833
|
-
if (!entry.isDirectory()) continue;
|
|
834
|
-
if (entry.name.startsWith("_") || entry.name === "node_modules") continue;
|
|
835
|
-
let segment = entry.name;
|
|
836
|
-
if (segment.startsWith("(") && segment.endsWith(")")) {
|
|
837
|
-
await scanNextJsDir(
|
|
838
|
-
path6.join(fullDir, segment),
|
|
839
|
-
appDir,
|
|
840
|
-
urlPrefix,
|
|
841
|
-
routes
|
|
842
|
-
);
|
|
843
|
-
continue;
|
|
844
|
-
}
|
|
845
|
-
if (segment.startsWith("[") && segment.endsWith("]")) {
|
|
846
|
-
segment = `:${segment.slice(1, -1)}`;
|
|
847
|
-
}
|
|
848
|
-
if (segment === "api") continue;
|
|
849
|
-
await scanNextJsDir(
|
|
850
|
-
path6.join(fullDir, entry.name),
|
|
851
|
-
appDir,
|
|
852
|
-
`${urlPrefix}/${segment}`,
|
|
853
|
-
routes
|
|
854
|
-
);
|
|
855
|
-
}
|
|
856
|
-
}
|
|
857
|
-
async function scanGenericRoutes(projectRoot, srcDir) {
|
|
858
|
-
const routes = [];
|
|
859
|
-
const fullDir = path6.join(projectRoot, srcDir);
|
|
860
|
-
try {
|
|
861
|
-
const files = await fs7.readdir(fullDir, { withFileTypes: true });
|
|
862
|
-
for (const file of files) {
|
|
863
|
-
if (file.isFile() && (file.name.endsWith(".tsx") || file.name.endsWith(".jsx"))) {
|
|
864
|
-
const name = file.name.replace(/\.(tsx|jsx)$/, "");
|
|
865
|
-
const urlPath = name === "index" ? "/" : `/${name}`;
|
|
866
|
-
routes.push({
|
|
867
|
-
urlPath,
|
|
868
|
-
filePath: path6.join(srcDir, file.name)
|
|
869
|
-
});
|
|
870
|
-
}
|
|
871
|
-
}
|
|
872
|
-
} catch {
|
|
873
|
-
}
|
|
874
|
-
return { routes };
|
|
875
|
-
}
|
|
876
|
-
|
|
877
|
-
// ../core/src/scanner/detect-styling.ts
|
|
878
|
-
import fs8 from "fs/promises";
|
|
879
|
-
import path7 from "path";
|
|
880
797
|
async function detectStylingSystem(projectRoot, framework) {
|
|
881
|
-
const pkgPath =
|
|
798
|
+
const pkgPath = path6.join(projectRoot, "package.json");
|
|
882
799
|
let pkg = {};
|
|
883
800
|
try {
|
|
884
|
-
pkg = JSON.parse(await
|
|
801
|
+
pkg = JSON.parse(await fs7.readFile(pkgPath, "utf-8"));
|
|
885
802
|
} catch {
|
|
886
803
|
}
|
|
887
804
|
const deps = { ...pkg.dependencies, ...pkg.devDependencies };
|
|
@@ -906,7 +823,7 @@ async function detectStylingSystem(projectRoot, framework) {
|
|
|
906
823
|
let configPath;
|
|
907
824
|
for (const candidate of configCandidates) {
|
|
908
825
|
try {
|
|
909
|
-
await
|
|
826
|
+
await fs7.access(path6.join(projectRoot, candidate));
|
|
910
827
|
configPath = candidate;
|
|
911
828
|
break;
|
|
912
829
|
} catch {
|
|
@@ -951,7 +868,7 @@ async function detectStylingSystem(projectRoot, framework) {
|
|
|
951
868
|
async function checkDarkMode(projectRoot, cssFiles) {
|
|
952
869
|
for (const file of cssFiles) {
|
|
953
870
|
try {
|
|
954
|
-
const css = await
|
|
871
|
+
const css = await fs7.readFile(path6.join(projectRoot, file), "utf-8");
|
|
955
872
|
if (css.includes(".dark") || css.includes('[data-theme="dark"]') || css.includes("prefers-color-scheme: dark")) {
|
|
956
873
|
return true;
|
|
957
874
|
}
|
|
@@ -963,7 +880,7 @@ async function checkDarkMode(projectRoot, cssFiles) {
|
|
|
963
880
|
async function checkCustomProperties(projectRoot, cssFiles) {
|
|
964
881
|
for (const file of cssFiles) {
|
|
965
882
|
try {
|
|
966
|
-
const css = await
|
|
883
|
+
const css = await fs7.readFile(path6.join(projectRoot, file), "utf-8");
|
|
967
884
|
if (/--[\w-]+\s*:/.test(css)) {
|
|
968
885
|
return true;
|
|
969
886
|
}
|
|
@@ -986,7 +903,7 @@ async function findBootstrapScssFiles(projectRoot) {
|
|
|
986
903
|
const found = [];
|
|
987
904
|
for (const candidate of candidates) {
|
|
988
905
|
try {
|
|
989
|
-
await
|
|
906
|
+
await fs7.access(path6.join(projectRoot, candidate));
|
|
990
907
|
found.push(candidate);
|
|
991
908
|
} catch {
|
|
992
909
|
}
|
|
@@ -995,8 +912,8 @@ async function findBootstrapScssFiles(projectRoot) {
|
|
|
995
912
|
}
|
|
996
913
|
|
|
997
914
|
// src/server/scanner/scan-shadows.ts
|
|
998
|
-
import
|
|
999
|
-
import
|
|
915
|
+
import fs9 from "fs/promises";
|
|
916
|
+
import path8 from "path";
|
|
1000
917
|
|
|
1001
918
|
// src/server/scanner/presets/tailwind.ts
|
|
1002
919
|
var TAILWIND_SHADOW_PRESETS = [
|
|
@@ -1043,8 +960,8 @@ var TAILWIND_SHADOW_PRESETS = [
|
|
|
1043
960
|
];
|
|
1044
961
|
|
|
1045
962
|
// src/server/scanner/presets/bootstrap.ts
|
|
1046
|
-
import
|
|
1047
|
-
import
|
|
963
|
+
import fs8 from "fs/promises";
|
|
964
|
+
import path7 from "path";
|
|
1048
965
|
var BOOTSTRAP_SHADOW_PRESETS = [
|
|
1049
966
|
{
|
|
1050
967
|
name: "box-shadow-sm",
|
|
@@ -1067,7 +984,7 @@ async function scanBootstrapScssOverrides(projectRoot, scssFiles) {
|
|
|
1067
984
|
const overrides = [];
|
|
1068
985
|
for (const file of scssFiles) {
|
|
1069
986
|
try {
|
|
1070
|
-
const content = await
|
|
987
|
+
const content = await fs8.readFile(path7.join(projectRoot, file), "utf-8");
|
|
1071
988
|
const lines = content.split("\n");
|
|
1072
989
|
for (const line of lines) {
|
|
1073
990
|
const match = line.match(
|
|
@@ -1095,7 +1012,7 @@ async function scanBootstrapCssOverrides(projectRoot, cssFiles) {
|
|
|
1095
1012
|
const overrides = [];
|
|
1096
1013
|
for (const file of cssFiles) {
|
|
1097
1014
|
try {
|
|
1098
|
-
const content = await
|
|
1015
|
+
const content = await fs8.readFile(path7.join(projectRoot, file), "utf-8");
|
|
1099
1016
|
const propRegex = /(--bs-box-shadow(?:-sm|-lg|-inset)?)\s*:\s*([^;]+);/g;
|
|
1100
1017
|
let match;
|
|
1101
1018
|
while ((match = propRegex.exec(content)) !== null) {
|
|
@@ -1212,7 +1129,7 @@ async function scanCustomShadows(projectRoot, cssFiles) {
|
|
|
1212
1129
|
const shadows = [];
|
|
1213
1130
|
for (const file of cssFiles) {
|
|
1214
1131
|
try {
|
|
1215
|
-
const css = await
|
|
1132
|
+
const css = await fs9.readFile(path8.join(projectRoot, file), "utf-8");
|
|
1216
1133
|
const rootTokens = parseBlock(css, ":root");
|
|
1217
1134
|
for (const [name, value] of rootTokens) {
|
|
1218
1135
|
if (name.includes("shadow") || isShadowValue(value)) {
|
|
@@ -1308,12 +1225,11 @@ var cachedScan = null;
|
|
|
1308
1225
|
async function runScan(projectRoot) {
|
|
1309
1226
|
const framework = await detectFramework(projectRoot);
|
|
1310
1227
|
const styling = await detectStylingSystem(projectRoot, framework);
|
|
1311
|
-
const [tokens, shadows
|
|
1228
|
+
const [tokens, shadows] = await Promise.all([
|
|
1312
1229
|
scanTokens(projectRoot, framework),
|
|
1313
|
-
scanShadows(projectRoot, framework, styling)
|
|
1314
|
-
scanRoutes(projectRoot, framework)
|
|
1230
|
+
scanShadows(projectRoot, framework, styling)
|
|
1315
1231
|
]);
|
|
1316
|
-
cachedScan = { framework, styling, tokens, shadows
|
|
1232
|
+
cachedScan = { framework, styling, tokens, shadows };
|
|
1317
1233
|
return cachedScan;
|
|
1318
1234
|
}
|
|
1319
1235
|
function createShadowsScanRouter(projectRoot) {
|
|
@@ -1351,21 +1267,23 @@ function createShadowsScanRouter(projectRoot) {
|
|
|
1351
1267
|
}
|
|
1352
1268
|
|
|
1353
1269
|
// src/server/index.ts
|
|
1354
|
-
var __dirname =
|
|
1355
|
-
var packageRoot =
|
|
1270
|
+
var __dirname = path9.dirname(fileURLToPath(import.meta.url));
|
|
1271
|
+
var packageRoot = fs10.existsSync(path9.join(__dirname, "../package.json")) ? path9.resolve(__dirname, "..") : path9.resolve(__dirname, "../..");
|
|
1356
1272
|
async function startShadowsServer(preflight) {
|
|
1357
|
-
const clientRoot =
|
|
1358
|
-
const injectScriptPath =
|
|
1359
|
-
const compiledInject =
|
|
1360
|
-
const actualInjectPath =
|
|
1273
|
+
const clientRoot = path9.join(packageRoot, "src/client");
|
|
1274
|
+
const injectScriptPath = path9.join(packageRoot, "../core/src/inject/selection.ts");
|
|
1275
|
+
const compiledInject = path9.join(packageRoot, "dist/inject/selection.js");
|
|
1276
|
+
const actualInjectPath = fs10.existsSync(compiledInject) ? compiledInject : injectScriptPath;
|
|
1361
1277
|
const { app, wss, projectRoot } = await createToolServer({
|
|
1362
1278
|
targetPort: preflight.targetPort,
|
|
1363
1279
|
toolPort: preflight.toolPort,
|
|
1364
1280
|
clientRoot,
|
|
1365
|
-
injectScriptPath: actualInjectPath
|
|
1281
|
+
injectScriptPath: actualInjectPath,
|
|
1282
|
+
setupRoutes: (app2, projectRoot2) => {
|
|
1283
|
+
app2.use("/api/shadows", createShadowsRouter(projectRoot2));
|
|
1284
|
+
app2.use("/scan", createShadowsScanRouter(projectRoot2));
|
|
1285
|
+
}
|
|
1366
1286
|
});
|
|
1367
|
-
app.use("/api/shadows", createShadowsRouter(projectRoot));
|
|
1368
|
-
app.use("/scan", createShadowsScanRouter(projectRoot));
|
|
1369
1287
|
return { app, wss, projectRoot };
|
|
1370
1288
|
}
|
|
1371
1289
|
|
package/package.json
CHANGED
package/src/client/app.tsx
CHANGED
|
@@ -16,7 +16,6 @@ export interface ShadowsScanData {
|
|
|
16
16
|
cssFilePath: string;
|
|
17
17
|
stylingType: string;
|
|
18
18
|
};
|
|
19
|
-
routes: { routes: { urlPath: string; filePath: string }[] };
|
|
20
19
|
}
|
|
21
20
|
|
|
22
21
|
export function App() {
|
|
@@ -87,7 +86,6 @@ export function App() {
|
|
|
87
86
|
<ToolChrome
|
|
88
87
|
toolName="Shadows"
|
|
89
88
|
toolIcon={<ShadowIcon style={{ width: 15, height: 15 }} />}
|
|
90
|
-
routes={scanData?.routes.routes || []}
|
|
91
89
|
selectionMode={selectionMode}
|
|
92
90
|
onToggleSelectionMode={() => setSelectionMode((s) => !s)}
|
|
93
91
|
theme={theme}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
@layer theme,base,components,utilities;@layer theme{@theme default{ --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(97.1% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .005 285.823); --color-neutral-50: oklch(98.5% 0 0); --color-neutral-100: oklch(97% 0 0); --color-neutral-200: oklch(92.2% 0 0); --color-neutral-300: oklch(87% 0 0); --color-neutral-400: oklch(70.8% 0 0); --color-neutral-500: oklch(55.6% 0 0); --color-neutral-600: oklch(43.9% 0 0); --color-neutral-700: oklch(37.1% 0 0); --color-neutral-800: oklch(26.9% 0 0); --color-neutral-900: oklch(20.5% 0 0); --color-neutral-950: oklch(14.5% 0 0); --color-stone-50: oklch(98.5% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / .15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / .2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / .075), 0px 1px 1px rgb(0 0 0 / .075), 0px 2px 2px rgb(0 0 0 / .075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / .1), 0px 1px 2px rgb(0 0 0 / .1), 0px 2px 4px rgb(0 0 0 / .1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / .1), 0px 3px 2px rgb(0 0 0 / .1), 0px 4px 8px rgb(0 0 0 / .1); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:--theme(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:--theme(--default-font-feature-settings,normal);font-variation-settings:--theme(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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-family:--theme(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:--theme(--default-mono-font-feature-settings,normal);font-variation-settings:--theme(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}:root{--studio-bg: #0e0e12;--studio-surface: #18181f;--studio-surface-hover: #1f1f28;--studio-surface-active: #26263a;--studio-border: #2a2a3a;--studio-border-subtle: #222230;--studio-text: #e4e4ef;--studio-text-muted: #8e8ea4;--studio-text-dimmed: #64647a;--studio-input-bg: #13131a;--studio-accent: #3b82f6;--studio-accent-hover: #2563eb;--studio-accent-muted: rgba(59, 130, 246, .15);--studio-success: #22c55e;--studio-warning: #f59e0b;--studio-danger: #ef4444}@layer base{*{box-sizing:border-box;margin:0;padding:0}}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,sans-serif;background:var(--studio-bg);color:var(--studio-text);overflow:hidden;height:100vh;font-size:12px;-webkit-font-smoothing:antialiased}#root{height:100vh}.studio-scrollbar::-webkit-scrollbar{width:5px}.studio-scrollbar::-webkit-scrollbar-track{background:transparent}.studio-scrollbar::-webkit-scrollbar-thumb{background:var(--studio-border);border-radius:3px}.studio-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--studio-text-muted)}.studio-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--studio-text-muted);cursor:pointer;transition:background .1s,color .1s;flex-shrink:0}.studio-icon-btn:hover{background:var(--studio-surface-hover);color:var(--studio-text)}.studio-icon-btn.active{background:var(--studio-accent);color:#fff}.studio-segmented{display:inline-flex;background:var(--studio-input-bg);border-radius:6px;padding:2px;gap:1px}.studio-segmented button{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:4px 10px;border:none;border-radius:4px;background:transparent;color:var(--studio-text-dimmed);font-size:11px;font-weight:500;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.studio-segmented button:hover{background:#ffffff0a;color:var(--studio-text)}.studio-segmented button.active{background:var(--studio-surface-hover);color:var(--studio-text);box-shadow:0 1px 2px #0003}.studio-section-hdr{display:flex;align-items:center;gap:5px;padding:12px 16px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--studio-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;border:none;background:none;width:100%}.studio-section-hdr:hover{color:var(--studio-text)}.studio-section-hdr .count{margin-left:auto;font-size:9px;font-weight:400;color:var(--studio-text-dimmed)}.studio-section-hdr svg{width:10px;height:10px;flex-shrink:0;transition:transform .15s}.studio-prop-row{display:flex;align-items:center;gap:8px;padding:2px 16px;min-height:26px}.studio-prop-label{font-size:10px;font-weight:500;color:var(--studio-text-dimmed);min-width:42px;flex-shrink:0;text-transform:uppercase;letter-spacing:.03em}.studio-input{background:var(--studio-input-bg);border:1px solid var(--studio-border-subtle);border-radius:4px;color:var(--studio-text);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;padding:4px 6px;outline:none;transition:border-color .15s;min-width:0}.studio-input:focus{border-color:var(--studio-accent)}.studio-input::placeholder{color:var(--studio-text-dimmed)}.studio-select{background:var(--studio-input-bg);border:1px solid var(--studio-border-subtle);border-radius:4px;color:var(--studio-text);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;padding:3px 6px;outline:none;cursor:pointer;min-width:0;transition:border-color .15s}.studio-select:focus{border-color:var(--studio-accent)}.studio-two-col{display:grid;grid-template-columns:1fr 1fr;gap:4px 8px}.studio-swatch{width:18px;height:18px;border-radius:4px;border:1px solid var(--studio-border);flex-shrink:0;cursor:pointer;transition:box-shadow .1s;background-image:linear-gradient(var(--swatch-color, transparent),var(--swatch-color, transparent)),linear-gradient(45deg,#1a1a24 25%,transparent 25%),linear-gradient(-45deg,#1a1a24 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a1a24 75%),linear-gradient(-45deg,transparent 75%,#1a1a24 75%);background-size:cover,6px 6px,6px 6px,6px 6px,6px 6px;background-position:0 0,0 0,0 3px,3px -3px,-3px 0}.studio-swatch:hover{box-shadow:0 0 0 1px var(--studio-accent)}.studio-bp-btn{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border:1px solid var(--studio-border-subtle);border-radius:4px;background:var(--studio-input-bg);color:var(--studio-text-muted);font-size:11px;font-weight:500;font-family:SF Mono,Fira Code,Cascadia Code,monospace;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.studio-bp-btn:hover{background:var(--studio-surface-hover);border-color:var(--studio-border);color:var(--studio-text)}.studio-bp-btn.active{background:var(--studio-accent-muted);border-color:var(--studio-accent);color:var(--studio-accent)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:3px;background:var(--studio-border);border-radius:2px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--studio-accent);cursor:pointer;border:2px solid var(--studio-bg)}input[type=range]::-webkit-slider-thumb:hover{background:var(--studio-accent-hover)}.studio-color-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:4px 6px;background:var(--studio-input-bg);border:1px solid var(--studio-border-subtle);border-radius:4px;cursor:pointer;transition:border-color .15s;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;color:var(--studio-text);text-align:left}.studio-color-trigger:hover{border-color:var(--studio-border)}.studio-color-trigger:focus{border-color:var(--studio-accent);outline:none}.studio-color-trigger svg{width:10px;height:10px;color:var(--studio-text-dimmed);flex-shrink:0;margin-left:auto}.studio-popover{position:fixed;z-index:10000;background:var(--studio-surface);border:1px solid var(--studio-border);border-radius:8px;box-shadow:0 8px 24px #00000080,0 2px 8px #0000004d;padding:6px;width:240px;max-height:400px;display:flex;flex-direction:column}.studio-popover-swatch{width:100%;height:48px;border-radius:6px;border:1px solid var(--studio-border);margin-bottom:6px;flex-shrink:0;background-image:linear-gradient(var(--swatch-color, transparent),var(--swatch-color, transparent)),linear-gradient(45deg,#1a1a24 25%,transparent 25%),linear-gradient(-45deg,#1a1a24 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a1a24 75%),linear-gradient(-45deg,transparent 75%,#1a1a24 75%);background-size:cover,8px 8px,8px 8px,8px 8px,8px 8px;background-position:0 0,0 0,0 4px,4px -4px,-4px 0}.studio-popover-list{overflow-y:auto;display:flex;flex-direction:column;gap:1px;max-height:280px}.studio-popover-list::-webkit-scrollbar{width:4px}.studio-popover-list::-webkit-scrollbar-thumb{background:var(--studio-border);border-radius:2px}.studio-popover-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border:none;border-radius:4px;background:transparent;cursor:pointer;text-align:left;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;color:var(--studio-text);width:100%;transition:background .1s}.studio-popover-item:hover{background:var(--studio-surface-hover)}.studio-popover-item.active{background:var(--studio-accent-muted);color:var(--studio-accent)}.studio-popover-item .studio-swatch{width:16px;height:16px;border-radius:3px}.studio-tab-explainer{display:flex;align-items:flex-start;gap:8px;padding:12px 14px 13px;font-size:13px;line-height:1.45;color:var(--studio-text-muted);background:var(--studio-input-bg)}.studio-tab-explainer svg{width:14px;height:14px;flex-shrink:0;margin-top:2px;color:var(--studio-text-dimmed)}.studio-tab-explainer .studio-explainer-file{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:10px;color:var(--studio-text-dimmed);margin-top:2px}.studio-tree{position:relative;margin-left:16px;border-left:1px solid var(--studio-border-subtle);margin-bottom:2px}.studio-tree-node{position:relative}.studio-tree-node:before{content:"";position:absolute;left:0;top:14px;width:10px;height:1px;background:var(--studio-border-subtle)}.studio-tree-node:last-child:after{content:"";position:absolute;left:-1px;top:14px;bottom:0;width:1px;background:var(--studio-surface)}.studio-tree-node>button{padding-left:14px}.studio-tree-node .studio-section-hdr{padding:5px 16px 5px 14px}.studio-tree-content{padding-left:14px;padding-right:8px;padding-bottom:6px}
|
|
1
|
+
@layer theme,base,components,utilities;@layer theme{@theme default{ --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(97.1% .013 17.38); --color-red-100: oklch(93.6% .032 17.717); --color-red-200: oklch(88.5% .062 18.334); --color-red-300: oklch(80.8% .114 19.571); --color-red-400: oklch(70.4% .191 22.216); --color-red-500: oklch(63.7% .237 25.331); --color-red-600: oklch(57.7% .245 27.325); --color-red-700: oklch(50.5% .213 27.518); --color-red-800: oklch(44.4% .177 26.899); --color-red-900: oklch(39.6% .141 25.723); --color-red-950: oklch(25.8% .092 26.042); --color-orange-50: oklch(98% .016 73.684); --color-orange-100: oklch(95.4% .038 75.164); --color-orange-200: oklch(90.1% .076 70.697); --color-orange-300: oklch(83.7% .128 66.29); --color-orange-400: oklch(75% .183 55.934); --color-orange-500: oklch(70.5% .213 47.604); --color-orange-600: oklch(64.6% .222 41.116); --color-orange-700: oklch(55.3% .195 38.402); --color-orange-800: oklch(47% .157 37.304); --color-orange-900: oklch(40.8% .123 38.172); --color-orange-950: oklch(26.6% .079 36.259); --color-amber-50: oklch(98.7% .022 95.277); --color-amber-100: oklch(96.2% .059 95.617); --color-amber-200: oklch(92.4% .12 95.746); --color-amber-300: oklch(87.9% .169 91.605); --color-amber-400: oklch(82.8% .189 84.429); --color-amber-500: oklch(76.9% .188 70.08); --color-amber-600: oklch(66.6% .179 58.318); --color-amber-700: oklch(55.5% .163 48.998); --color-amber-800: oklch(47.3% .137 46.201); --color-amber-900: oklch(41.4% .112 45.904); --color-amber-950: oklch(27.9% .077 45.635); --color-yellow-50: oklch(98.7% .026 102.212); --color-yellow-100: oklch(97.3% .071 103.193); --color-yellow-200: oklch(94.5% .129 101.54); --color-yellow-300: oklch(90.5% .182 98.111); --color-yellow-400: oklch(85.2% .199 91.936); --color-yellow-500: oklch(79.5% .184 86.047); --color-yellow-600: oklch(68.1% .162 75.834); --color-yellow-700: oklch(55.4% .135 66.442); --color-yellow-800: oklch(47.6% .114 61.907); --color-yellow-900: oklch(42.1% .095 57.708); --color-yellow-950: oklch(28.6% .066 53.813); --color-lime-50: oklch(98.6% .031 120.757); --color-lime-100: oklch(96.7% .067 122.328); --color-lime-200: oklch(93.8% .127 124.321); --color-lime-300: oklch(89.7% .196 126.665); --color-lime-400: oklch(84.1% .238 128.85); --color-lime-500: oklch(76.8% .233 130.85); --color-lime-600: oklch(64.8% .2 131.684); --color-lime-700: oklch(53.2% .157 131.589); --color-lime-800: oklch(45.3% .124 130.933); --color-lime-900: oklch(40.5% .101 131.063); --color-lime-950: oklch(27.4% .072 132.109); --color-green-50: oklch(98.2% .018 155.826); --color-green-100: oklch(96.2% .044 156.743); --color-green-200: oklch(92.5% .084 155.995); --color-green-300: oklch(87.1% .15 154.449); --color-green-400: oklch(79.2% .209 151.711); --color-green-500: oklch(72.3% .219 149.579); --color-green-600: oklch(62.7% .194 149.214); --color-green-700: oklch(52.7% .154 150.069); --color-green-800: oklch(44.8% .119 151.328); --color-green-900: oklch(39.3% .095 152.535); --color-green-950: oklch(26.6% .065 152.934); --color-emerald-50: oklch(97.9% .021 166.113); --color-emerald-100: oklch(95% .052 163.051); --color-emerald-200: oklch(90.5% .093 164.15); --color-emerald-300: oklch(84.5% .143 164.978); --color-emerald-400: oklch(76.5% .177 163.223); --color-emerald-500: oklch(69.6% .17 162.48); --color-emerald-600: oklch(59.6% .145 163.225); --color-emerald-700: oklch(50.8% .118 165.612); --color-emerald-800: oklch(43.2% .095 166.913); --color-emerald-900: oklch(37.8% .077 168.94); --color-emerald-950: oklch(26.2% .051 172.552); --color-teal-50: oklch(98.4% .014 180.72); --color-teal-100: oklch(95.3% .051 180.801); --color-teal-200: oklch(91% .096 180.426); --color-teal-300: oklch(85.5% .138 181.071); --color-teal-400: oklch(77.7% .152 181.912); --color-teal-500: oklch(70.4% .14 182.503); --color-teal-600: oklch(60% .118 184.704); --color-teal-700: oklch(51.1% .096 186.391); --color-teal-800: oklch(43.7% .078 188.216); --color-teal-900: oklch(38.6% .063 188.416); --color-teal-950: oklch(27.7% .046 192.524); --color-cyan-50: oklch(98.4% .019 200.873); --color-cyan-100: oklch(95.6% .045 203.388); --color-cyan-200: oklch(91.7% .08 205.041); --color-cyan-300: oklch(86.5% .127 207.078); --color-cyan-400: oklch(78.9% .154 211.53); --color-cyan-500: oklch(71.5% .143 215.221); --color-cyan-600: oklch(60.9% .126 221.723); --color-cyan-700: oklch(52% .105 223.128); --color-cyan-800: oklch(45% .085 224.283); --color-cyan-900: oklch(39.8% .07 227.392); --color-cyan-950: oklch(30.2% .056 229.695); --color-sky-50: oklch(97.7% .013 236.62); --color-sky-100: oklch(95.1% .026 236.824); --color-sky-200: oklch(90.1% .058 230.902); --color-sky-300: oklch(82.8% .111 230.318); --color-sky-400: oklch(74.6% .16 232.661); --color-sky-500: oklch(68.5% .169 237.323); --color-sky-600: oklch(58.8% .158 241.966); --color-sky-700: oklch(50% .134 242.749); --color-sky-800: oklch(44.3% .11 240.79); --color-sky-900: oklch(39.1% .09 240.876); --color-sky-950: oklch(29.3% .066 243.157); --color-blue-50: oklch(97% .014 254.604); --color-blue-100: oklch(93.2% .032 255.585); --color-blue-200: oklch(88.2% .059 254.128); --color-blue-300: oklch(80.9% .105 251.813); --color-blue-400: oklch(70.7% .165 254.624); --color-blue-500: oklch(62.3% .214 259.815); --color-blue-600: oklch(54.6% .245 262.881); --color-blue-700: oklch(48.8% .243 264.376); --color-blue-800: oklch(42.4% .199 265.638); --color-blue-900: oklch(37.9% .146 265.522); --color-blue-950: oklch(28.2% .091 267.935); --color-indigo-50: oklch(96.2% .018 272.314); --color-indigo-100: oklch(93% .034 272.788); --color-indigo-200: oklch(87% .065 274.039); --color-indigo-300: oklch(78.5% .115 274.713); --color-indigo-400: oklch(67.3% .182 276.935); --color-indigo-500: oklch(58.5% .233 277.117); --color-indigo-600: oklch(51.1% .262 276.966); --color-indigo-700: oklch(45.7% .24 277.023); --color-indigo-800: oklch(39.8% .195 277.366); --color-indigo-900: oklch(35.9% .144 278.697); --color-indigo-950: oklch(25.7% .09 281.288); --color-violet-50: oklch(96.9% .016 293.756); --color-violet-100: oklch(94.3% .029 294.588); --color-violet-200: oklch(89.4% .057 293.283); --color-violet-300: oklch(81.1% .111 293.571); --color-violet-400: oklch(70.2% .183 293.541); --color-violet-500: oklch(60.6% .25 292.717); --color-violet-600: oklch(54.1% .281 293.009); --color-violet-700: oklch(49.1% .27 292.581); --color-violet-800: oklch(43.2% .232 292.759); --color-violet-900: oklch(38% .189 293.745); --color-violet-950: oklch(28.3% .141 291.089); --color-purple-50: oklch(97.7% .014 308.299); --color-purple-100: oklch(94.6% .033 307.174); --color-purple-200: oklch(90.2% .063 306.703); --color-purple-300: oklch(82.7% .119 306.383); --color-purple-400: oklch(71.4% .203 305.504); --color-purple-500: oklch(62.7% .265 303.9); --color-purple-600: oklch(55.8% .288 302.321); --color-purple-700: oklch(49.6% .265 301.924); --color-purple-800: oklch(43.8% .218 303.724); --color-purple-900: oklch(38.1% .176 304.987); --color-purple-950: oklch(29.1% .149 302.717); --color-fuchsia-50: oklch(97.7% .017 320.058); --color-fuchsia-100: oklch(95.2% .037 318.852); --color-fuchsia-200: oklch(90.3% .076 319.62); --color-fuchsia-300: oklch(83.3% .145 321.434); --color-fuchsia-400: oklch(74% .238 322.16); --color-fuchsia-500: oklch(66.7% .295 322.15); --color-fuchsia-600: oklch(59.1% .293 322.896); --color-fuchsia-700: oklch(51.8% .253 323.949); --color-fuchsia-800: oklch(45.2% .211 324.591); --color-fuchsia-900: oklch(40.1% .17 325.612); --color-fuchsia-950: oklch(29.3% .136 325.661); --color-pink-50: oklch(97.1% .014 343.198); --color-pink-100: oklch(94.8% .028 342.258); --color-pink-200: oklch(89.9% .061 343.231); --color-pink-300: oklch(82.3% .12 346.018); --color-pink-400: oklch(71.8% .202 349.761); --color-pink-500: oklch(65.6% .241 354.308); --color-pink-600: oklch(59.2% .249 .584); --color-pink-700: oklch(52.5% .223 3.958); --color-pink-800: oklch(45.9% .187 3.815); --color-pink-900: oklch(40.8% .153 2.432); --color-pink-950: oklch(28.4% .109 3.907); --color-rose-50: oklch(96.9% .015 12.422); --color-rose-100: oklch(94.1% .03 12.58); --color-rose-200: oklch(89.2% .058 10.001); --color-rose-300: oklch(81% .117 11.638); --color-rose-400: oklch(71.2% .194 13.428); --color-rose-500: oklch(64.5% .246 16.439); --color-rose-600: oklch(58.6% .253 17.585); --color-rose-700: oklch(51.4% .222 16.935); --color-rose-800: oklch(45.5% .188 13.697); --color-rose-900: oklch(41% .159 10.272); --color-rose-950: oklch(27.1% .105 12.094); --color-slate-50: oklch(98.4% .003 247.858); --color-slate-100: oklch(96.8% .007 247.896); --color-slate-200: oklch(92.9% .013 255.508); --color-slate-300: oklch(86.9% .022 252.894); --color-slate-400: oklch(70.4% .04 256.788); --color-slate-500: oklch(55.4% .046 257.417); --color-slate-600: oklch(44.6% .043 257.281); --color-slate-700: oklch(37.2% .044 257.287); --color-slate-800: oklch(27.9% .041 260.031); --color-slate-900: oklch(20.8% .042 265.755); --color-slate-950: oklch(12.9% .042 264.695); --color-gray-50: oklch(98.5% .002 247.839); --color-gray-100: oklch(96.7% .003 264.542); --color-gray-200: oklch(92.8% .006 264.531); --color-gray-300: oklch(87.2% .01 258.338); --color-gray-400: oklch(70.7% .022 261.325); --color-gray-500: oklch(55.1% .027 264.364); --color-gray-600: oklch(44.6% .03 256.802); --color-gray-700: oklch(37.3% .034 259.733); --color-gray-800: oklch(27.8% .033 256.848); --color-gray-900: oklch(21% .034 264.665); --color-gray-950: oklch(13% .028 261.692); --color-zinc-50: oklch(98.5% 0 0); --color-zinc-100: oklch(96.7% .001 286.375); --color-zinc-200: oklch(92% .004 286.32); --color-zinc-300: oklch(87.1% .006 286.286); --color-zinc-400: oklch(70.5% .015 286.067); --color-zinc-500: oklch(55.2% .016 285.938); --color-zinc-600: oklch(44.2% .017 285.786); --color-zinc-700: oklch(37% .013 285.805); --color-zinc-800: oklch(27.4% .006 286.033); --color-zinc-900: oklch(21% .006 285.885); --color-zinc-950: oklch(14.1% .005 285.823); --color-neutral-50: oklch(98.5% 0 0); --color-neutral-100: oklch(97% 0 0); --color-neutral-200: oklch(92.2% 0 0); --color-neutral-300: oklch(87% 0 0); --color-neutral-400: oklch(70.8% 0 0); --color-neutral-500: oklch(55.6% 0 0); --color-neutral-600: oklch(43.9% 0 0); --color-neutral-700: oklch(37.1% 0 0); --color-neutral-800: oklch(26.9% 0 0); --color-neutral-900: oklch(20.5% 0 0); --color-neutral-950: oklch(14.5% 0 0); --color-stone-50: oklch(98.5% .001 106.423); --color-stone-100: oklch(97% .001 106.424); --color-stone-200: oklch(92.3% .003 48.717); --color-stone-300: oklch(86.9% .005 56.366); --color-stone-400: oklch(70.9% .01 56.259); --color-stone-500: oklch(55.3% .013 58.071); --color-stone-600: oklch(44.4% .011 73.639); --color-stone-700: oklch(37.4% .01 67.558); --color-stone-800: oklch(26.8% .007 34.298); --color-stone-900: oklch(21.6% .006 56.043); --color-stone-950: oklch(14.7% .004 49.25); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --text-shadow-2xs: 0px 1px 0px rgb(0 0 0 / .15); --text-shadow-xs: 0px 1px 1px rgb(0 0 0 / .2); --text-shadow-sm: 0px 1px 0px rgb(0 0 0 / .075), 0px 1px 1px rgb(0 0 0 / .075), 0px 2px 2px rgb(0 0 0 / .075); --text-shadow-md: 0px 1px 1px rgb(0 0 0 / .1), 0px 1px 2px rgb(0 0 0 / .1), 0px 2px 4px rgb(0 0 0 / .1); --text-shadow-lg: 0px 1px 2px rgb(0 0 0 / .1), 0px 3px 2px rgb(0 0 0 / .1), 0px 4px 8px rgb(0 0 0 / .1); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: --theme(--font-sans, initial); --default-font-feature-settings: --theme( --font-sans--font-feature-settings, initial ); --default-font-variation-settings: --theme( --font-sans--font-variation-settings, initial ); --default-mono-font-family: --theme(--font-mono, initial); --default-mono-font-feature-settings: --theme( --font-mono--font-feature-settings, initial ); --default-mono-font-variation-settings: --theme( --font-mono--font-variation-settings, initial ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:--theme(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:--theme(--default-font-feature-settings,normal);font-variation-settings:--theme(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}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-family:--theme(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:--theme(--default-mono-font-feature-settings,normal);font-variation-settings:--theme(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}:root{--studio-bg: #0a0a0c;--studio-surface: #1a1a1e;--studio-surface-hover: #242428;--studio-surface-active: #2e2e34;--studio-border: #3c3c44;--studio-border-subtle: #2e2e36;--studio-text: #f4f4f8;--studio-text-muted: #b0b0c0;--studio-text-dimmed: #808094;--studio-input-bg: #121216;--studio-accent: #60a5fa;--studio-accent-hover: #3b82f6;--studio-accent-muted: rgba(96, 165, 250, .16);--studio-success: #22c55e;--studio-warning: #f59e0b;--studio-danger: #ef4444}@layer base{*{box-sizing:border-box;margin:0;padding:0}}body{font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,system-ui,sans-serif;background:var(--studio-bg);color:var(--studio-text);overflow:hidden;height:100vh;font-size:12px;-webkit-font-smoothing:antialiased}#root{height:100vh}.studio-scrollbar::-webkit-scrollbar{width:5px}.studio-scrollbar::-webkit-scrollbar-track{background:transparent}.studio-scrollbar::-webkit-scrollbar-thumb{background:var(--studio-border);border-radius:3px}.studio-scrollbar::-webkit-scrollbar-thumb:hover{background:var(--studio-text-muted)}.studio-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:var(--studio-text-muted);cursor:pointer;transition:background .1s,color .1s;flex-shrink:0}.studio-icon-btn:hover{background:var(--studio-surface-hover);color:var(--studio-text)}.studio-icon-btn.active{background:var(--studio-accent);color:#fff}.studio-segmented{display:inline-flex;background:var(--studio-input-bg);border-radius:6px;padding:2px;gap:1px}.studio-segmented button{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:4px 10px;border:none;border-radius:4px;background:transparent;color:var(--studio-text-dimmed);font-size:11px;font-weight:500;cursor:pointer;transition:background .1s,color .1s;white-space:nowrap}.studio-segmented button:hover{background:#ffffff0a;color:var(--studio-text)}.studio-segmented button.active{background:var(--studio-surface-hover);color:var(--studio-text);box-shadow:0 1px 2px #0003}.studio-section-hdr{display:flex;align-items:center;gap:5px;padding:12px 16px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--studio-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;border:none;background:none;width:100%}.studio-section-hdr:hover{color:var(--studio-text)}.studio-section-hdr .count{margin-left:auto;font-size:9px;font-weight:400;color:var(--studio-text-dimmed)}.studio-section-hdr svg{width:10px;height:10px;flex-shrink:0;transition:transform .15s}.studio-prop-row{display:flex;align-items:center;gap:8px;padding:2px 16px;min-height:26px}.studio-prop-label{font-size:10px;font-weight:500;color:var(--studio-text-dimmed);min-width:42px;flex-shrink:0;text-transform:uppercase;letter-spacing:.03em}.studio-input{background:var(--studio-input-bg);border:1px solid var(--studio-border-subtle);border-radius:4px;color:var(--studio-text);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;padding:4px 6px;outline:none;transition:border-color .15s;min-width:0}.studio-input:focus{border-color:var(--studio-accent)}.studio-input::placeholder{color:var(--studio-text-dimmed)}.studio-select{background:var(--studio-input-bg);border:1px solid var(--studio-border-subtle);border-radius:4px;color:var(--studio-text);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;padding:3px 6px;outline:none;cursor:pointer;min-width:0;transition:border-color .15s}.studio-select:focus{border-color:var(--studio-accent)}.studio-two-col{display:grid;grid-template-columns:1fr 1fr;gap:4px 8px}.studio-swatch{width:18px;height:18px;border-radius:4px;border:1px solid var(--studio-border);flex-shrink:0;cursor:pointer;transition:box-shadow .1s;background-image:linear-gradient(var(--swatch-color, transparent),var(--swatch-color, transparent)),linear-gradient(45deg,#1a1a24 25%,transparent 25%),linear-gradient(-45deg,#1a1a24 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a1a24 75%),linear-gradient(-45deg,transparent 75%,#1a1a24 75%);background-size:cover,6px 6px,6px 6px,6px 6px,6px 6px;background-position:0 0,0 0,0 3px,3px -3px,-3px 0}.studio-swatch:hover{box-shadow:0 0 0 1px var(--studio-accent)}.studio-bp-btn{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;border:1px solid var(--studio-border-subtle);border-radius:4px;background:var(--studio-input-bg);color:var(--studio-text-muted);font-size:11px;font-weight:500;font-family:SF Mono,Fira Code,Cascadia Code,monospace;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.studio-bp-btn:hover{background:var(--studio-surface-hover);border-color:var(--studio-border);color:var(--studio-text)}.studio-bp-btn.active{background:var(--studio-accent-muted);border-color:var(--studio-accent);color:var(--studio-accent)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:3px;background:var(--studio-border);border-radius:2px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:var(--studio-accent);cursor:pointer;border:2px solid var(--studio-bg)}input[type=range]::-webkit-slider-thumb:hover{background:var(--studio-accent-hover)}.studio-color-trigger{display:flex;align-items:center;gap:8px;width:100%;padding:4px 6px;background:var(--studio-input-bg);border:1px solid var(--studio-border-subtle);border-radius:4px;cursor:pointer;transition:border-color .15s;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;color:var(--studio-text);text-align:left}.studio-color-trigger:hover{border-color:var(--studio-border)}.studio-color-trigger:focus{border-color:var(--studio-accent);outline:none}.studio-color-trigger svg{width:10px;height:10px;color:var(--studio-text-dimmed);flex-shrink:0;margin-left:auto}.studio-popover{position:fixed;z-index:10000;background:var(--studio-surface);border:1px solid var(--studio-border);border-radius:8px;box-shadow:0 8px 24px #00000080,0 2px 8px #0000004d;padding:6px;width:240px;max-height:400px;display:flex;flex-direction:column}.studio-popover-swatch{width:100%;height:48px;border-radius:6px;border:1px solid var(--studio-border);margin-bottom:6px;flex-shrink:0;background-image:linear-gradient(var(--swatch-color, transparent),var(--swatch-color, transparent)),linear-gradient(45deg,#1a1a24 25%,transparent 25%),linear-gradient(-45deg,#1a1a24 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1a1a24 75%),linear-gradient(-45deg,transparent 75%,#1a1a24 75%);background-size:cover,8px 8px,8px 8px,8px 8px,8px 8px;background-position:0 0,0 0,0 4px,4px -4px,-4px 0}.studio-popover-list{overflow-y:auto;display:flex;flex-direction:column;gap:1px;max-height:280px}.studio-popover-list::-webkit-scrollbar{width:4px}.studio-popover-list::-webkit-scrollbar-thumb{background:var(--studio-border);border-radius:2px}.studio-popover-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border:none;border-radius:4px;background:transparent;cursor:pointer;text-align:left;font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11px;color:var(--studio-text);width:100%;transition:background .1s}.studio-popover-item:hover{background:var(--studio-surface-hover)}.studio-popover-item.active{background:var(--studio-accent-muted);color:var(--studio-accent)}.studio-popover-item .studio-swatch{width:16px;height:16px;border-radius:3px}.studio-tab-explainer{display:flex;align-items:flex-start;gap:8px;padding:12px 14px 13px;font-size:13px;line-height:1.45;color:var(--studio-text-muted);background:var(--studio-input-bg)}.studio-tab-explainer svg{width:14px;height:14px;flex-shrink:0;margin-top:2px;color:var(--studio-text-dimmed)}.studio-tab-explainer .studio-explainer-file{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:10px;color:var(--studio-text-dimmed);margin-top:2px}.studio-tree{position:relative;margin-left:16px;border-left:1px solid var(--studio-border-subtle);margin-bottom:2px}.studio-tree-node{position:relative}.studio-tree-node:before{content:"";position:absolute;left:0;top:14px;width:10px;height:1px;background:var(--studio-border-subtle)}.studio-tree-node:last-child:after{content:"";position:absolute;left:-1px;top:14px;bottom:0;width:1px;background:var(--studio-surface)}.studio-tree-node>button{padding-left:14px}.studio-tree-node .studio-section-hdr{padding:5px 16px 5px 14px}.studio-tree-content{padding-left:14px;padding-right:8px;padding-bottom:6px}
|