*,
:before,
:after {
	font-family: 'Inter Tight', 'Inter', Arial, sans-serif;
	box-sizing: border-box;
	border-width: 0;
	border-style: solid;
	border-color: #e5e7eb
}

:before,
:after {
	--tw-content: ""
}

html,
:host {

	line-height: 1.5;
	-webkit-text-size-adjust: 100%;
	-moz-tab-size: 4;
	-o-tab-size: 4;
	tab-size: 4;
	font-family: Inter var, sans-serif;
	font-feature-settings: normal;
	font-variation-settings: normal;
	-webkit-tap-highlight-color: transparent
}

body {
	margin: 0;
	line-height: inherit
}

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;
	text-decoration: inherit
}

b,
strong {
	font-weight: bolder
}

code,
kbd,
samp,
pre {
	font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
	font-feature-settings: normal;
	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
}

button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-feature-settings: inherit;
	font-variation-settings: inherit;
	font-size: 100%;
	font-weight: inherit;
	line-height: inherit;
	letter-spacing: inherit;
	color: inherit;
	margin: 0;
	padding: 0
}

button,
select {
	text-transform: none
}

:-moz-focusring {
	outline: auto
}

:-moz-ui-invalid {
	box-shadow: none
}

progress {
	vertical-align: baseline
}

summary {
	display: list-item
}

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
	margin: 0
}

fieldset {
	margin: 0;
	padding: 0
}

legend {
	padding: 0
}

ol,
ul,
menu {
	list-style: none;
	margin: 0;
	padding: 0
}

dialog {
	padding: 0
}

textarea {
	resize: vertical
}

input::-moz-placeholder,
textarea::-moz-placeholder {
	opacity: 1;
	color: #9ca3af
}

input::placeholder,
textarea::placeholder {
	opacity: 1;
	color: #9ca3af
}

button,
[role=button] {
	cursor: pointer
}

:disabled {
	cursor: default
}

[hidden] {
	display: none
}

*,
:before,
:after {
	--tw-border-spacing-x: 0;
	--tw-border-spacing-y: 0;
	--tw-translate-x: 0;
	--tw-translate-y: 0;
	--tw-rotate: 0;
	--tw-skew-x: 0;
	--tw-skew-y: 0;
	--tw-scale-x: 1;
	--tw-scale-y: 1;
	--tw-pan-x: ;
	--tw-pan-y: ;
	--tw-pinch-zoom: ;
	--tw-scroll-snap-strictness: proximity;
	--tw-gradient-from-position: ;
	--tw-gradient-via-position: ;
	--tw-gradient-to-position: ;
	--tw-ordinal: ;
	--tw-slashed-zero: ;
	--tw-numeric-figure: ;
	--tw-numeric-spacing: ;
	--tw-numeric-fraction: ;
	--tw-ring-inset: ;
	--tw-ring-offset-width: 0px;
	--tw-ring-offset-color: #fff;
	--tw-ring-color: rgb(59 130 246 / .5);
	--tw-ring-offset-shadow: 0 0 #0000;
	--tw-ring-shadow: 0 0 #0000;
	--tw-shadow: 0 0 #0000;
	--tw-shadow-colored: 0 0 #0000;
	--tw-blur: ;
	--tw-brightness: ;
	--tw-contrast: ;
	--tw-grayscale: ;
	--tw-hue-rotate: ;
	--tw-invert: ;
	--tw-saturate: ;
	--tw-sepia: ;
	--tw-drop-shadow: ;
	--tw-backdrop-blur: ;
	--tw-backdrop-brightness: ;
	--tw-backdrop-contrast: ;
	--tw-backdrop-grayscale: ;
	--tw-backdrop-hue-rotate: ;
	--tw-backdrop-invert: ;
	--tw-backdrop-opacity: ;
	--tw-backdrop-saturate: ;
	--tw-backdrop-sepia: ;
	--tw-contain-size: ;
	--tw-contain-layout: ;
	--tw-contain-paint: ;
	--tw-contain-style:
}

::backdrop {
	--tw-border-spacing-x: 0;
	--tw-border-spacing-y: 0;
	--tw-translate-x: 0;
	--tw-translate-y: 0;
	--tw-rotate: 0;
	--tw-skew-x: 0;
	--tw-skew-y: 0;
	--tw-scale-x: 1;
	--tw-scale-y: 1;
	--tw-pan-x: ;
	--tw-pan-y: ;
	--tw-pinch-zoom: ;
	--tw-scroll-snap-strictness: proximity;
	--tw-gradient-from-position: ;
	--tw-gradient-via-position: ;
	--tw-gradient-to-position: ;
	--tw-ordinal: ;
	--tw-slashed-zero: ;
	--tw-numeric-figure: ;
	--tw-numeric-spacing: ;
	--tw-numeric-fraction: ;
	--tw-ring-inset: ;
	--tw-ring-offset-width: 0px;
	--tw-ring-offset-color: #fff;
	--tw-ring-color: rgb(59 130 246 / .5);
	--tw-ring-offset-shadow: 0 0 #0000;
	--tw-ring-shadow: 0 0 #0000;
	--tw-shadow: 0 0 #0000;
	--tw-shadow-colored: 0 0 #0000;
	--tw-blur: ;
	--tw-brightness: ;
	--tw-contrast: ;
	--tw-grayscale: ;
	--tw-hue-rotate: ;
	--tw-invert: ;
	--tw-saturate: ;
	--tw-sepia: ;
	--tw-drop-shadow: ;
	--tw-backdrop-blur: ;
	--tw-backdrop-brightness: ;
	--tw-backdrop-contrast: ;
	--tw-backdrop-grayscale: ;
	--tw-backdrop-hue-rotate: ;
	--tw-backdrop-invert: ;
	--tw-backdrop-opacity: ;
	--tw-backdrop-saturate: ;
	--tw-backdrop-sepia: ;
	--tw-contain-size: ;
	--tw-contain-layout: ;
	--tw-contain-paint: ;
	--tw-contain-style:
}

.peer { position: absolute; opacity: 0; width: 0; height: 0; }

.peer:focus + span { box-shadow: 0 0 0 2px var(--accent, #C16DFC55); }

.peer:checked + span {
    background: var(--accent, #C16DFC);
    border-color: var(--accent, #C16DFC);
}

.peer:checked + span svg {
    opacity: 1;
}

.peer + span svg {
    opacity: 0;
}

.prose {
	color: var(--tw-prose-body);
	max-width: 65ch
}

.prose :where(p):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 1.25em;
	margin-bottom: 1.25em
}

.prose :where([class~=lead]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-lead);
	font-size: 1.25em;
	line-height: 1.6;
	margin-top: 1.2em;
	margin-bottom: 1.2em
}

.prose :where(a):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-links);
	text-decoration: underline;
	font-weight: 500
}

.prose :where(strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-bold);
	font-weight: 600
}

.prose :where(a strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(blockquote strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(thead th strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(ol):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: decimal;
	margin-top: 1.25em;
	margin-bottom: 1.25em;
	padding-inline-start: 1.625em
}

.prose :where(ol[type=A]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: upper-alpha
}

.prose :where(ol[type=a]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: lower-alpha
}

.prose :where(ol[type=A s]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: upper-alpha
}

.prose :where(ol[type=a s]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: lower-alpha
}

.prose :where(ol[type=I]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: upper-roman
}

.prose :where(ol[type=i]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: lower-roman
}

.prose :where(ol[type=I s]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: upper-roman
}

.prose :where(ol[type=i s]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: lower-roman
}

.prose :where(ol[type="1"]):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: decimal
}

.prose :where(ul):not(:where([class~=not-prose], [class~=not-prose] *)) {
	list-style-type: disc;
	margin-top: 1.25em;
	margin-bottom: 1.25em;
	padding-inline-start: 1.625em
}

.prose :where(ol>li):not(:where([class~=not-prose], [class~=not-prose] *))::marker {
	font-weight: 400;
	color: var(--tw-prose-counters)
}

.prose :where(ul>li):not(:where([class~=not-prose], [class~=not-prose] *))::marker {
	color: var(--tw-prose-bullets)
}

.prose :where(dt):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-headings);
	font-weight: 600;
	margin-top: 1.25em
}

.prose :where(hr):not(:where([class~=not-prose], [class~=not-prose] *)) {
	border-color: var(--tw-prose-hr);
	border-top-width: 1px;
	margin-top: 3em;
	margin-bottom: 3em
}

.prose :where(blockquote):not(:where([class~=not-prose], [class~=not-prose] *)) {
	font-weight: 500;
	font-style: italic;
	color: var(--tw-prose-quotes);
	border-inline-start-width: .25rem;
	border-inline-start-color: var(--tw-prose-quote-borders);
	quotes: "“""”""‘""’";
	margin-top: 1.6em;
	margin-bottom: 1.6em;
	padding-inline-start: 1em
}

.prose :where(blockquote p:first-of-type):not(:where([class~=not-prose], [class~=not-prose] *)):before {
	content: open-quote
}

.prose :where(blockquote p:last-of-type):not(:where([class~=not-prose], [class~=not-prose] *)):after {
	content: close-quote
}

.prose :where(h1):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-headings);
	font-weight: 800;
	font-size: 2.25em;
	margin-top: 0;
	margin-bottom: .8888889em;
	line-height: 1.1111111
}

.prose :where(h1 strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	font-weight: 900;
	color: inherit
}

.prose :where(h2):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-headings);
	font-weight: 700;
	font-size: 1.5em;
	margin-top: 2em;
	margin-bottom: 1em;
	line-height: 1.3333333
}

.prose :where(h2 strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	font-weight: 800;
	color: inherit
}

.prose :where(h3):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-headings);
	font-weight: 600;
	font-size: 1.25em;
	margin-top: 1.6em;
	margin-bottom: .6em;
	line-height: 1.6
}

.prose :where(h3 strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	font-weight: 700;
	color: inherit
}

.prose :where(h4):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-headings);
	font-weight: 600;
	margin-top: 1.5em;
	margin-bottom: .5em;
	line-height: 1.5
}

.prose :where(h4 strong):not(:where([class~=not-prose], [class~=not-prose] *)) {
	font-weight: 700;
	color: inherit
}

.prose :where(img):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 2em;
	margin-bottom: 2em
}

.prose :where(picture):not(:where([class~=not-prose], [class~=not-prose] *)) {
	display: block;
	margin-top: 2em;
	margin-bottom: 2em
}

.prose :where(video):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 2em;
	margin-bottom: 2em
}

.prose :where(kbd):not(:where([class~=not-prose], [class~=not-prose] *)) {
	font-weight: 500;
	font-family: inherit;
	color: var(--tw-prose-kbd);
	box-shadow: 0 0 0 1px rgb(var(--tw-prose-kbd-shadows) / 10%), 0 3px 0 rgb(var(--tw-prose-kbd-shadows) / 10%);
	font-size: .875em;
	border-radius: .3125rem;
	padding-top: .1875em;
	padding-inline-end: .375em;
	padding-bottom: .1875em;
	padding-inline-start: .375em
}

.prose :where(code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-code);
	font-weight: 600;
	font-size: .875em
}

.prose :where(code):not(:where([class~=not-prose], [class~=not-prose] *)):before {
	content: "`"
}

.prose :where(code):not(:where([class~=not-prose], [class~=not-prose] *)):after {
	content: "`"
}

.prose :where(a code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(h1 code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(h2 code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit;
	font-size: .875em
}

.prose :where(h3 code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit;
	font-size: .9em
}

.prose :where(h4 code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(blockquote code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(thead th code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: inherit
}

.prose :where(pre):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-pre-code);
	background-color: var(--tw-prose-pre-bg);
	overflow-x: auto;
	font-weight: 400;
	font-size: .875em;
	line-height: 1.7142857;
	margin-top: 1.7142857em;
	margin-bottom: 1.7142857em;
	border-radius: .375rem;
	padding-top: .8571429em;
	padding-inline-end: 1.1428571em;
	padding-bottom: .8571429em;
	padding-inline-start: 1.1428571em
}

.prose :where(pre code):not(:where([class~=not-prose], [class~=not-prose] *)) {
	background-color: transparent;
	border-width: 0;
	border-radius: 0;
	padding: 0;
	font-weight: inherit;
	color: inherit;
	font-size: inherit;
	font-family: inherit;
	line-height: inherit
}

.prose :where(pre code):not(:where([class~=not-prose], [class~=not-prose] *)):before {
	content: none
}

.prose :where(pre code):not(:where([class~=not-prose], [class~=not-prose] *)):after {
	content: none
}

.prose :where(table):not(:where([class~=not-prose], [class~=not-prose] *)) {
	width: 100%;
	table-layout: auto;
	text-align: start;
	margin-top: 2em;
	margin-bottom: 2em;
	font-size: .875em;
	line-height: 1.7142857
}

.prose :where(thead):not(:where([class~=not-prose], [class~=not-prose] *)) {
	border-bottom-width: 1px;
	border-bottom-color: var(--tw-prose-th-borders)
}

.prose :where(thead th):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-headings);
	font-weight: 600;
	vertical-align: bottom;
	padding-inline-end: .5714286em;
	padding-bottom: .5714286em;
	padding-inline-start: .5714286em
}

.prose :where(tbody tr):not(:where([class~=not-prose], [class~=not-prose] *)) {
	border-bottom-width: 1px;
	border-bottom-color: var(--tw-prose-td-borders)
}

.prose :where(tbody tr:last-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	border-bottom-width: 0
}

.prose :where(tbody td):not(:where([class~=not-prose], [class~=not-prose] *)) {
	vertical-align: baseline
}

.prose :where(tfoot):not(:where([class~=not-prose], [class~=not-prose] *)) {
	border-top-width: 1px;
	border-top-color: var(--tw-prose-th-borders)
}

.prose :where(tfoot td):not(:where([class~=not-prose], [class~=not-prose] *)) {
	vertical-align: top
}

.prose :where(figure>*):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 0;
	margin-bottom: 0
}

.prose :where(figcaption):not(:where([class~=not-prose], [class~=not-prose] *)) {
	color: var(--tw-prose-captions);
	font-size: .875em;
	line-height: 1.4285714;
	margin-top: .8571429em
}

.prose {
	--tw-prose-body: #374151;
	--tw-prose-headings: #111827;
	--tw-prose-lead: #4b5563;
	--tw-prose-links: #111827;
	--tw-prose-bold: #111827;
	--tw-prose-counters: #6b7280;
	--tw-prose-bullets: #d1d5db;
	--tw-prose-hr: #e5e7eb;
	--tw-prose-quotes: #111827;
	--tw-prose-quote-borders: #e5e7eb;
	--tw-prose-captions: #6b7280;
	--tw-prose-kbd: #111827;
	--tw-prose-kbd-shadows: 17 24 39;
	--tw-prose-code: #111827;
	--tw-prose-pre-code: #e5e7eb;
	--tw-prose-pre-bg: #1f2937;
	--tw-prose-th-borders: #d1d5db;
	--tw-prose-td-borders: #e5e7eb;
	--tw-prose-invert-body: #d1d5db;
	--tw-prose-invert-headings: #fff;
	--tw-prose-invert-lead: #9ca3af;
	--tw-prose-invert-links: #fff;
	--tw-prose-invert-bold: #fff;
	--tw-prose-invert-counters: #9ca3af;
	--tw-prose-invert-bullets: #4b5563;
	--tw-prose-invert-hr: #374151;
	--tw-prose-invert-quotes: #f3f4f6;
	--tw-prose-invert-quote-borders: #374151;
	--tw-prose-invert-captions: #9ca3af;
	--tw-prose-invert-kbd: #fff;
	--tw-prose-invert-kbd-shadows: 255 255 255;
	--tw-prose-invert-code: #fff;
	--tw-prose-invert-pre-code: #d1d5db;
	--tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);
	--tw-prose-invert-th-borders: #4b5563;
	--tw-prose-invert-td-borders: #374151;
	font-size: 1rem;
	line-height: 1.75
}

.prose :where(picture>img):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 0;
	margin-bottom: 0
}

.prose :where(li):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: .5em;
	margin-bottom: .5em
}

.prose :where(ol>li):not(:where([class~=not-prose], [class~=not-prose] *)) {
	padding-inline-start: .375em
}

.prose :where(ul>li):not(:where([class~=not-prose], [class~=not-prose] *)) {
	padding-inline-start: .375em
}

.prose :where(.prose>ul>li p):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: .75em;
	margin-bottom: .75em
}

.prose :where(.prose>ul>li>*:first-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 1.25em
}

.prose :where(.prose>ul>li>*:last-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-bottom: 1.25em
}

.prose :where(.prose>ol>li>*:first-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 1.25em
}

.prose :where(.prose>ol>li>*:last-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-bottom: 1.25em
}

.prose :where(ul ul, ul ol, ol ul, ol ol):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: .75em;
	margin-bottom: .75em
}

.prose :where(dl):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 1.25em;
	margin-bottom: 1.25em
}

.prose :where(dd):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: .5em;
	padding-inline-start: 1.625em
}

.prose :where(hr+*):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 0
}

.prose :where(h2+*):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 0
}

.prose :where(h3+*):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 0
}

.prose :where(h4+*):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 0
}

.prose :where(thead th:first-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	padding-inline-start: 0
}

.prose :where(thead th:last-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	padding-inline-end: 0
}

.prose :where(tbody td, tfoot td):not(:where([class~=not-prose], [class~=not-prose] *)) {
	padding-top: .5714286em;
	padding-inline-end: .5714286em;
	padding-bottom: .5714286em;
	padding-inline-start: .5714286em
}

.prose :where(tbody td:first-child, tfoot td:first-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	padding-inline-start: 0
}

.prose :where(tbody td:last-child, tfoot td:last-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	padding-inline-end: 0
}

.prose :where(figure):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 2em;
	margin-bottom: 2em
}

.prose :where(.prose>:first-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-top: 0
}

.prose :where(.prose>:last-child):not(:where([class~=not-prose], [class~=not-prose] *)) {
	margin-bottom: 0
}

.prose-invert {
	--tw-prose-body: var(--tw-prose-invert-body);
	--tw-prose-headings: var(--tw-prose-invert-headings);
	--tw-prose-lead: var(--tw-prose-invert-lead);
	--tw-prose-links: var(--tw-prose-invert-links);
	--tw-prose-bold: var(--tw-prose-invert-bold);
	--tw-prose-counters: var(--tw-prose-invert-counters);
	--tw-prose-bullets: var(--tw-prose-invert-bullets);
	--tw-prose-hr: var(--tw-prose-invert-hr);
	--tw-prose-quotes: var(--tw-prose-invert-quotes);
	--tw-prose-quote-borders: var(--tw-prose-invert-quote-borders);
	--tw-prose-captions: var(--tw-prose-invert-captions);
	--tw-prose-kbd: var(--tw-prose-invert-kbd);
	--tw-prose-kbd-shadows: var(--tw-prose-invert-kbd-shadows);
	--tw-prose-code: var(--tw-prose-invert-code);
	--tw-prose-pre-code: var(--tw-prose-invert-pre-code);
	--tw-prose-pre-bg: var(--tw-prose-invert-pre-bg);
	--tw-prose-th-borders: var(--tw-prose-invert-th-borders);
	--tw-prose-td-borders: var(--tw-prose-invert-td-borders)
}

.pointer-events-none {
	pointer-events: none
}

.absolute {
	position: absolute
}

.m-0 {
	margin: 0
}

.mx-auto {
	margin-left: auto;
	margin-right: auto
}

.my-12 {
	margin-top: 3rem;
	margin-bottom: 3rem
}

.my-16 {
	margin-top: 4rem;
	margin-bottom: 4rem
}

.my-2 {
	margin-top: .5rem;
	margin-bottom: .5rem
}

.my-3 {
	margin-top: .75rem;
	margin-bottom: .75rem
}

.my-5 {
	margin-top: 1.25rem;
	margin-bottom: 1.25rem
}

.my-6 {
	margin-top: 1.5rem;
	margin-bottom: 1.5rem
}

.mb-1 {
	margin-bottom: .25rem
}

.mb-2 {
	margin-bottom: .5rem
}

.mb-4 {
	margin-bottom: 1rem
}

.mb-6 {
	margin-bottom: 1.5rem
}

.mb-8 {
	margin-bottom: 2rem
}

.ml-3 {
	margin-left: .75rem
}

.mr-4 {
	margin-right: 1rem
}

.mt-10 {
	margin-top: 2.5rem
}

.mt-2 {
	margin-top: .5rem
}

.mt-4 {
	margin-top: 1rem
}

.flex {
	display: flex
}

.grid {
	display: grid
}

.hidden {
	display: none
}

.h-4 {
	height: 1rem
}

.h-6 {
	height: 1.5rem
}

.h-8 {
	height: 2rem
}

.h-full {
	height: 100%
}

.min-h-screen {
	min-height: 100vh
}

.w-12 {
	width: 3rem
}

.w-4 {
	width: 1rem
}

.w-6 {
	width: 1.5rem
}

.w-full {
	width: 100%
}

.max-w-2xl {
	max-width: 42rem
}

.max-w-3xl {
	max-width: 48rem
}

.max-w-5xl {
	max-width: 64rem
}

.flex-1 {
	flex: 1 1 0%
}

.grow {
	flex-grow: 1
}

.basis-full {
	flex-basis: 100%
}

@keyframes pulse {
	50% {
		opacity: .5
	}
}

.animate-pulse {
	animation: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite
}

.cursor-pointer {
	cursor: pointer
}

.select-none {
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none
}

.list-inside {
	list-style-position: inside
}

.list-decimal {
	list-style-type: decimal
}

.list-disc {
	list-style-type: disc
}

.appearance-none {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none
}

.grid-cols-1 {
	grid-template-columns: repeat(1, minmax(0, 1fr))
}

.grid-cols-2 {
	grid-template-columns: repeat(2, minmax(0, 1fr))
}

.flex-row {
	flex-direction: row
}

.flex-col {
	flex-direction: column
}

.flex-col-reverse {
	flex-direction: column-reverse
}

.items-center {
	align-items: center
}

.items-stretch {
	align-items: stretch
}

.justify-center {
	justify-content: center
}

.justify-evenly {
	justify-content: space-evenly
}

.justify-stretch {
	justify-content: stretch
}

.gap-1 {
	gap: .25rem
}

.gap-2 {
	gap: .5rem
}

.gap-3 {
	gap: .75rem
}

.gap-4 {
	gap: 1rem
}

.gap-8 {
	gap: 2rem
}

.self-center {
	align-self: center
}

.rounded-3xl {
	border-radius: 1.5rem
}

.rounded-lg {
	border-radius: .5rem
}

.rounded-xl {
	border-radius: .75rem
}

.border-2 {
	border-width: 2px
}

.border-4 {
	border-width: 4px
}

.border-b {
	border-bottom-width: 1px
}

.border-l-2 {
	border-left-width: 2px
}

.border-t {
	border-top-width: 1px
}

.border-dashed {
	border-style: dashed
}

.border-light {
	--tw-border-opacity: 1;
	border-color: rgb(241 240 234 / var(--tw-border-opacity))
}

.border-light\/10 {
	border-color: #49497033
}

.border-light\/20 {
	border-color: #49497033
}

.bg-accent\/10 {
	background-color: #C16DFC1a
}

.bg-dark {
	--tw-bg-opacity: 1;
	background-color: rgb(12 12 16 / var(--tw-bg-opacity))
}

.glow-text {
    text-shadow: 0 0 10px;
}

.gradient-text {
 	background: linear-gradient(to bottom right, #e788ff, #bd15ff);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}
    
.bg-dark\/50 {
	background-color: #131317cc
}

.bg-light {
	--tw-bg-opacity: 1;
	background-color: rgb(98 53 130 / var(--tw-bg-opacity))
}

.feature-card {
    background: rgba(24, 24, 36, 0.7);
    border-radius: 1.5rem;
    box-shadow: 0 8px 32px 0 rgba(49, 29, 80, 0.18);
    backdrop-filter: blur(8px);
    border: 1.5px solid #232336;
    transition: box-shadow 0.3s, transform 0.3s;
    position: relative;
    overflow: visible;
    min-height: fit-content;
}

.feature-card > * {
    max-width: 100%;
}

.feature-card img {
    width: 100%;
    height: auto;
    object-fit: contain;
}

.feature-card:hover {
    box-shadow: 0 12px 48px 0 #C16DFC44, 0 1.5px 8px 0 #232336;
    transform: translateY(-4px) scale(1.012);
}

.feature-img {
    transition: transform 0.5s cubic-bezier(.4,0,.2,1), box-shadow 0.3s;
}

.feature-card:hover .feature-img {
    transform: scale(1.04) rotate(-1deg);
    box-shadow: 0 8px 32px 0 #C16DFC33;
}

@keyframes fade-in {
    from { opacity: 0; transform: translateY(32px); }
    to { opacity: 1; transform: none; }
}

.animate-fade-in {
    animation: fade-in 0.8s cubic-bezier(.4,0,.2,1) both;
}

.animate-fade-in.delay-100 { animation-delay: 0.1s; }

.animate-fade-in.delay-200 { animation-delay: 0.2s; }

@keyframes heading-fade-in {
    from { opacity: 0; transform: translateY(32px) scale(0.98); }
    to { opacity: 1; transform: none; }
}

.bg-red-600\/10 {
	background-color: #dc26261a
}

.object-fill {
	-o-object-fit: fill;
	object-fit: fill
}

.p-1 {
	padding: .25rem
}

.p-2 {
	padding: .5rem
}

.p-3 {
	padding: .75rem
}

.p-4 {
	padding: 1rem
}

.p-6 {
	padding: 1.5rem
}

.p-8 {
	padding: 2rem
}

.px-5 {
	padding-left: 1.25rem;
	padding-right: 1.25rem
}

.px-8 {
	padding-left: 2rem;
	padding-right: 2rem
}

.py-4 {
	padding-top: 1rem;
	padding-bottom: 1rem
}

.py-8 {
	padding-top: 2rem;
	padding-bottom: 2rem
}

.text-center {
	text-align: center
}

.text-2xl {
	font-size: 1.5rem;
	line-height: 2rem
}

.text-3xl {
	font-size: 1.875rem;
	line-height: 2.25rem
}

.text-4xl {
	font-size: 2.25rem;
	line-height: 2.5rem
}

.text-5xl {
	font-size: 3rem;
	line-height: 1
}

.feature-card {
    background: rgba(24, 24, 36, 0.7);
    border-radius: 1.5rem;
    box-shadow: 0 8px 32px 0 rgba(49, 29, 80, 0.18);
    backdrop-filter: blur(8px);
    border: 1.5px solid #232336;
    transition: box-shadow 0.3s, transform 0.3s;
    position: relative;
    overflow: hidden;
}

.feature-card:hover {
    box-shadow: 0 12px 48px 0 #C16DFC44, 0 1.5px 8px 0 #232336;
    transform: translateY(-4px) scale(1.012);
}

.feature-img {
    transition: transform 0.5s cubic-bezier(.4,0,.2,1), box-shadow 0.3s;
}

.feature-card:hover .feature-img {
	transform: scale(1.04) rotate(-1deg);
    box-shadow: 0 8px 32px 0 #C16DFC33;
}

@keyframes fade-in {
    from { opacity: 0; transform: translateY(32px); }
    to { opacity: 1; transform: none; }
}

.animate-fade-in {
    animation: fade-in 0.8s cubic-bezier(.4,0,.2,1) both;
}

.animate-fade-in.delay-100 { animation-delay: 0.1s; }
.animate-fade-in.delay-200 { animation-delay: 0.2s; }

.text-8xl {
	font-size: 6rem;
	line-height: 1
}

.text-lg {
	font-size: 1.125rem;
	line-height: 1.75rem
}

.text-sm {
	font-size: .875rem;
	line-height: 1.25rem
}

.text-xl {
	font-size: 1.25rem;
	line-height: 1.75rem
}

.font-black {
	font-weight: 900
}

.font-bold {
	font-weight: 700
}

.font-medium {
	font-weight: 500
}

.font-semibold {
	font-weight: 600
}

.uppercase {
	text-transform: uppercase
}

.italic {
	font-style: italic
}

.text-accent {
	--tw-text-opacity: 1;
	color: rgb(193 109 252 / var(--tw-text-opacity))
}

.text-dark {
	--tw-text-opacity: 1;
	color: rgb(20 20 20 / var(--tw-text-opacity))
}

.text-green-400 {
	--tw-text-opacity: 1;
	color: rgb(74 222 128 / var(--tw-text-opacity))
}

.text-light {
	--tw-text-opacity: 1;
	color: rgb(230 230 235 / var(--tw-text-opacity))
}

.text-light\/50 {
	color: #f1f0ea80
}

.text-light\/75 {
	color: #f1f0eabf
}

.text-light\/90 {
	color: #f1f0eae6
}

.text-red-400 {
	--tw-text-opacity: 1;
	color: rgb(248 113 113 / var(--tw-text-opacity))
}

.text-red-600 {
	--tw-text-opacity: 1;
	color: rgb(220 38 38 / var(--tw-text-opacity))
}

.text-transparent {
	color: transparent
}

.text-white {
	--tw-text-opacity: 1;
	color: rgb(255 255 255 / var(--tw-text-opacity))
}

.text-yellow-400 {
	--tw-text-opacity: 1;
	color: rgb(250 204 21 / var(--tw-text-opacity))
}

.underline {
	text-decoration-line: underline
}

.line-through {
	text-decoration-line: line-through
}

.accent-accent {
	accent-color: #C16DFC
}

.opacity-0 {
	opacity: 0
}

.opacity-50 {
	opacity: .5
}

.outline-none {
	outline: 2px solid transparent;
	outline-offset: 2px
}

.invert {
	--tw-invert: invert(100%);
	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 {
	--tw-backdrop-blur: blur(8px);
	-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-all {
	transition-property: all;
	transition-timing-function: cubic-bezier(.4, 0, .2, 1);
	transition-duration: .15s
}

.transition-colors {
	transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
	transition-timing-function: cubic-bezier(.4, 0, .2, 1);
	transition-duration: .15s
}

.transition-opacity {
	transition-property: opacity;
	transition-timing-function: cubic-bezier(.4, 0, .2, 1);
	transition-duration: .15s
}

.selection\:bg-accent *::-moz-selection {
	--tw-bg-opacity: 1;
	background-color: rgb(193 109 252 / var(--tw-bg-opacity))
}

.selection\:bg-accent *::selection {
	--tw-bg-opacity: 1;
	background-color: rgb(193 109 252 / var(--tw-bg-opacity))
}

.selection\:text-dark *::-moz-selection {
	--tw-text-opacity: 1;
	color: rgb(20 20 20 / var(--tw-text-opacity))
}

.selection\:text-dark *::selection {
	--tw-text-opacity: 1;
	color: rgb(20 20 20 / var(--tw-text-opacity))
}

.selection\:bg-accent::-moz-selection {
	--tw-bg-opacity: 1;
	background-color: rgb(193 109 252 / var(--tw-bg-opacity))
}

.selection\:bg-accent::selection {
	--tw-bg-opacity: 1;
	background-color: rgb(193 109 252 / var(--tw-bg-opacity))
}

.selection\:text-dark::-moz-selection {
	--tw-text-opacity: 1;
	color: rgb(20 20 20 / var(--tw-text-opacity))
}

.selection\:text-dark::selection {
	--tw-text-opacity: 1;
	color: rgb(20 20 20 / var(--tw-text-opacity))
}

.placeholder\:font-semibold::-moz-placeholder {
	font-weight: 600
}

.placeholder\:font-semibold::placeholder {
	font-weight: 600
}

.placeholder\:text-light\/25::-moz-placeholder {
	color: #f1f0ea40
}

.placeholder\:text-light\/25::placeholder {
	color: #f1f0ea40
}

.hover\:-translate-y-1:hover {
	--tw-translate-y: -.25rem;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.hover\:translate-x-0:hover {
	--tw-translate-x: 0px;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.hover\:translate-x-0\.5:hover {
	--tw-translate-x: .125rem;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.hover\:scale-105:hover {
	--tw-scale-x: 1.05;
	--tw-scale-y: 1.05;
	transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))
}

.hover\:cursor-pointer:hover {
	cursor: pointer
}

.hover\:border-accent:hover {
	--tw-border-opacity: 1;
	border-color: rgb(193 109 252 / var(--tw-border-opacity))
}

.hover\:border-accent\/75:hover {
	border-color: #C16DFCbf
}

.hover\:bg-accent:hover {
	--tw-bg-opacity: 1;
	background-color: rgb(193 109 252 / var(--tw-bg-opacity))
}

.hover\:text-accent:hover {
	--tw-text-opacity: 1;
	color: rgb(193 109 252 / var(--tw-text-opacity))
}

.focus\:border-accent:focus {
	--tw-border-opacity: 1;
	border-color: rgb(193 109 252 / var(--tw-border-opacity))
}

.group:hover .group-hover\:opacity-100 {
	opacity: 1
}

.peer:checked~.peer-checked\:border-accent {
	--tw-border-opacity: 1;
	border-color: rgb(193 109 252 / var(--tw-border-opacity))
}

.peer:checked~.peer-checked\:bg-accent\/10 {
	background-color: #C16DFC1a
}

.hover\:prose-a\:text-accent :is(:where(a):not(:where([class~=not-prose], [class~=not-prose] *))):hover {
	--tw-text-opacity: 1;
	color: rgb(193 109 252 / var(--tw-text-opacity))
}

@media (min-width: 640px) {
	.sm\:order-last {
		order: 9999
	}

	.sm\:mx-auto {
		margin-left: auto;
		margin-right: auto
	}

	.sm\:ml-0 {
		margin-left: 0
	}

	.sm\:ml-auto {
		margin-left: auto
	}

	.sm\:mr-0 {
		margin-right: 0
	}

	.sm\:mr-auto {
		margin-right: auto
	}

	.sm\:h-12 {
		height: 3rem
	}

	.sm\:grid-cols-2 {
		grid-template-columns: repeat(2, minmax(0, 1fr))
	}

	.sm\:flex-row {
		flex-direction: row
	}

	.sm\:gap-12 {
		gap: 3rem
	}

	.sm\:gap-16 {
		gap: 4rem
	}

	.sm\:gap-8 {
		gap: 2rem
	}

	.sm\:text-right {
		text-align: right
	}
}

@media (min-width: 768px) {
	.md\:sticky {
		position: sticky
	}

	.md\:top-0 {
		top: 0
	}

	.md\:z-50 {
		z-index: 50
	}

	.md\:grid-cols-2 {
		grid-template-columns: repeat(2, minmax(0, 1fr))
	}
}

@media (min-width: 1024px) {
	.lg\:flex-row {
		flex-direction: row
	}

	.lg\:text-right {
		text-align: right
	}

	.lg\:text-9xl {
		font-size: 8rem;
		line-height: 1
	}
}


button, .btn, a.button, a[class*="bg-light"], a[class*="bg-accent"] {
  border-radius: 1.25rem !important;
  transition: background 0.22s cubic-bezier(.4,0,.2,1), color 0.18s, box-shadow 0.22s, transform 0.18s;
  box-shadow: 0 2px 16px 0 #C16DFC22, 0 1.5px 8px 0 #23233611;
  will-change: transform, box-shadow;
}
button:hover, .btn:hover, a.button:hover, a[class*="bg-light"]:hover, a[class*="bg-accent"]:hover {
  transform: scale(1.07) rotate(-1.5deg);
  box-shadow: 0 6px 32px 0 #C16DFC44, 0 2px 12px 0 #23233622;
  background: linear-gradient(90deg, #C16DFC 60%, #7F4AFF 100%);
  color: #fff !important;
}

input, textarea, select {
  border-radius: 1.25rem !important;
  transition: border-color 0.18s, box-shadow 0.18s;
}

input:focus, textarea:focus, select:focus {
  box-shadow: 0 0 0 2px #C16DFC55;
  border-color: #C16DFC;
}

.feature-card {
  border-radius: 2.25rem !important;
  transition: box-shadow 0.32s cubic-bezier(.4,0,.2,1), transform 0.32s cubic-bezier(.4,0,.2,1);
}

.feature-card:hover {
  transform: scale(1.025) rotate(-0.5deg) translateY(-8px);
  box-shadow: 0 16px 48px 0 #C16DFC55, 0 2px 12px 0 #23233622;
}

@keyframes fade-in-pop {
  0% { opacity: 0; transform: scale(0.96) translateY(32px); }
  60% { opacity: 1; transform: scale(1.04) translateY(-4px); }
  100% { opacity: 1; transform: scale(1) translateY(0); }
}
.animate-fade-in {
  animation: fade-in-pop 0.85s cubic-bezier(.4,0,.2,1) both;
}

button:active, .btn:active, a.button:active, a[class*="bg-light"]:active, a[class*="bg-accent"]:active {
  transform: scale(0.96) rotate(0.5deg);
  box-shadow: 0 1px 4px 0 #C16DFC33;
}

input[type="checkbox"], .custom-checkbox {
  border-radius: 0.75rem !important;
}

.rounded-lg, .rounded-xl, .rounded-3xl {
  border-radius: 2.25rem !important;
}