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

*, :before, :after {
    box-sizing: border-box;
    border: 0 solid #e5e7eb
}

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

html, :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    font-family: var(--font-body);
    font-feature-settings: normal;
    font-variation-settings: normal;
    -webkit-tap-highlight-color: transparent
}

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

hr {
    height: 0;
    color: inherit;
    border-top-width: 1px
}

abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted
}

h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit
}

a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit
}

b, strong {
    font-weight: bolder
}

code, kbd, samp, pre {
    font-feature-settings: normal;
    font-variation-settings: normal;
    font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;
    font-size: 1em
}

small {
    font-size: 80%
}

sub, sup {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse
}

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

button, select {
    text-transform: none
}

button, input:where([type=button]), input:where([type=reset]), input:where([type=submit]) {
    -webkit-appearance: button;
    background-color: #0000;
    background-image: none
}

:-moz-focusring {
    outline: auto
}

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

progress {
    vertical-align: baseline
}

::-webkit-inner-spin-button {
    height: auto
}

::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

summary {
    display: list-item
}

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

fieldset {
    margin: 0;
    padding: 0
}

legend {
    padding: 0
}

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

dialog {
    padding: 0
}

textarea {
    resize: vertical
}

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

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

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

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

:disabled {
    cursor: default
}

img, svg, video, canvas, audio, iframe, embed, object {
    vertical-align: middle;
    display: block
}

img, video {
    max-width: 100%;
    height: auto
}

[hidden]:where(:not([hidden=until-found])) {
    display: none
}

:root {
    --font-heading: "Noto Serif SC", "Georgia", serif;
    --font-body: "Noto Sans SC", "system-ui", sans-serif;
    --font-label: "Noto Sans SC", "system-ui", sans-serif;
    --background-50: .98 .01 85;
    --background-100: .95 .02 80;
    --background-200: .92 .02 75;
    --background-300: .88 .03 70;
    --background-400: .82 .03 65;
    --background-500: .75 .04 60;
    --background-600: .68 .04 55;
    --background-700: .6 .05 50;
    --background-800: .5 .05 45;
    --background-900: .4 .04 40;
    --background-950: .25 .03 35;
    --primary-50: .95 .05 25;
    --primary-100: .9 .08 25;
    --primary-200: .82 .12 25;
    --primary-300: .72 .15 25;
    --primary-400: .6 .18 25;
    --primary-500: .48 .2 25;
    --primary-600: .42 .18 25;
    --primary-700: .36 .16 25;
    --primary-800: .3 .14 25;
    --primary-900: .24 .12 25;
    --primary-950: .18 .1 25;
    --accent-50: .95 .05 65;
    --accent-100: .9 .08 65;
    --accent-200: .84 .12 65;
    --accent-300: .76 .16 65;
    --accent-400: .68 .18 65;
    --accent-500: .6 .18 65;
    --accent-600: .54 .16 65;
    --accent-700: .48 .14 65;
    --accent-800: .4 .12 65;
    --accent-900: .32 .1 65;
    --accent-950: .24 .08 65;
    --secondary-50: .96 .02 55;
    --secondary-100: .9 .04 55;
    --secondary-200: .82 .05 55;
    --secondary-300: .74 .06 55;
    --secondary-400: .66 .07 55;
    --secondary-500: .58 .08 55;
    --secondary-600: .52 .07 55;
    --secondary-700: .46 .06 55;
    --secondary-800: .38 .05 55;
    --secondary-900: .3 .04 55;
    --secondary-950: .22 .03 55;
    --foreground-50: .98 .01 80;
    --foreground-100: .94 .02 75;
    --foreground-200: .88 .03 70;
    --foreground-300: .8 .04 65;
    --foreground-400: .7 .05 60;
    --foreground-500: .6 .06 55;
    --foreground-600: .5 .07 50;
    --foreground-700: .42 .07 45;
    --foreground-800: .34 .06 40;
    --foreground-900: .26 .05 35;
    --foreground-950: .18 .04 30
}

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

.absolute {
    position: absolute
}

.relative {
    position: relative
}

.bottom-0 {
    bottom: 0
}

.top-4 {
    top: 1rem
}

.z-0 {
    z-index: 0
}

.z-10 {
    z-index: 10
}

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

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

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

.mb-3 {
    margin-bottom: .75rem
}

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

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

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

.mt-0\.5 {
    margin-top: .125rem
}

.mt-12 {
    margin-top: 3rem
}

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

.mt-3 {
    margin-top: .75rem
}

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

.mt-6 {
    margin-top: 1.5rem
}

.line-clamp-2 {
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden
}

.block {
    display: block
}

.inline-block {
    display: inline-block
}

.flex {
    display: flex
}

.grid {
    display: grid
}

.hidden {
    display: none
}

.h-12 {
    height: 3rem
}

.h-16 {
    height: 4rem
}

.h-36 {
    height: 9rem
}

.h-5 {
    height: 1.25rem
}

.h-52 {
    height: 13rem
}

.h-6 {
    height: 1.5rem
}

.h-8 {
    height: 2rem
}

.h-full {
    height: 100%
}

.h-screen {
    height: 100vh
}

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

.w-12 {
    width: 3rem
}

.w-16 {
    width: 4rem
}

.w-28 {
    width: 7rem
}

.w-40 {
    width: 10rem
}

.w-5 {
    width: 1.25rem
}

.w-6 {
    width: 1.5rem
}

.w-auto {
    width: auto
}

.w-full {
    width: 100%
}

.min-w-0 {
    min-width: 0
}

.max-w-7xl {
    max-width: 80rem
}

.flex-1 {
    flex: 1
}

.flex-shrink-0 {
    flex-shrink: 0
}

.cursor-not-allowed {
    cursor: not-allowed
}

.cursor-pointer {
    cursor: pointer
}

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

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

.flex-col {
    flex-direction: column
}

.flex-wrap {
    flex-wrap: wrap
}

.items-start {
    align-items: flex-start
}

.items-center {
    align-items: center
}

.justify-center {
    justify-content: center
}

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

.gap-1 {
    gap: .25rem
}

.gap-1\.5 {
    gap: .375rem
}

.gap-2 {
    gap: .5rem
}

.gap-3 {
    gap: .75rem
}

.gap-4 {
    gap: 1rem
}

.gap-6 {
    gap: 1.5rem
}

.space-y-1 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.25rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.25rem * var(--tw-space-y-reverse))
}

.space-y-1\.5 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.375rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.375rem * var(--tw-space-y-reverse))
}

.space-y-2 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.5rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.5rem * var(--tw-space-y-reverse))
}

.space-y-2\.5 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.625rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.625rem * var(--tw-space-y-reverse))
}

.space-y-3 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(.75rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(.75rem * var(--tw-space-y-reverse))
}

.space-y-4 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1rem * var(--tw-space-y-reverse))
}

.space-y-5 > :not([hidden]) ~ :not([hidden]) {
    --tw-space-y-reverse: 0;
    margin-top: calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));
    margin-bottom: calc(1.25rem * var(--tw-space-y-reverse))
}

.overflow-hidden {
    overflow: hidden
}

.truncate {
    text-overflow: ellipsis;
    white-space: nowrap;
    overflow: hidden
}

.whitespace-nowrap {
    white-space: nowrap
}

.break-all {
    word-break: break-all
}

.rounded-full {
    border-radius: 9999px
}

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

.rounded-md {
    border-radius: .375rem
}

.border {
    border-width: 1px
}

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

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

.border-background-200\/70 {
    border-color: oklch(var(--background-200) / .7)
}

.bg-accent-100 {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--accent-100) / var(--tw-bg-opacity,1))
}

.bg-background-100 {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--background-100) / var(--tw-bg-opacity,1))
}

.bg-background-50 {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--background-50) / var(--tw-bg-opacity,1))
}

.bg-primary-100 {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--primary-100) / var(--tw-bg-opacity,1))
}

.bg-primary-500 {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--primary-500) / var(--tw-bg-opacity,1))
}

.bg-secondary-100 {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--secondary-100) / var(--tw-bg-opacity,1))
}

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

.object-top {
    -o-object-position: top;
    object-position: top
}

.p-4 {
    padding: 1rem
}

.p-5 {
    padding: 1.25rem
}

.p-8 {
    padding: 2rem
}

.px-2\.5 {
    padding-left: .625rem;
    padding-right: .625rem
}

.px-3 {
    padding-left: .75rem;
    padding-right: .75rem
}

.px-4 {
    padding-left: 1rem;
    padding-right: 1rem
}

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

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

.py-1\.5 {
    padding-top: .375rem;
    padding-bottom: .375rem
}

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

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

.py-6 {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem
}

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

.pb-4 {
    padding-bottom: 1rem
}

.text-center {
    text-align: center
}

.font-body {
    font-family: var(--font-body)
}

.font-heading {
    font-family: var(--font-heading)
}

.font-mono {
    font-family: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace
}

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

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

.text-base {
    font-size: 1rem;
    line-height: 1.5rem
}

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

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

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

.text-xs {
    font-size: .75rem;
    line-height: 1rem
}

.font-black {
    font-weight: 900
}

.font-bold {
    font-weight: 700
}

.font-medium {
    font-weight: 500
}

.font-semibold {
    font-weight: 600
}

.leading-relaxed {
    line-height: 1.625
}

.text-accent-900 {
    --tw-text-opacity: 1;
    color: oklch(var(--accent-900) / var(--tw-text-opacity,1))
}

.text-background-50 {
    --tw-text-opacity: 1;
    color: oklch(var(--background-50) / var(--tw-text-opacity,1))
}

.text-background-50\/90 {
    color: oklch(var(--background-50) / .9)
}

.text-foreground-300 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-300) / var(--tw-text-opacity,1))
}

.text-foreground-400 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-400) / var(--tw-text-opacity,1))
}

.text-foreground-500 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-500) / var(--tw-text-opacity,1))
}

.text-foreground-600 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-600) / var(--tw-text-opacity,1))
}

.text-foreground-700 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-700) / var(--tw-text-opacity,1))
}

.text-foreground-800 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-800) / var(--tw-text-opacity,1))
}

.text-foreground-900 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-900) / var(--tw-text-opacity,1))
}

.text-foreground-950 {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-950) / var(--tw-text-opacity,1))
}

.text-gray-400 {
    --tw-text-opacity: 1;
    color: rgb(156 163 175/var(--tw-text-opacity,1))
}

.text-gray-50 {
    --tw-text-opacity: 1;
    color: rgb(249 250 251/var(--tw-text-opacity,1))
}

.text-gray-500 {
    --tw-text-opacity: 1;
    color: rgb(107 114 128/var(--tw-text-opacity,1))
}

.text-primary-500 {
    --tw-text-opacity: 1;
    color: oklch(var(--primary-500) / var(--tw-text-opacity,1))
}

.text-primary-600 {
    --tw-text-opacity: 1;
    color: oklch(var(--primary-600) / var(--tw-text-opacity,1))
}

.text-primary-800 {
    --tw-text-opacity: 1;
    color: oklch(var(--primary-800) / var(--tw-text-opacity,1))
}

.text-secondary-500 {
    --tw-text-opacity: 1;
    color: oklch(var(--secondary-500) / var(--tw-text-opacity,1))
}

.text-secondary-900 {
    --tw-text-opacity: 1;
    color: oklch(var(--secondary-900) / var(--tw-text-opacity,1))
}

.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)
}

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

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

.duration-200 {
    transition-duration: .2s
}

.duration-300 {
    transition-duration: .3s
}

.hover\:border-primary-300:hover {
    --tw-border-opacity: 1;
    border-color: oklch(var(--primary-300) / var(--tw-border-opacity,1))
}

.hover\:bg-background-200:hover {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--background-200) / var(--tw-bg-opacity,1))
}

.hover\:bg-primary-600:hover {
    --tw-bg-opacity: 1;
    background-color: oklch(var(--primary-600) / var(--tw-bg-opacity,1))
}

.hover\:text-background-50:hover {
    --tw-text-opacity: 1;
    color: oklch(var(--background-50) / var(--tw-text-opacity,1))
}

.hover\:text-foreground-800:hover {
    --tw-text-opacity: 1;
    color: oklch(var(--foreground-800) / var(--tw-text-opacity,1))
}

.hover\:text-primary-600:hover {
    --tw-text-opacity: 1;
    color: oklch(var(--primary-600) / var(--tw-text-opacity,1))
}

.hover\:text-primary-700:hover {
    --tw-text-opacity: 1;
    color: oklch(var(--primary-700) / var(--tw-text-opacity,1))
}

.hover\:shadow-sm:hover {
    --tw-shadow: 0 1px 2px 0 #0000000d;
    --tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);
    box-shadow: var(--tw-ring-offset-shadow,0 0 #0000), var(--tw-ring-shadow,0 0 #0000), var(--tw-shadow)
}

.group:hover .group-hover\:text-primary-600 {
    --tw-text-opacity: 1;
    color: oklch(var(--primary-600) / var(--tw-text-opacity,1))
}

@media (width>=640px) {
    .sm\:mx-0 {
        margin-left: 0;
        margin-right: 0
    }

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

    .sm\:h-40 {
        height: 10rem
    }

    .sm\:w-32 {
        width: 8rem
    }

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

    .sm\:items-baseline {
        align-items: baseline
    }

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

    .sm\:gap-5 {
        gap: 1.25rem
    }

    .sm\:p-5 {
        padding: 1.25rem
    }

    .sm\:p-6 {
        padding: 1.5rem
    }

    .sm\:px-6 {
        padding-left: 1.5rem;
        padding-right: 1.5rem
    }

    .sm\:py-12 {
        padding-top: 3rem;
        padding-bottom: 3rem
    }

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

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

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

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

@media (width>=768px) {
    .md\:block {
        display: block
    }

    .md\:flex {
        display: flex
    }

    .md\:hidden {
        display: none
    }

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

    .md\:text-\[12rem\] {
        font-size: 12rem
    }

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

@media (width>=1024px) {
    .lg\:sticky {
        position: sticky
    }

    .lg\:top-6 {
        top: 1.5rem
    }

    .lg\:w-72 {
        width: 18rem
    }

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

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

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

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