veslx 0.0.27 → 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.
Files changed (86) hide show
  1. package/bin/lib/build.ts +3 -0
  2. package/bin/lib/serve.ts +4 -4
  3. package/bin/veslx.ts +1 -1
  4. package/dist/assets/README-DVMP1xaW.js +7 -0
  5. package/dist/assets/SLIDES-DjNLQtEU.js +10 -0
  6. package/dist/assets/index-CBkKcH4y.js +469 -0
  7. package/dist/assets/index-PspMxLnH.css +1 -0
  8. package/dist/assets/index-UZKwazVi.js +1 -0
  9. package/dist/index.html +2 -2
  10. package/dist/raw/.veslx.json +61 -0
  11. package/dist/raw/README.md +33 -0
  12. package/dist/raw/test-post/Chart.tsx +16 -0
  13. package/dist/raw/test-post/README.mdx +21 -0
  14. package/dist/raw/test-slides/Counter.tsx +25 -0
  15. package/dist/raw/test-slides/SLIDES.mdx +27 -0
  16. package/index.html +17 -0
  17. package/package.json +4 -7
  18. package/plugin/src/plugin.ts +38 -0
  19. package/src/components/slides-renderer.tsx +130 -0
  20. package/src/hooks/use-mdx-content.ts +108 -0
  21. package/src/pages/post.tsx +15 -13
  22. package/src/pages/slides.tsx +21 -34
  23. package/src/vite-env.d.ts +21 -0
  24. package/vite.config.ts +1 -19
  25. package/dist/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2 +0 -0
  26. package/dist/assets/KaTeX_AMS-Regular-DMm9YOAa.woff +0 -0
  27. package/dist/assets/KaTeX_AMS-Regular-DRggAlZN.ttf +0 -0
  28. package/dist/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf +0 -0
  29. package/dist/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff +0 -0
  30. package/dist/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2 +0 -0
  31. package/dist/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff +0 -0
  32. package/dist/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2 +0 -0
  33. package/dist/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf +0 -0
  34. package/dist/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf +0 -0
  35. package/dist/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff +0 -0
  36. package/dist/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2 +0 -0
  37. package/dist/assets/KaTeX_Fraktur-Regular-CB_wures.ttf +0 -0
  38. package/dist/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2 +0 -0
  39. package/dist/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff +0 -0
  40. package/dist/assets/KaTeX_Main-Bold-Cx986IdX.woff2 +0 -0
  41. package/dist/assets/KaTeX_Main-Bold-Jm3AIy58.woff +0 -0
  42. package/dist/assets/KaTeX_Main-Bold-waoOVXN0.ttf +0 -0
  43. package/dist/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2 +0 -0
  44. package/dist/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf +0 -0
  45. package/dist/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff +0 -0
  46. package/dist/assets/KaTeX_Main-Italic-3WenGoN9.ttf +0 -0
  47. package/dist/assets/KaTeX_Main-Italic-BMLOBm91.woff +0 -0
  48. package/dist/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2 +0 -0
  49. package/dist/assets/KaTeX_Main-Regular-B22Nviop.woff2 +0 -0
  50. package/dist/assets/KaTeX_Main-Regular-Dr94JaBh.woff +0 -0
  51. package/dist/assets/KaTeX_Main-Regular-ypZvNtVU.ttf +0 -0
  52. package/dist/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf +0 -0
  53. package/dist/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2 +0 -0
  54. package/dist/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff +0 -0
  55. package/dist/assets/KaTeX_Math-Italic-DA0__PXp.woff +0 -0
  56. package/dist/assets/KaTeX_Math-Italic-flOr_0UB.ttf +0 -0
  57. package/dist/assets/KaTeX_Math-Italic-t53AETM-.woff2 +0 -0
  58. package/dist/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf +0 -0
  59. package/dist/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2 +0 -0
  60. package/dist/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff +0 -0
  61. package/dist/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2 +0 -0
  62. package/dist/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff +0 -0
  63. package/dist/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf +0 -0
  64. package/dist/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf +0 -0
  65. package/dist/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff +0 -0
  66. package/dist/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2 +0 -0
  67. package/dist/assets/KaTeX_Script-Regular-C5JkGWo-.ttf +0 -0
  68. package/dist/assets/KaTeX_Script-Regular-D3wIWfF6.woff2 +0 -0
  69. package/dist/assets/KaTeX_Script-Regular-D5yQViql.woff +0 -0
  70. package/dist/assets/KaTeX_Size1-Regular-C195tn64.woff +0 -0
  71. package/dist/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf +0 -0
  72. package/dist/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2 +0 -0
  73. package/dist/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf +0 -0
  74. package/dist/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2 +0 -0
  75. package/dist/assets/KaTeX_Size2-Regular-oD1tc_U0.woff +0 -0
  76. package/dist/assets/KaTeX_Size3-Regular-CTq5MqoE.woff +0 -0
  77. package/dist/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf +0 -0
  78. package/dist/assets/KaTeX_Size4-Regular-BF-4gkZK.woff +0 -0
  79. package/dist/assets/KaTeX_Size4-Regular-DWFBv043.ttf +0 -0
  80. package/dist/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2 +0 -0
  81. package/dist/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff +0 -0
  82. package/dist/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2 +0 -0
  83. package/dist/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf +0 -0
  84. package/dist/assets/index-C75KddSa.css +0 -1
  85. package/dist/assets/index-DsHb4M_F.js +0 -542
  86. package/src/components/runtime-mdx.tsx +0 -82
@@ -0,0 +1 @@
1
+ @import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap";/*! tailwindcss v4.1.17 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-ordinal:initial;--tw-slashed-zero:initial;--tw-numeric-figure:initial;--tw-numeric-spacing:initial;--tw-numeric-fraction:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial;--tw-content:"";--tw-space-x-reverse:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-amber-500:oklch(76.9% .188 70.08);--color-amber-600:oklch(66.6% .179 58.318);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-emerald-50:oklch(97.9% .021 166.113);--color-emerald-500:oklch(69.6% .17 162.48);--color-cyan-500:oklch(71.5% .143 215.221);--color-cyan-600:oklch(60.9% .126 221.723);--color-blue-50:oklch(97% .014 254.604);--color-blue-500:oklch(62.3% .214 259.815);--color-purple-400:oklch(71.4% .203 305.504);--color-purple-600:oklch(55.8% .288 302.321);--color-rose-50:oklch(96.9% .015 12.422);--color-rose-500:oklch(64.5% .246 16.439);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-xl:36rem;--container-4xl:56rem;--container-5xl:64rem;--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-6xl:3.75rem;--text-6xl--line-height:1;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tighter:-.05em;--tracking-tight:-.025em;--tracking-wide:.025em;--tracking-wider:.05em;--tracking-widest:.1em;--leading-relaxed:1.625;--radius-sm:calc(var(--radius) - 4px);--radius-md:calc(var(--radius) - 2px);--radius-lg:var(--radius);--radius-xl:calc(var(--radius) + 4px);--ease-out:cubic-bezier(0,0,.2,1);--ease-in-out:cubic-bezier(.4,0,.2,1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4,0,.6,1)infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-background:hsl(var(--background));--color-foreground:hsl(var(--foreground));--color-card:hsl(var(--card));--color-card-foreground:hsl(var(--card-foreground));--color-popover:hsl(var(--popover));--color-popover-foreground:hsl(var(--popover-foreground));--color-primary:hsl(var(--primary));--color-primary-foreground:hsl(var(--primary-foreground));--color-secondary:hsl(var(--secondary));--color-secondary-foreground:hsl(var(--secondary-foreground));--color-muted:hsl(var(--muted));--color-muted-foreground:hsl(var(--muted-foreground));--color-accent:hsl(var(--accent));--color-accent-foreground:hsl(var(--accent-foreground));--color-destructive:hsl(var(--destructive));--color-destructive-foreground:hsl(var(--destructive-foreground));--color-border:hsl(var(--border));--color-input:hsl(var(--input));--color-ring:hsl(var(--ring));--color-sidebar-foreground:hsl(var(--sidebar-foreground));--color-sidebar-accent:hsl(var(--sidebar-accent));--color-sidebar-accent-foreground:hsl(var(--sidebar-accent-foreground));--color-sidebar-border:hsl(var(--sidebar-border));--color-sidebar-ring:hsl(var(--sidebar-ring))}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--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:var(--default-font-feature-settings,normal);font-variation-settings:var(--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:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);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}:-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{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}: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:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::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{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-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]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}*{border-color:hsl(var(--border))}html{scroll-behavior:smooth}body{background-color:hsl(var(--background));color:hsl(var(--foreground));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11","ss01","liga","calt";letter-spacing:-.01em;line-height:1.7}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-family:ui-sans-serif,system-ui,sans-serif;font-weight:600;line-height:1.25}h1{letter-spacing:-.025em;font-weight:700}:focus-visible{box-shadow:0 0 0 1px hsl(var(--ring)),0 0 0 2px hsl(var(--background));outline:none}::selection{background-color:hsl(var(--primary)/.15);color:hsl(var(--foreground))}.prose{letter-spacing:.005em;max-width:var(--prose-width);line-height:1.8}.prose p{margin-bottom:1.5em}.prose a{color:hsl(var(--primary));text-underline-offset:2px;text-decoration:underline;-webkit-text-decoration-color:hsl(var(--primary)/.4);text-decoration-color:hsl(var(--primary)/.4);transition:text-decoration-color .15s}.prose a:hover{-webkit-text-decoration-color:hsl(var(--primary));text-decoration-color:hsl(var(--primary))}kbd{border:1px solid hsl(var(--border));background-color:hsl(var(--muted)/.5);border-radius:.25rem;padding:.125rem .375rem;font-family:ui-monospace,monospace;font-size:.75em}pre{letter-spacing:0;font-family:ui-monospace,monospace;font-size:.875rem}code{letter-spacing:0;font-family:ui-monospace,monospace;font-size:.875em}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background-color:hsl(var(--border));border-radius:9999px}::-webkit-scrollbar-thumb:hover{background-color:hsl(var(--muted-foreground)/.3)}button,a,[role=button]{cursor:pointer}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing)*0)}.inset-x-0{inset-inline:calc(var(--spacing)*0)}.inset-y-0{inset-block:calc(var(--spacing)*0)}.-top-12{top:calc(var(--spacing)*-12)}.top-0{top:calc(var(--spacing)*0)}.top-1\.5{top:calc(var(--spacing)*1.5)}.top-1\/2{top:50%}.top-2{top:calc(var(--spacing)*2)}.top-3\.5{top:calc(var(--spacing)*3.5)}.top-4{top:calc(var(--spacing)*4)}.-right-12{right:calc(var(--spacing)*-12)}.right-0{right:calc(var(--spacing)*0)}.right-1{right:calc(var(--spacing)*1)}.right-3{right:calc(var(--spacing)*3)}.right-4{right:calc(var(--spacing)*4)}.-bottom-12{bottom:calc(var(--spacing)*-12)}.bottom-0{bottom:calc(var(--spacing)*0)}.-left-12{left:calc(var(--spacing)*-12)}.left-0{left:calc(var(--spacing)*0)}.left-1\/2{left:50%}.left-2{left:calc(var(--spacing)*2)}.left-4{left:calc(var(--spacing)*4)}.z-10{z-index:10}.z-20{z-index:20}.z-40{z-index:40}.z-50{z-index:50}.z-\[9999\]{z-index:9999}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.-mx-1{margin-inline:calc(var(--spacing)*-1)}.-mx-1\.5{margin-inline:calc(var(--spacing)*-1.5)}.-mx-3{margin-inline:calc(var(--spacing)*-3)}.-mx-\[calc\(\(var\(--gallery-width\)-var\(--content-width\)\)\/2\+var\(--page-padding\)\)\]{margin-inline:calc(calc((var(--gallery-width) - var(--content-width))/2 + var(--page-padding))*-1)}.mx-1{margin-inline:calc(var(--spacing)*1)}.mx-2{margin-inline:calc(var(--spacing)*2)}.mx-3\.5{margin-inline:calc(var(--spacing)*3.5)}.mx-auto{margin-inline:auto}.my-1{margin-block:calc(var(--spacing)*1)}.my-4{margin-block:calc(var(--spacing)*4)}.my-6{margin-block:calc(var(--spacing)*6)}.my-8{margin-block:calc(var(--spacing)*8)}.my-24{margin-block:calc(var(--spacing)*24)}.-mt-4{margin-top:calc(var(--spacing)*-4)}.mt-0{margin-top:calc(var(--spacing)*0)}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-1\.5{margin-top:calc(var(--spacing)*1.5)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-6{margin-top:calc(var(--spacing)*6)}.mt-8{margin-top:calc(var(--spacing)*8)}.mt-10{margin-top:calc(var(--spacing)*10)}.mt-12{margin-top:calc(var(--spacing)*12)}.mt-32{margin-top:calc(var(--spacing)*32)}.mr-2{margin-right:calc(var(--spacing)*2)}.mb-1{margin-bottom:calc(var(--spacing)*1)}.mb-1\.5{margin-bottom:calc(var(--spacing)*1.5)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-8{margin-bottom:calc(var(--spacing)*8)}.mb-32{margin-bottom:calc(var(--spacing)*32)}.-ml-4{margin-left:calc(var(--spacing)*-4)}.ml-1{margin-left:calc(var(--spacing)*1)}.ml-6{margin-left:calc(var(--spacing)*6)}.ml-auto{margin-left:auto}.line-clamp-1{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.aspect-\[4\/3\]{aspect-ratio:4/3}.aspect-square{aspect-ratio:1}.size-4{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.size-full{width:100%;height:100%}.h-1\.5{height:calc(var(--spacing)*1.5)}.h-2{height:calc(var(--spacing)*2)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-7{height:calc(var(--spacing)*7)}.h-8{height:calc(var(--spacing)*8)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-11{height:calc(var(--spacing)*11)}.h-12{height:calc(var(--spacing)*12)}.h-32{height:calc(var(--spacing)*32)}.h-\[1px\]{height:1px}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.h-svh{height:100svh}.max-h-\[--radix-select-content-available-height\]{max-height:--radix-select-content-available-height}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-full{max-height:100%}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-\[50vh\]{min-height:50vh}.min-h-screen{min-height:100vh}.min-h-svh{min-height:100svh}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-2{width:calc(var(--spacing)*2)}.w-3{width:calc(var(--spacing)*3)}.w-3\.5{width:calc(var(--spacing)*3.5)}.w-3\/4{width:75%}.w-4{width:calc(var(--spacing)*4)}.w-5{width:calc(var(--spacing)*5)}.w-7{width:calc(var(--spacing)*7)}.w-8{width:calc(var(--spacing)*8)}.w-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-20{width:calc(var(--spacing)*20)}.w-\[--sidebar-width\]{width:--sidebar-width}.w-\[1px\]{width:1px}.w-auto{width:auto}.w-fit{width:fit-content}.w-full{width:100%}.w-screen{width:100vw}.max-w-4xl{max-width:var(--container-4xl)}.max-w-5xl{max-width:var(--container-5xl)}.max-w-\[--skeleton-width\]{max-width:--skeleton-width}.max-w-\[var\(--content-width\)\]{max-width:var(--content-width)}.max-w-\[var\(--gallery-width\)\]{max-width:var(--gallery-width)}.max-w-\[var\(--prose-width\)\]{max-width:var(--prose-width)}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.max-w-xl{max-width:var(--container-xl)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-5{min-width:calc(var(--spacing)*5)}.min-w-\[3ch\]{min-width:3ch}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.grow{flex-grow:1}.grow-0{flex-grow:0}.basis-full{flex-basis:100%}.border-collapse{border-collapse:collapse}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:--radix-dropdown-menu-content-transform-origin}.origin-\[--radix-select-content-transform-origin\]{transform-origin:--radix-select-content-transform-origin}.origin-\[--radix-tooltip-content-transform-origin\]{transform-origin:--radix-tooltip-content-transform-origin}.-translate-x-1{--tw-translate-x:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-x-1\/2{--tw-translate-x: -50% ;translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-x-px{--tw-translate-x:-1px;translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-x-px{--tw-translate-x:1px;translate:var(--tw-translate-x)var(--tw-translate-y)}.-translate-y-1\/2{--tw-translate-y: -50% ;translate:var(--tw-translate-x)var(--tw-translate-y)}.scale-0{--tw-scale-x:0%;--tw-scale-y:0%;--tw-scale-z:0%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-100{--tw-scale-x:100%;--tw-scale-y:100%;--tw-scale-z:100%;scale:var(--tw-scale-x)var(--tw-scale-y)}.-rotate-90{rotate:-90deg}.rotate-0{rotate:none}.rotate-90{rotate:90deg}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-\[repeat\(auto-fill\,minmax\(180px\,1fr\)\)\]{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.items-baseline{align-items:baseline}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-0{gap:calc(var(--spacing)*0)}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}.gap-8{gap:calc(var(--spacing)*8)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1.5)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1.5)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*8)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*8)*calc(1 - var(--tw-space-y-reverse)))}.gap-x-6{column-gap:calc(var(--spacing)*6)}.gap-y-px{row-gap:1px}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-sm{border-radius:var(--radius-sm)}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-none{--tw-border-style:none;border-style:none}.border-border{border-color:var(--color-border)}.border-border\/30{border-color:hsl(var(--border))}@supports (color:color-mix(in lab,red,red)){.border-border\/30{border-color:color-mix(in srgb,hsl(var(--border))30%,transparent);border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/30{border-color:color-mix(in oklab,var(--color-border)30%,transparent)}}}.border-border\/40{border-color:hsl(var(--border))}@supports (color:color-mix(in lab,red,red)){.border-border\/40{border-color:color-mix(in srgb,hsl(var(--border))40%,transparent);border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/40{border-color:color-mix(in oklab,var(--color-border)40%,transparent)}}}.border-border\/50{border-color:hsl(var(--border))}@supports (color:color-mix(in lab,red,red)){.border-border\/50{border-color:color-mix(in srgb,hsl(var(--border))50%,transparent);border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/50{border-color:color-mix(in oklab,var(--color-border)50%,transparent)}}}.border-border\/60{border-color:hsl(var(--border))}@supports (color:color-mix(in lab,red,red)){.border-border\/60{border-color:color-mix(in srgb,hsl(var(--border))60%,transparent);border-color:var(--color-border)}@supports (color:color-mix(in lab,red,red)){.border-border\/60{border-color:color-mix(in oklab,var(--color-border)60%,transparent)}}}.border-current{border-color:currentColor}.border-destructive\/30{border-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.border-destructive\/30{border-color:color-mix(in srgb,hsl(var(--destructive))30%,transparent);border-color:var(--color-destructive)}@supports (color:color-mix(in lab,red,red)){.border-destructive\/30{border-color:color-mix(in oklab,var(--color-destructive)30%,transparent)}}}.border-input{border-color:var(--color-input)}.border-muted-foreground\/40{border-color:hsl(var(--muted-foreground))}@supports (color:color-mix(in lab,red,red)){.border-muted-foreground\/40{border-color:color-mix(in srgb,hsl(var(--muted-foreground))40%,transparent);border-color:var(--color-muted-foreground)}@supports (color:color-mix(in lab,red,red)){.border-muted-foreground\/40{border-color:color-mix(in oklab,var(--color-muted-foreground)40%,transparent)}}}.border-primary{border-color:var(--color-primary)}.border-sidebar-border{border-color:var(--color-sidebar-border)}.border-transparent{border-color:#0000}.border-t-transparent{border-top-color:#0000}.bg-background{background-color:var(--color-background)}.bg-background\/80{background-color:hsl(var(--background))}@supports (color:color-mix(in lab,red,red)){.bg-background\/80{background-color:color-mix(in srgb,hsl(var(--background))80%,transparent);background-color:var(--color-background)}@supports (color:color-mix(in lab,red,red)){.bg-background\/80{background-color:color-mix(in oklab,var(--color-background)80%,transparent)}}}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:var(--color-black)}@supports (color:color-mix(in lab,red,red)){.bg-black\/80{background-color:color-mix(in oklab,var(--color-black)80%,transparent)}}}.bg-border{background-color:var(--color-border)}.bg-card{background-color:var(--color-card)}.bg-card\/20{background-color:hsl(var(--card))}@supports (color:color-mix(in lab,red,red)){.bg-card\/20{background-color:color-mix(in srgb,hsl(var(--card))20%,transparent);background-color:var(--color-card)}@supports (color:color-mix(in lab,red,red)){.bg-card\/20{background-color:color-mix(in oklab,var(--color-card)20%,transparent)}}}.bg-card\/30{background-color:hsl(var(--card))}@supports (color:color-mix(in lab,red,red)){.bg-card\/30{background-color:color-mix(in srgb,hsl(var(--card))30%,transparent);background-color:var(--color-card)}@supports (color:color-mix(in lab,red,red)){.bg-card\/30{background-color:color-mix(in oklab,var(--color-card)30%,transparent)}}}.bg-current{background-color:currentColor}.bg-destructive{background-color:var(--color-destructive)}.bg-destructive\/5{background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/5{background-color:color-mix(in srgb,hsl(var(--destructive))5%,transparent);background-color:var(--color-destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/5{background-color:color-mix(in oklab,var(--color-destructive)5%,transparent)}}}.bg-destructive\/10{background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/10{background-color:color-mix(in srgb,hsl(var(--destructive))10%,transparent);background-color:var(--color-destructive)}@supports (color:color-mix(in lab,red,red)){.bg-destructive\/10{background-color:color-mix(in oklab,var(--color-destructive)10%,transparent)}}}.bg-green-500{background-color:var(--color-green-500)}.bg-muted{background-color:var(--color-muted)}.bg-muted\/20{background-color:hsl(var(--muted))}@supports (color:color-mix(in lab,red,red)){.bg-muted\/20{background-color:color-mix(in srgb,hsl(var(--muted))20%,transparent);background-color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/20{background-color:color-mix(in oklab,var(--color-muted)20%,transparent)}}}.bg-muted\/30{background-color:hsl(var(--muted))}@supports (color:color-mix(in lab,red,red)){.bg-muted\/30{background-color:color-mix(in srgb,hsl(var(--muted))30%,transparent);background-color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/30{background-color:color-mix(in oklab,var(--color-muted)30%,transparent)}}}.bg-muted\/50{background-color:hsl(var(--muted))}@supports (color:color-mix(in lab,red,red)){.bg-muted\/50{background-color:color-mix(in srgb,hsl(var(--muted))50%,transparent);background-color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.bg-muted\/50{background-color:color-mix(in oklab,var(--color-muted)50%,transparent)}}}.bg-popover{background-color:var(--color-popover)}.bg-primary{background-color:var(--color-primary)}.bg-primary\/20{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab,red,red)){.bg-primary\/20{background-color:color-mix(in srgb,hsl(var(--primary))20%,transparent);background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/20{background-color:color-mix(in oklab,var(--color-primary)20%,transparent)}}}.bg-primary\/40{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab,red,red)){.bg-primary\/40{background-color:color-mix(in srgb,hsl(var(--primary))40%,transparent);background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/40{background-color:color-mix(in oklab,var(--color-primary)40%,transparent)}}}.bg-primary\/60{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab,red,red)){.bg-primary\/60{background-color:color-mix(in srgb,hsl(var(--primary))60%,transparent);background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.bg-primary\/60{background-color:color-mix(in oklab,var(--color-primary)60%,transparent)}}}.bg-red-500{background-color:var(--color-red-500)}.bg-secondary{background-color:var(--color-secondary)}.bg-sidebar-border{background-color:var(--color-sidebar-border)}.bg-transparent{background-color:#0000}.fill-current{fill:currentColor}.object-contain{object-fit:contain}.p-0{padding:calc(var(--spacing)*0)}.p-1{padding:calc(var(--spacing)*1)}.p-1\.5{padding:calc(var(--spacing)*1.5)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-8{padding:calc(var(--spacing)*8)}.p-12{padding:calc(var(--spacing)*12)}.p-16{padding:calc(var(--spacing)*16)}.px-1{padding-inline:calc(var(--spacing)*1)}.px-1\.5{padding-inline:calc(var(--spacing)*1.5)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-2\.5{padding-inline:calc(var(--spacing)*2.5)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.px-8{padding-inline:calc(var(--spacing)*8)}.px-\[var\(--page-padding\)\]{padding-inline:var(--page-padding)}.py-0\.5{padding-block:calc(var(--spacing)*.5)}.py-1{padding-block:calc(var(--spacing)*1)}.py-1\.5{padding-block:calc(var(--spacing)*1.5)}.py-2{padding-block:calc(var(--spacing)*2)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.py-8{padding-block:calc(var(--spacing)*8)}.py-12{padding-block:calc(var(--spacing)*12)}.py-16{padding-block:calc(var(--spacing)*16)}.py-24{padding-block:calc(var(--spacing)*24)}.pt-0{padding-top:calc(var(--spacing)*0)}.pt-0\.5{padding-top:calc(var(--spacing)*.5)}.pt-4{padding-top:calc(var(--spacing)*4)}.pr-2{padding-right:calc(var(--spacing)*2)}.pb-1{padding-bottom:calc(var(--spacing)*1)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-3{padding-bottom:calc(var(--spacing)*3)}.pl-3{padding-left:calc(var(--spacing)*3)}.pl-4{padding-left:calc(var(--spacing)*4)}.pl-6{padding-left:calc(var(--spacing)*6)}.pl-8{padding-left:calc(var(--spacing)*8)}.text-center{text-align:center}.text-left{text-align:left}.align-top{vertical-align:top}.font-mono{font-family:var(--font-mono)}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.text-\[0\.85em\]{font-size:.85em}.text-\[9px\]{font-size:9px}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-normal{--tw-font-weight:var(--font-weight-normal);font-weight:var(--font-weight-normal)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.tracking-tighter{--tw-tracking:var(--tracking-tighter);letter-spacing:var(--tracking-tighter)}.tracking-wide{--tw-tracking:var(--tracking-wide);letter-spacing:var(--tracking-wide)}.tracking-wider{--tw-tracking:var(--tracking-wider);letter-spacing:var(--tracking-wider)}.tracking-widest{--tw-tracking:var(--tracking-widest);letter-spacing:var(--tracking-widest)}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.text-amber-600{color:var(--color-amber-600)}.text-card-foreground{color:var(--color-card-foreground)}.text-cyan-600{color:var(--color-cyan-600)}.text-destructive{color:var(--color-destructive)}.text-destructive-foreground{color:var(--color-destructive-foreground)}.text-foreground{color:var(--color-foreground)}.text-foreground\/80{color:hsl(var(--foreground))}@supports (color:color-mix(in lab,red,red)){.text-foreground\/80{color:var(--color-foreground)}@supports (color:color-mix(in lab,red,red)){.text-foreground\/80{color:color-mix(in oklab,var(--color-foreground)80%,transparent)}}}.text-muted-foreground{color:var(--color-muted-foreground)}.text-muted-foreground\/30{color:hsl(var(--muted-foreground))}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/30{color:var(--color-muted-foreground)}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/30{color:color-mix(in oklab,var(--color-muted-foreground)30%,transparent)}}}.text-muted-foreground\/40{color:hsl(var(--muted-foreground))}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/40{color:var(--color-muted-foreground)}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/40{color:color-mix(in oklab,var(--color-muted-foreground)40%,transparent)}}}.text-muted-foreground\/50{color:hsl(var(--muted-foreground))}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/50{color:var(--color-muted-foreground)}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/50{color:color-mix(in oklab,var(--color-muted-foreground)50%,transparent)}}}.text-muted-foreground\/60{color:hsl(var(--muted-foreground))}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/60{color:var(--color-muted-foreground)}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/60{color:color-mix(in oklab,var(--color-muted-foreground)60%,transparent)}}}.text-muted-foreground\/70{color:hsl(var(--muted-foreground))}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/70{color:var(--color-muted-foreground)}@supports (color:color-mix(in lab,red,red)){.text-muted-foreground\/70{color:color-mix(in oklab,var(--color-muted-foreground)70%,transparent)}}}.text-popover-foreground{color:var(--color-popover-foreground)}.text-primary{color:var(--color-primary)}.text-primary-foreground{color:var(--color-primary-foreground)}.text-primary-foreground\/60{color:hsl(var(--primary-foreground))}@supports (color:color-mix(in lab,red,red)){.text-primary-foreground\/60{color:var(--color-primary-foreground)}@supports (color:color-mix(in lab,red,red)){.text-primary-foreground\/60{color:color-mix(in oklab,var(--color-primary-foreground)60%,transparent)}}}.text-purple-600{color:var(--color-purple-600)}.text-red-600{color:var(--color-red-600)}.text-secondary-foreground{color:var(--color-secondary-foreground)}.text-sidebar-foreground{color:var(--color-sidebar-foreground)}.text-sidebar-foreground\/70{color:hsl(var(--sidebar-foreground))}@supports (color:color-mix(in lab,red,red)){.text-sidebar-foreground\/70{color:var(--color-sidebar-foreground)}@supports (color:color-mix(in lab,red,red)){.text-sidebar-foreground\/70{color:color-mix(in oklab,var(--color-sidebar-foreground)70%,transparent)}}}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal,)var(--tw-slashed-zero,)var(--tw-numeric-figure,)var(--tw-numeric-spacing,)var(--tw-numeric-fraction,)}.underline-offset-2{text-underline-offset:2px}.underline-offset-4{text-underline-offset:4px}.accent-foreground{accent-color:var(--color-foreground)}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-100{opacity:1}.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\]{--tw-shadow:0 0 0 1px var(--tw-shadow-color,hsl(var(--sidebar-border)));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-sidebar-ring{--tw-ring-color:var(--color-sidebar-ring)}.ring-offset-background{--tw-ring-offset-color:var(--color-background)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.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(var(--blur-sm));-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,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[left\,right\,width\]{transition-property:left,right,width;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[margin\,opacity\]{transition-property:margin,opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[width\,height\,padding\]{transition-property:width,height,padding;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-\[width\]{transition-property:width;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.duration-700{--tw-duration:.7s;transition-duration:.7s}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.ease-linear{--tw-ease:linear;transition-timing-function:linear}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.group-focus-within\/menu-item\:opacity-100:is(:where(.group\/menu-item):focus-within *){opacity:1}@media(hover:hover){.group-hover\:translate-x-0:is(:where(.group):hover *){--tw-translate-x:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-hover\:underline:is(:where(.group):hover *){text-decoration-line:underline}.group-hover\:opacity-100:is(:where(.group):hover *),.group-hover\/menu-item\:opacity-100:is(:where(.group\/menu-item):hover *){opacity:1}}.group-has-\[\[data-sidebar\=menu-action\]\]\/menu-item\:pr-8:is(:where(.group\/menu-item):has([data-sidebar=menu-action]) *){padding-right:calc(var(--spacing)*8)}.group-data-\[collapsible\=icon\]\:-mt-8:is(:where(.group)[data-collapsible=icon] *){margin-top:calc(var(--spacing)*-8)}.group-data-\[collapsible\=icon\]\:hidden:is(:where(.group)[data-collapsible=icon] *){display:none}.group-data-\[collapsible\=icon\]\:\!size-8:is(:where(.group)[data-collapsible=icon] *){width:calc(var(--spacing)*8)!important;height:calc(var(--spacing)*8)!important}.group-data-\[collapsible\=icon\]\:w-\[--sidebar-width-icon\]:is(:where(.group)[data-collapsible=icon] *){width:--sidebar-width-icon}.group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)\)\]:is(:where(.group)[data-collapsible=icon] *){width:calc(var(--sidebar-width-icon) + 1rem)}.group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)_\+2px\)\]:is(:where(.group)[data-collapsible=icon] *){width:calc(var(--sidebar-width-icon) + 1rem + 2px)}.group-data-\[collapsible\=icon\]\:overflow-hidden:is(:where(.group)[data-collapsible=icon] *){overflow:hidden}.group-data-\[collapsible\=icon\]\:\!p-0:is(:where(.group)[data-collapsible=icon] *){padding:calc(var(--spacing)*0)!important}.group-data-\[collapsible\=icon\]\:\!p-2:is(:where(.group)[data-collapsible=icon] *){padding:calc(var(--spacing)*2)!important}.group-data-\[collapsible\=icon\]\:opacity-0:is(:where(.group)[data-collapsible=icon] *){opacity:0}.group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\]:is(:where(.group)[data-collapsible=offcanvas] *){right:calc(var(--sidebar-width)*-1)}.group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\]:is(:where(.group)[data-collapsible=offcanvas] *){left:calc(var(--sidebar-width)*-1)}.group-data-\[collapsible\=offcanvas\]\:w-0:is(:where(.group)[data-collapsible=offcanvas] *){width:calc(var(--spacing)*0)}.group-data-\[collapsible\=offcanvas\]\:translate-x-0:is(:where(.group)[data-collapsible=offcanvas] *){--tw-translate-x:calc(var(--spacing)*0);translate:var(--tw-translate-x)var(--tw-translate-y)}.group-data-\[side\=left\]\:-right-4:is(:where(.group)[data-side=left] *){right:calc(var(--spacing)*-4)}.group-data-\[side\=left\]\:border-r:is(:where(.group)[data-side=left] *){border-right-style:var(--tw-border-style);border-right-width:1px}.group-data-\[side\=right\]\:left-0:is(:where(.group)[data-side=right] *){left:calc(var(--spacing)*0)}.group-data-\[side\=right\]\:rotate-180:is(:where(.group)[data-side=right] *){rotate:180deg}.group-data-\[side\=right\]\:border-l:is(:where(.group)[data-side=right] *){border-left-style:var(--tw-border-style);border-left-width:1px}.group-data-\[variant\=floating\]\:rounded-lg:is(:where(.group)[data-variant=floating] *){border-radius:var(--radius-lg)}.group-data-\[variant\=floating\]\:border:is(:where(.group)[data-variant=floating] *){border-style:var(--tw-border-style);border-width:1px}.group-data-\[variant\=floating\]\:border-sidebar-border:is(:where(.group)[data-variant=floating] *){border-color:var(--color-sidebar-border)}.group-data-\[variant\=floating\]\:shadow:is(:where(.group)[data-variant=floating] *){--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}@media(hover:hover){.peer-hover\/menu-button\:text-sidebar-accent-foreground:is(:where(.peer\/menu-button):hover~*){color:var(--color-sidebar-accent-foreground)}}.peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground:is(:where(.peer\/menu-button)[data-active=true]~*){color:var(--color-sidebar-accent-foreground)}.peer-data-\[size\=default\]\/menu-button\:top-1\.5:is(:where(.peer\/menu-button)[data-size=default]~*){top:calc(var(--spacing)*1.5)}.peer-data-\[size\=lg\]\/menu-button\:top-2\.5:is(:where(.peer\/menu-button)[data-size=lg]~*){top:calc(var(--spacing)*2.5)}.peer-data-\[size\=sm\]\/menu-button\:top-1:is(:where(.peer\/menu-button)[data-size=sm]~*){top:calc(var(--spacing)*1)}.marker\:text-muted-foreground ::marker{color:var(--color-muted-foreground)}.marker\:text-muted-foreground::marker{color:var(--color-muted-foreground)}.marker\:text-muted-foreground ::-webkit-details-marker{color:var(--color-muted-foreground)}.marker\:text-muted-foreground::-webkit-details-marker{color:var(--color-muted-foreground)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--color-foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--color-muted-foreground)}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:-inset-2:after{content:var(--tw-content);inset:calc(var(--spacing)*-2)}.after\:inset-y-0:after{content:var(--tw-content);inset-block:calc(var(--spacing)*0)}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-\[2px\]:after{content:var(--tw-content);width:2px}.group-data-\[collapsible\=offcanvas\]\:after\:left-full:is(:where(.group)[data-collapsible=offcanvas] *):after{content:var(--tw-content);left:100%}.first\:mt-0:first-child{margin-top:calc(var(--spacing)*0)}.last\:mb-0:last-child{margin-bottom:calc(var(--spacing)*0)}.last\:border-b-0:last-child{border-bottom-style:var(--tw-border-style);border-bottom-width:0}@media(hover:hover){.hover\:scale-\[1\.02\]:hover{scale:1.02}.hover\:bg-accent:hover{background-color:var(--color-accent)}.hover\:bg-destructive\/80:hover{background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/80:hover{background-color:color-mix(in srgb,hsl(var(--destructive))80%,transparent);background-color:var(--color-destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/80:hover{background-color:color-mix(in oklab,var(--color-destructive)80%,transparent)}}}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive))}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in srgb,hsl(var(--destructive))90%,transparent);background-color:var(--color-destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--color-destructive)90%,transparent)}}}.hover\:bg-green-600:hover{background-color:var(--color-green-600)}.hover\:bg-muted\/30:hover{background-color:hsl(var(--muted))}@supports (color:color-mix(in lab,red,red)){.hover\:bg-muted\/30:hover{background-color:color-mix(in srgb,hsl(var(--muted))30%,transparent);background-color:var(--color-muted)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-muted\/30:hover{background-color:color-mix(in oklab,var(--color-muted)30%,transparent)}}}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/80:hover{background-color:color-mix(in srgb,hsl(var(--primary))80%,transparent);background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/80:hover{background-color:color-mix(in oklab,var(--color-primary)80%,transparent)}}}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary))}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in srgb,hsl(var(--primary))90%,transparent);background-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--color-primary)90%,transparent)}}}.hover\:bg-red-600:hover{background-color:var(--color-red-600)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary))}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in srgb,hsl(var(--secondary))80%,transparent);background-color:var(--color-secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--color-secondary)80%,transparent)}}}.hover\:bg-sidebar-accent:hover{background-color:var(--color-sidebar-accent)}.hover\:text-accent-foreground:hover{color:var(--color-accent-foreground)}.hover\:text-foreground:hover{color:var(--color-foreground)}.hover\:text-sidebar-accent-foreground:hover{color:var(--color-sidebar-accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover{--tw-shadow:0 0 0 1px var(--tw-shadow-color,hsl(var(--sidebar-accent)));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:after\:bg-sidebar-border:hover:after{content:var(--tw-content);background-color:var(--color-sidebar-border)}}.focus\:bg-accent:focus{background-color:var(--color-accent)}.focus\:text-accent-foreground:focus{color:var(--color-accent-foreground)}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--color-ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.focus-visible\:ring-2:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:var(--color-ring)}.focus-visible\:ring-sidebar-ring:focus-visible{--tw-ring-color:var(--color-sidebar-ring)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color)}.focus-visible\:outline-none:focus-visible{--tw-outline-style:none;outline-style:none}.active\:bg-sidebar-accent:active{background-color:var(--color-sidebar-accent)}.active\:text-sidebar-accent-foreground:active{color:var(--color-sidebar-accent-foreground)}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.aria-disabled\:pointer-events-none[aria-disabled=true]{pointer-events:none}.aria-disabled\:opacity-50[aria-disabled=true]{opacity:.5}.data-\[active\=true\]\:bg-sidebar-accent[data-active=true]{background-color:var(--color-sidebar-accent)}.data-\[active\=true\]\:font-medium[data-active=true]{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.data-\[active\=true\]\:text-sidebar-accent-foreground[data-active=true]{color:var(--color-sidebar-accent-foreground)}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:var(--color-muted-foreground)}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:calc(var(--spacing)*1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:calc(var(--spacing)*-1);translate:var(--tw-translate-x)var(--tw-translate-y)}.data-\[state\=closed\]\:duration-300[data-state=closed]{--tw-duration:.3s;transition-duration:.3s}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--color-accent)}.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:var(--color-secondary)}.data-\[state\=open\]\:opacity-100[data-state=open]{opacity:1}.data-\[state\=open\]\:duration-500[data-state=open]{--tw-duration:.5s;transition-duration:.5s}@media(hover:hover){.data-\[state\=open\]\:hover\:bg-sidebar-accent[data-state=open]:hover{background-color:var(--color-sidebar-accent)}.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground[data-state=open]:hover{color:var(--color-sidebar-accent-foreground)}}@media(min-width:40rem){.sm\:flex{display:flex}.sm\:min-h-\[70vh\]{min-height:70vh}.sm\:max-w-sm{max-width:var(--container-sm)}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2\.5{gap:calc(var(--spacing)*2.5)}.sm\:gap-4{gap:calc(var(--spacing)*4)}:where(.sm\:space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*2)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-x-reverse)))}.sm\:py-12{padding-block:calc(var(--spacing)*12)}.sm\:text-left{text-align:left}}@media(min-width:48rem){.md\:block{display:block}.md\:flex{display:flex}.md\:min-h-screen{min-height:100vh}.md\:basis-1\/2{flex-basis:50%}.md\:py-6{padding-block:calc(var(--spacing)*6)}.md\:py-16{padding-block:calc(var(--spacing)*16)}.md\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.md\:text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.md\:opacity-0{opacity:0}.md\:peer-data-\[variant\=inset\]\:m-2:is(:where(.peer)[data-variant=inset]~*){margin:calc(var(--spacing)*2)}.md\:peer-data-\[variant\=inset\]\:ml-0:is(:where(.peer)[data-variant=inset]~*){margin-left:calc(var(--spacing)*0)}.md\:peer-data-\[variant\=inset\]\:rounded-xl:is(:where(.peer)[data-variant=inset]~*){border-radius:var(--radius-xl)}.md\:peer-data-\[variant\=inset\]\:shadow:is(:where(.peer)[data-variant=inset]~*){--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.md\:peer-data-\[state\=collapsed\]\:peer-data-\[variant\=inset\]\:ml-2:is(:where(.peer)[data-state=collapsed]~*):is(:where(.peer)[data-variant=inset]~*){margin-left:calc(var(--spacing)*2)}}.after\:md\:hidden:after{content:var(--tw-content)}@media(min-width:48rem){.after\:md\:hidden:after{display:none}}@media(min-width:64rem){.lg\:basis-1\/3{flex-basis:33.3333%}}@media(prefers-color-scheme:dark){.dark\:text-amber-500{color:var(--color-amber-500)}.dark\:text-cyan-500{color:var(--color-cyan-500)}.dark\:text-purple-400{color:var(--color-purple-400)}}@media print{.print\:hidden{display:none}}.\[\&_\.highlighted-word\]\:bg-blue-50 .highlighted-word{background-color:var(--color-blue-50)}@media(prefers-color-scheme:dark){.dark\:\[\&_\.highlighted-word\]\:\!bg-blue-500\/10 .highlighted-word{background-color:#3080ff1a!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.highlighted-word\]\:\!bg-blue-500\/10 .highlighted-word{background-color:var(--color-blue-500)!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.highlighted-word\]\:\!bg-blue-500\/10 .highlighted-word{background-color:color-mix(in oklab,var(--color-blue-500)10%,transparent)!important}}}}.\[\&_\.line\]\:relative .line{position:relative}.\[\&_\.line\]\:w-full .line{width:100%}.\[\&_\.line\]\:px-4 .line{padding-inline:calc(var(--spacing)*4)}.\[\&_\.line\]\:before\:mr-4 .line:before{content:var(--tw-content);margin-right:calc(var(--spacing)*4)}.\[\&_\.line\]\:before\:inline-block .line:before{content:var(--tw-content);display:inline-block}.\[\&_\.line\]\:before\:w-4 .line:before{content:var(--tw-content);width:calc(var(--spacing)*4)}.\[\&_\.line\]\:before\:text-right .line:before{content:var(--tw-content);text-align:right}.\[\&_\.line\]\:before\:font-mono .line:before{content:var(--tw-content);font-family:var(--font-mono)}.\[\&_\.line\]\:before\:text-\[13px\] .line:before{content:var(--tw-content);font-size:13px}.\[\&_\.line\]\:before\:text-muted-foreground\/50 .line:before{content:var(--tw-content);color:hsl(var(--muted-foreground))}@supports (color:color-mix(in lab,red,red)){.\[\&_\.line\]\:before\:text-muted-foreground\/50 .line:before{color:var(--color-muted-foreground)}@supports (color:color-mix(in lab,red,red)){.\[\&_\.line\]\:before\:text-muted-foreground\/50 .line:before{color:color-mix(in oklab,var(--color-muted-foreground)50%,transparent)}}}.\[\&_\.line\]\:before\:content-\[counter\(line\)\] .line:before{--tw-content:counter(line);content:var(--tw-content)}.\[\&_\.line\]\:before\:select-none .line:before{content:var(--tw-content);-webkit-user-select:none;user-select:none}.\[\&_\.line\]\:before\:\[counter-increment\:line\] .line:before{content:var(--tw-content);counter-increment:line}.\[\&_\.line\.diff\]\:after\:absolute .line.diff:after{content:var(--tw-content);position:absolute}.\[\&_\.line\.diff\]\:after\:top-0 .line.diff:after{content:var(--tw-content);top:calc(var(--spacing)*0)}.\[\&_\.line\.diff\]\:after\:bottom-0 .line.diff:after{content:var(--tw-content);bottom:calc(var(--spacing)*0)}.\[\&_\.line\.diff\]\:after\:left-0 .line.diff:after{content:var(--tw-content);left:calc(var(--spacing)*0)}.\[\&_\.line\.diff\]\:after\:w-0\.5 .line.diff:after{content:var(--tw-content);width:calc(var(--spacing)*.5)}.\[\&_\.line\.diff\.add\]\:bg-emerald-50 .line.diff.add{background-color:var(--color-emerald-50)}.\[\&_\.line\.diff\.add\]\:after\:bg-emerald-500 .line.diff.add:after{content:var(--tw-content);background-color:var(--color-emerald-500)}@media(prefers-color-scheme:dark){.dark\:\[\&_\.line\.diff\.add\]\:\!bg-emerald-500\/10 .line.diff.add{background-color:#00bb7f1a!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.line\.diff\.add\]\:\!bg-emerald-500\/10 .line.diff.add{background-color:var(--color-emerald-500)!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.line\.diff\.add\]\:\!bg-emerald-500\/10 .line.diff.add{background-color:color-mix(in oklab,var(--color-emerald-500)10%,transparent)!important}}}}.\[\&_\.line\.diff\.remove\]\:bg-rose-50 .line.diff.remove{background-color:var(--color-rose-50)}.\[\&_\.line\.diff\.remove\]\:after\:bg-rose-500 .line.diff.remove:after{content:var(--tw-content);background-color:var(--color-rose-500)}@media(prefers-color-scheme:dark){.dark\:\[\&_\.line\.diff\.remove\]\:\!bg-rose-500\/10 .line.diff.remove{background-color:#ff23571a!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.line\.diff\.remove\]\:\!bg-rose-500\/10 .line.diff.remove{background-color:var(--color-rose-500)!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.line\.diff\.remove\]\:\!bg-rose-500\/10 .line.diff.remove{background-color:color-mix(in oklab,var(--color-rose-500)10%,transparent)!important}}}}.\[\&_\.line\.highlighted\]\:bg-blue-50 .line.highlighted{background-color:var(--color-blue-50)}.\[\&_\.line\.highlighted\]\:after\:absolute .line.highlighted:after{content:var(--tw-content);position:absolute}.\[\&_\.line\.highlighted\]\:after\:top-0 .line.highlighted:after{content:var(--tw-content);top:calc(var(--spacing)*0)}.\[\&_\.line\.highlighted\]\:after\:bottom-0 .line.highlighted:after{content:var(--tw-content);bottom:calc(var(--spacing)*0)}.\[\&_\.line\.highlighted\]\:after\:left-0 .line.highlighted:after{content:var(--tw-content);left:calc(var(--spacing)*0)}.\[\&_\.line\.highlighted\]\:after\:w-0\.5 .line.highlighted:after{content:var(--tw-content);width:calc(var(--spacing)*.5)}.\[\&_\.line\.highlighted\]\:after\:bg-blue-500 .line.highlighted:after{content:var(--tw-content);background-color:var(--color-blue-500)}@media(prefers-color-scheme:dark){.dark\:\[\&_\.line\.highlighted\]\:\!bg-blue-500\/10 .line.highlighted{background-color:#3080ff1a!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.line\.highlighted\]\:\!bg-blue-500\/10 .line.highlighted{background-color:var(--color-blue-500)!important}@supports (color:color-mix(in lab,red,red)){.dark\:\[\&_\.line\.highlighted\]\:\!bg-blue-500\/10 .line.highlighted{background-color:color-mix(in oklab,var(--color-blue-500)10%,transparent)!important}}}}.\[\&_\.shiki\]\:\!bg-\[var\(--shiki-bg\)\] .shiki{background-color:var(--shiki-bg)!important}@media(prefers-color-scheme:dark){.dark\:\[\&_\.shiki\]\:\!bg-\[var\(--shiki-dark-bg\)\] .shiki{background-color:var(--shiki-dark-bg)!important}.dark\:\[\&_\.shiki\]\:\!\[font-weight\:var\(--shiki-dark-font-weight\)\] .shiki{font-weight:var(--shiki-dark-font-weight)!important}.dark\:\[\&_\.shiki\]\:\!text-\[var\(--shiki-dark\)\] .shiki{color:var(--shiki-dark)!important}.dark\:\[\&_\.shiki\]\:\!\[font-style\:var\(--shiki-dark-font-style\)\] .shiki{font-style:var(--shiki-dark-font-style)!important}.dark\:\[\&_\.shiki\]\:\!\[text-decoration\:var\(--shiki-dark-text-decoration\)\] .shiki{-webkit-text-decoration:var(--shiki-dark-text-decoration)!important;text-decoration:var(--shiki-dark-text-decoration)!important}.dark\:\[\&_\.shiki_span\]\:\!\[font-weight\:var\(--shiki-dark-font-weight\)\] .shiki span{font-weight:var(--shiki-dark-font-weight)!important}.dark\:\[\&_\.shiki_span\]\:\!text-\[var\(--shiki-dark\)\] .shiki span{color:var(--shiki-dark)!important}.dark\:\[\&_\.shiki_span\]\:\!\[font-style\:var\(--shiki-dark-font-style\)\] .shiki span{font-style:var(--shiki-dark-font-style)!important}.dark\:\[\&_\.shiki_span\]\:\!\[text-decoration\:var\(--shiki-dark-text-decoration\)\] .shiki span{-webkit-text-decoration:var(--shiki-dark-text-decoration)!important;text-decoration:var(--shiki-dark-text-decoration)!important}}.\[\&_code\]\:grid code{display:grid}.\[\&_code\]\:w-full code{width:100%}.\[\&_code\]\:overflow-x-auto code{overflow-x:auto}.\[\&_code\]\:bg-transparent code{background-color:#0000}.\[\&_code\]\:\[counter-increment\:line_0\] code{counter-increment:line 0}.\[\&_code\]\:\[counter-reset\:line\] code{counter-reset:line}.\[\&_code\:has\(\.focused\)_\.line\]\:blur-\[2px\] code:has(.focused) .line{--tw-blur:blur(2px);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,)}.\[\&_code\:has\(\.focused\)_\.line\.focused\]\:blur-none code:has(.focused) .line.focused{--tw-blur: ;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,)}.\[\&_pre\]\:py-4 pre{padding-block:calc(var(--spacing)*4)}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&\>button\]\:hidden>button{display:none}.\[\&\>span\]\:line-clamp-1>span{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.\[\&\>span\:last-child\]\:truncate>span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.\[\&\>svg\]\:size-4>svg{width:calc(var(--spacing)*4);height:calc(var(--spacing)*4)}.\[\&\>svg\]\:h-3\.5>svg{height:calc(var(--spacing)*3.5)}.\[\&\>svg\]\:w-3\.5>svg{width:calc(var(--spacing)*3.5)}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-sidebar-accent-foreground>svg{color:var(--color-sidebar-accent-foreground)}[data-side=left] .\[\[data-side\=left\]_\&\]\:cursor-w-resize{cursor:w-resize}[data-side=left][data-collapsible=offcanvas] .\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-right-2{right:calc(var(--spacing)*-2)}[data-side=left][data-state=collapsed] .\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize,[data-side=right] .\[\[data-side\=right\]_\&\]\:cursor-e-resize{cursor:e-resize}[data-side=right][data-collapsible=offcanvas] .\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-left-2{left:calc(var(--spacing)*-2)}[data-side=right][data-state=collapsed] .\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize{cursor:w-resize}}:root{--background:0 0% 100%;--foreground:240 10% 10%;--card:0 0% 99%;--card-foreground:240 10% 10%;--popover:0 0% 100%;--popover-foreground:240 10% 10%;--primary:190 80% 42%;--primary-foreground:0 0% 100%;--secondary:220 14% 96%;--secondary-foreground:240 10% 20%;--muted:220 14% 95%;--muted-foreground:220 10% 45%;--accent:220 14% 96%;--accent-foreground:240 10% 10%;--destructive:0 84% 60%;--destructive-foreground:0 0% 100%;--border:220 13% 90%;--input:220 13% 90%;--ring:190 80% 42%;--radius:.375rem;--sidebar-background:220 14% 98%;--sidebar-foreground:220 10% 40%;--sidebar-primary:190 80% 42%;--sidebar-primary-foreground:0 0% 100%;--sidebar-accent:220 14% 95%;--sidebar-accent-foreground:240 10% 10%;--sidebar-border:220 13% 91%;--sidebar-ring:190 80% 42%;--content-width:44rem;--content-width-wide:72rem;--gallery-width:90vw;--prose-width:60ch;--page-padding:2rem}.dark{--background:0 0% 7%;--foreground:0 0% 93%;--card:0 0% 10%;--card-foreground:0 0% 93%;--popover:0 0% 10%;--popover-foreground:0 0% 93%;--primary:175 70% 45%;--primary-foreground:0 0% 98%;--secondary:0 0% 14%;--secondary-foreground:0 0% 80%;--muted:0 0% 16%;--muted-foreground:0 0% 50%;--accent:0 0% 14%;--accent-foreground:0 0% 93%;--destructive:0 65% 55%;--destructive-foreground:0 0% 98%;--border:0 0% 22%;--input:0 0% 22%;--ring:175 70% 45%;--sidebar-background:0 0% 10%;--sidebar-foreground:0 0% 65%;--sidebar-primary:175 70% 45%;--sidebar-primary-foreground:0 0% 98%;--sidebar-accent:0 0% 13%;--sidebar-accent-foreground:0 0% 93%;--sidebar-border:0 0% 19%;--sidebar-ring:175 70% 45%}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-slow{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s ease-out forwards fade-in}.animate-fade-in-slow{animation:.6s ease-out forwards fade-in-slow}.animate-slide-up{animation:.5s ease-out forwards slide-up}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-ordinal{syntax:"*";inherits:false}@property --tw-slashed-zero{syntax:"*";inherits:false}@property --tw-numeric-figure{syntax:"*";inherits:false}@property --tw-numeric-spacing{syntax:"*";inherits:false}@property --tw-numeric-fraction{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@property --tw-content{syntax:"*";inherits:false;initial-value:""}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}
@@ -0,0 +1 @@
1
+ import{R as t}from"./index-CBkKcH4y.js";const o={},s=t.createContext(o);function u(e){const n=t.useContext(s);return t.useMemo(function(){return{...n,...e}},[n,e])}export{u};
package/dist/index.html CHANGED
@@ -9,8 +9,8 @@
9
9
  <link rel="preconnect" href="https://fonts.googleapis.com">
10
10
  <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
11
11
  <link href="https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap" rel="stylesheet">
12
- <script type="module" crossorigin src="/assets/index-DsHb4M_F.js"></script>
13
- <link rel="stylesheet" crossorigin href="/assets/index-C75KddSa.css">
12
+ <script type="module" crossorigin src="/assets/index-CBkKcH4y.js"></script>
13
+ <link rel="stylesheet" crossorigin href="/assets/index-PspMxLnH.css">
14
14
  </head>
15
15
  <body>
16
16
  <div id="root"></div>
@@ -0,0 +1,61 @@
1
+ {
2
+ "type": "directory",
3
+ "name": "test-content",
4
+ "path": ".",
5
+ "children": [
6
+ {
7
+ "type": "file",
8
+ "name": "README.md",
9
+ "path": "README.md",
10
+ "size": 472
11
+ },
12
+ {
13
+ "type": "directory",
14
+ "name": "test-slides",
15
+ "path": "test-slides",
16
+ "children": [
17
+ {
18
+ "type": "file",
19
+ "name": "SLIDES.mdx",
20
+ "path": "test-slides/SLIDES.mdx",
21
+ "size": 367,
22
+ "frontmatter": {
23
+ "title": "Test Slides",
24
+ "description": "These are test slides for testing purposes.",
25
+ "date": "2024-06-15"
26
+ }
27
+ },
28
+ {
29
+ "type": "file",
30
+ "name": "Counter.tsx",
31
+ "path": "test-slides/Counter.tsx",
32
+ "size": 684
33
+ }
34
+ ]
35
+ },
36
+ {
37
+ "type": "directory",
38
+ "name": "test-post",
39
+ "path": "test-post",
40
+ "children": [
41
+ {
42
+ "type": "file",
43
+ "name": "Chart.tsx",
44
+ "path": "test-post/Chart.tsx",
45
+ "size": 480
46
+ },
47
+ {
48
+ "type": "file",
49
+ "name": "README.mdx",
50
+ "path": "test-post/README.mdx",
51
+ "size": 455,
52
+ "frontmatter": {
53
+ "title": "Test Post",
54
+ "description": "This is a test post for testing purposes.",
55
+ "date": "2024-06-15"
56
+ }
57
+ }
58
+ ]
59
+ }
60
+ ]
61
+ }
@@ -0,0 +1,33 @@
1
+
2
+ ## Getting Started
3
+
4
+ ### Installation
5
+
6
+ First install [Task](https://taskfile.dev/docs/installation), then:
7
+
8
+ ```bash
9
+ git clone https://github.com/eoinmurray/pinglab
10
+ task install
11
+ ```
12
+
13
+ ### Simulate
14
+
15
+ Then you can run experiments like:
16
+
17
+ ```bash
18
+ task execute -- content/dynamical-regimes/experiment.py
19
+ # or
20
+ task execute:all
21
+ ```
22
+
23
+ which will generate data in the appropriate folder.
24
+
25
+ ### Present
26
+
27
+ Start the UI server with
28
+
29
+ ```bash
30
+ task dev
31
+ # or
32
+ task bg # starts in background
33
+ ```
@@ -0,0 +1,16 @@
1
+ export default function Chart({ data = [30, 60, 45, 80, 55] }: { data?: number[] }) {
2
+ const max = Math.max(...data)
3
+
4
+ return (
5
+ <div className="flex items-end gap-2 h-32 p-4 bg-muted rounded-lg">
6
+ {data.map((value, i) => (
7
+ <div
8
+ key={i}
9
+ className="flex-1 bg-primary rounded-t transition-all hover:bg-primary/80"
10
+ style={{ height: `${(value / max) * 100}%` }}
11
+ title={`Value: ${value}`}
12
+ />
13
+ ))}
14
+ </div>
15
+ )
16
+ }
@@ -0,0 +1,21 @@
1
+ ---
2
+ title: "Test Post"
3
+ description: "This is a test post for testing purposes."
4
+ date: "2024-06-15"
5
+ ---
6
+
7
+ import Chart from './Chart.tsx'
8
+
9
+ # Test Post
10
+
11
+ This post demonstrates local imports in MDX.
12
+
13
+ ## Interactive Chart
14
+
15
+ Here's a chart component imported from a local file:
16
+
17
+ <Chart data={[25, 50, 75, 40, 90]} />
18
+
19
+ ## How it works
20
+
21
+ The MDX is compiled at build time by Vite, so `import Chart from './Chart.tsx'` works natively. No runtime compilation needed!
@@ -0,0 +1,25 @@
1
+ import { useState } from 'react'
2
+
3
+ export default function Counter() {
4
+ const [count, setCount] = useState(0)
5
+
6
+ return (
7
+ <div className="flex flex-col items-center gap-4 p-4 border rounded-lg">
8
+ <p className="text-2xl font-bold">{count}</p>
9
+ <div className="flex gap-2">
10
+ <button
11
+ onClick={() => setCount(c => c - 1)}
12
+ className="px-4 py-2 bg-red-500 text-white rounded hover:bg-red-600"
13
+ >
14
+ -
15
+ </button>
16
+ <button
17
+ onClick={() => setCount(c => c + 1)}
18
+ className="px-4 py-2 bg-green-500 text-white rounded hover:bg-green-600"
19
+ >
20
+ +
21
+ </button>
22
+ </div>
23
+ </div>
24
+ )
25
+ }
@@ -0,0 +1,27 @@
1
+ ---
2
+ title: "Test Slides"
3
+ description: "These are test slides for testing purposes."
4
+ date: "2024-06-15"
5
+ ---
6
+
7
+ import Counter from './Counter.tsx'
8
+
9
+ # Slide 1
10
+
11
+ This is the first slide with some text.
12
+
13
+ ---
14
+
15
+ # Slide 2: Interactive Component
16
+
17
+ Here's an interactive counter component:
18
+
19
+ <Counter />
20
+
21
+ ---
22
+
23
+ # Slide 3
24
+
25
+ This is the final slide.
26
+
27
+ Local imports work in slides now!
package/index.html ADDED
@@ -0,0 +1,17 @@
1
+ <!doctype html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8" />
5
+ <link rel="icon" type="image/svg+xml" href="/logo_dark.png" />
6
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
7
+ <title>Pinglab</title>
8
+ <!-- Google Fonts: DM Sans + DM Mono -->
9
+ <link rel="preconnect" href="https://fonts.googleapis.com">
10
+ <link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
11
+ <link href="https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,400&display=swap" rel="stylesheet">
12
+ </head>
13
+ <body>
14
+ <div id="root"></div>
15
+ <script type="module" src="/src/main.tsx"></script>
16
+ </body>
17
+ </html>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "veslx",
3
- "version": "0.0.27",
3
+ "version": "0.1.0",
4
4
  "type": "module",
5
5
  "bin": {
6
6
  "veslx": "bin/veslx.ts"
@@ -11,15 +11,12 @@
11
11
  "plugin",
12
12
  "src",
13
13
  "public",
14
+ "index.html",
14
15
  "vite.config.ts"
15
16
  ],
16
17
  "scripts": {
17
- "dev": "vite",
18
- "build": "vite build",
19
- "typecheck": "tsc -b",
20
- "lint": "eslint .",
21
- "preview": "vite preview",
22
- "start": "vite preview"
18
+ "dev": "bun bin/veslx.ts serve",
19
+ "build": "bun bin/veslx.ts build"
23
20
  },
24
21
  "dependencies": {
25
22
  "acorn": "^8.15.0",
@@ -5,6 +5,9 @@ import { buildAll } from './lib'
5
5
  import chokidar, { type FSWatcher } from 'chokidar'
6
6
  import type { IncomingMessage, ServerResponse } from 'http'
7
7
 
8
+ const VIRTUAL_MODULE_ID = 'virtual:content-modules'
9
+ const RESOLVED_VIRTUAL_MODULE_ID = '\0' + VIRTUAL_MODULE_ID
10
+
8
11
  /**
9
12
  * Recursively copy a directory
10
13
  */
@@ -83,6 +86,41 @@ export default function contentPlugin(contentDir: string): Plugin {
83
86
 
84
87
  return {
85
88
  name: 'content',
89
+
90
+ // Inject @content alias and fs.allow into Vite config
91
+ config() {
92
+ return {
93
+ resolve: {
94
+ alias: {
95
+ '@content': dir,
96
+ },
97
+ },
98
+ server: {
99
+ fs: {
100
+ allow: [dir],
101
+ },
102
+ },
103
+ }
104
+ },
105
+
106
+ // Virtual module for content MDX imports
107
+ resolveId(id) {
108
+ if (id === VIRTUAL_MODULE_ID) {
109
+ return RESOLVED_VIRTUAL_MODULE_ID
110
+ }
111
+ },
112
+
113
+ load(id) {
114
+ if (id === RESOLVED_VIRTUAL_MODULE_ID) {
115
+ // Generate virtual module with import.meta.glob for MDX files
116
+ return `
117
+ export const modules = import.meta.glob('@content/**/README.mdx');
118
+ export const slides = import.meta.glob('@content/**/SLIDES.mdx');
119
+ export const index = import.meta.glob('@content/.veslx.json', { eager: true });
120
+ `
121
+ }
122
+ },
123
+
86
124
  async buildStart() {
87
125
  await buildFn()
88
126
  },
@@ -0,0 +1,130 @@
1
+ import React, { Children, isValidElement, ReactNode, useMemo } from 'react'
2
+ import { mdxComponents } from '@/components/mdx-components'
3
+
4
+ interface SlidesRendererProps {
5
+ Content: React.ComponentType<{ components?: Record<string, React.ComponentType> }> | null
6
+ frontmatter?: {
7
+ title?: string
8
+ description?: string
9
+ date?: string
10
+ }
11
+ }
12
+
13
+ /**
14
+ * Splits MDX content into slides by <hr> elements.
15
+ * The MDX is compiled at build time, so imports work.
16
+ * Slide boundaries are marked with --- in MDX (which becomes <hr>).
17
+ */
18
+ export function useSlidesFromMDX({ Content, frontmatter }: SlidesRendererProps) {
19
+ const slides = useMemo(() => {
20
+ // Handle null Content (loading state)
21
+ if (!Content) {
22
+ return []
23
+ }
24
+
25
+ // Create a custom hr component that we can detect
26
+ const SlideBreak = () => <hr data-slide-break="true" />
27
+
28
+ // Render the MDX with our custom hr
29
+ const componentsWithBreak = {
30
+ ...mdxComponents,
31
+ hr: SlideBreak,
32
+ }
33
+
34
+ // Render to get the element tree
35
+ const rendered = <Content components={componentsWithBreak} />
36
+
37
+ // Split children by hr elements
38
+ return splitByHr(rendered)
39
+ }, [Content])
40
+
41
+ return { slides, frontmatter }
42
+ }
43
+
44
+ /**
45
+ * Recursively traverses React element tree and splits by <hr> elements
46
+ */
47
+ function splitByHr(element: ReactNode): ReactNode[][] {
48
+ const slides: ReactNode[][] = [[]]
49
+
50
+ function traverse(node: ReactNode) {
51
+ if (!node) return
52
+
53
+ if (Array.isArray(node)) {
54
+ node.forEach(traverse)
55
+ return
56
+ }
57
+
58
+ if (isValidElement(node)) {
59
+ // Check if this is our slide break marker
60
+ if (node.type === 'hr' || (node.props && node.props['data-slide-break'] === 'true')) {
61
+ // Start a new slide
62
+ slides.push([])
63
+ return
64
+ }
65
+
66
+ // Check if it's an hr component from mdxComponents
67
+ const nodeType = node.type as any
68
+ if (typeof nodeType === 'function' && nodeType.name === 'SlideBreak') {
69
+ slides.push([])
70
+ return
71
+ }
72
+
73
+ // For fragments or elements with children, we need to check children
74
+ if (node.props?.children) {
75
+ const children = Children.toArray(node.props.children)
76
+
77
+ // Check if any child is an hr - if so, we need to split this element
78
+ const hasHrChild = children.some(child =>
79
+ isValidElement(child) && (
80
+ child.type === 'hr' ||
81
+ (child.props && child.props['data-slide-break'] === 'true')
82
+ )
83
+ )
84
+
85
+ if (hasHrChild) {
86
+ // Split the children
87
+ children.forEach(child => {
88
+ if (isValidElement(child) && (
89
+ child.type === 'hr' ||
90
+ (child.props && child.props['data-slide-break'] === 'true')
91
+ )) {
92
+ slides.push([])
93
+ } else {
94
+ slides[slides.length - 1].push(child)
95
+ }
96
+ })
97
+ } else {
98
+ // No hr children, add the whole element
99
+ slides[slides.length - 1].push(node)
100
+ }
101
+ return
102
+ }
103
+ }
104
+
105
+ // Add to current slide
106
+ slides[slides.length - 1].push(node)
107
+ }
108
+
109
+ // Get the children of the rendered element
110
+ if (isValidElement(element) && element.props?.children) {
111
+ const children = Children.toArray(element.props.children)
112
+ children.forEach(traverse)
113
+ } else {
114
+ traverse(element)
115
+ }
116
+
117
+ // Filter out empty slides
118
+ return slides.filter(slide => slide.length > 0)
119
+ }
120
+
121
+ /**
122
+ * Renders a single slide's content
123
+ */
124
+ export function SlideContent({ children }: { children: ReactNode[] }) {
125
+ return (
126
+ <div className="slide-content prose dark:prose-invert prose-headings:tracking-tight prose-p:leading-relaxed max-w-xl">
127
+ {children}
128
+ </div>
129
+ )
130
+ }