@layer properties;@layer theme,base,components,utilities;@layer theme{:root,:host{--font-sans: var(--font-sans);--font-mono: var(--font-mono);--color-orange-500: oklch(70.5% .213 47.604);--color-yellow-500: oklch(79.5% .184 86.047);--color-yellow-600: oklch(68.1% .162 75.834);--color-green-400: oklch(79.2% .209 151.711);--color-green-500: oklch(72.3% .219 149.579);--color-teal-400: oklch(77.7% .152 181.912);--color-cyan-500: oklch(71.5% .143 215.221);--color-blue-500: oklch(62.3% .214 259.815);--color-blue-600: oklch(54.6% .245 262.881);--color-violet-500: oklch(60.6% .25 292.717);--color-purple-500: oklch(62.7% .265 303.9);--color-purple-600: oklch(55.8% .288 302.321);--color-pink-500: oklch(65.6% .241 354.308);--color-white: #fff;--spacing: .25rem;--container-md: 28rem;--container-lg: 32rem;--container-2xl: 42rem;--container-3xl: 48rem;--container-4xl: 56rem;--container-5xl: 64rem;--container-6xl: 72rem;--text-xs: .75rem;--text-xs--line-height: calc(1 / .75);--text-sm: .875rem;--text-sm--line-height: calc(1.25 / .875);--text-base: 1rem;--text-base--line-height: 1.5 ;--text-lg: 1.125rem;--text-lg--line-height: calc(1.75 / 1.125);--text-xl: 1.25rem;--text-xl--line-height: calc(1.75 / 1.25);--text-2xl: 1.5rem;--text-2xl--line-height: calc(2 / 1.5);--text-3xl: 1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl: 2.25rem;--text-4xl--line-height: calc(2.5 / 2.25);--text-5xl: 3rem;--text-5xl--line-height: 1;--text-7xl: 4.5rem;--text-7xl--line-height: 1;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--tracking-tight: -.025em;--tracking-wider: .05em;--leading-snug: 1.375;--leading-relaxed: 1.625;--animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite;--animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--blur-sm: 8px;--blur-xl: 24px;--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)}}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;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{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px){::placeholder{color: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,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{.visible{visibility:visible}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border-width:0}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.inset-x-0{inset-inline:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-4{top:calc(var(--spacing) * 4)}.top-\[-10\%\]{top:-10%}.top-\[-20\%\]{top:-20%}.top-\[-25\%\]{top:-25%}.top-\[-30\%\]{top:-30%}.top-full{top:100%}.right-0{right:calc(var(--spacing) * 0)}.right-4{right:calc(var(--spacing) * 4)}.right-6{right:calc(var(--spacing) * 6)}.right-23{right:calc(var(--spacing) * 23)}.right-\[-5\%\]{right:-5%}.right-\[-10\%\]{right:-10%}.right-\[-15\%\]{right:-15%}.right-\[10\%\]{right:10%}.bottom-4{bottom:calc(var(--spacing) * 4)}.bottom-6{bottom:calc(var(--spacing) * 6)}.bottom-\[-20\%\]{bottom:-20%}.bottom-\[-30\%\]{bottom:-30%}.left-0{left:calc(var(--spacing) * 0)}.left-23{left:calc(var(--spacing) * 23)}.left-\[-10\%\]{left:-10%}.left-\[10\%\]{left:10%}.left-\[20\%\]{left:20%}.left-\[30\%\]{left:30%}.-z-10{z-index:-10}.z-10{z-index:10}.z-50{z-index:50}.z-\[60\]{z-index:60}.z-\[100\]{z-index:100}.z-\[101\]{z-index:101}.col-span-2{grid-column:span 2 / span 2}.row-span-2{grid-row:span 2 / span 2}.container{width:100%}@media(width>=40rem){.container{max-width:40rem}}@media(width>=48rem){.container{max-width:48rem}}@media(width>=64rem){.container{max-width:64rem}}@media(width>=80rem){.container{max-width:80rem}}@media(width>=96rem){.container{max-width:96rem}}.container{margin-inline:auto;padding-inline:2rem}.mx-4{margin-inline:calc(var(--spacing) * 4)}.mx-auto{margin-inline:auto}.my-2{margin-block:calc(var(--spacing) * 2)}.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-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-5{margin-top:calc(var(--spacing) * 5)}.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-16{margin-top:calc(var(--spacing) * 16)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-10{margin-bottom:calc(var(--spacing) * 10)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.ml-4{margin-left:calc(var(--spacing) * 4)}.line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.table{display:table}.h-1{height:calc(var(--spacing) * 1)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-2{height:calc(var(--spacing) * 2)}.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-16{height:calc(var(--spacing) * 16)}.h-20{height:calc(var(--spacing) * 20)}.h-24{height:calc(var(--spacing) * 24)}.h-64{height:calc(var(--spacing) * 64)}.h-\[1px\]{height:1px}.h-\[2px\]{height:2px}.h-\[3px\]{height:3px}.h-\[350px\]{height:350px}.h-\[400px\]{height:400px}.h-\[450px\]{height:450px}.h-\[500px\]{height:500px}.h-full{height:100%}.max-h-\[300px\]{max-height:300px}.min-h-screen{min-height:100vh}.w-1{width:calc(var(--spacing) * 1)}.w-1\.5{width:calc(var(--spacing) * 1.5)}.w-2{width:calc(var(--spacing) * 2)}.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-16{width:calc(var(--spacing) * 16)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-48{width:calc(var(--spacing) * 48)}.w-\[350px\]{width:350px}.w-\[400px\]{width:400px}.w-\[450px\]{width:450px}.w-\[500px\]{width:500px}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-3xl{max-width:var(--container-3xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-5xl{max-width:var(--container-5xl)}.max-w-6xl{max-width:var(--container-6xl)}.max-w-\[200px\]{max-width:200px}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-none{max-width:none}.flex-1{flex:1}.shrink-0{flex-shrink:0}.translate-x-2{--tw-translate-x: calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}.-rotate-90{rotate:-90deg}.rotate-0{rotate:0deg}.rotate-90{rotate:90deg}.rotate-180{rotate:180deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-in{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.animate-ping{animation:var(--animate-ping)}.animate-pulse{animation:var(--animate-pulse)}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-2\.5{gap:calc(var(--spacing) * 2.5)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-5{gap:calc(var(--spacing) * 5)}.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-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)))}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:calc(var(--radius) + 8px)}.rounded-3xl{border-radius:calc(var(--radius) + 12px)}.rounded-\[calc\(1rem-1px\)\]{border-radius:calc(1rem - 1px)}.rounded-full{border-radius:calc(infinity * 1px)}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-border{border-color:var(--border)}.border-border\/40{border-color:var(--border)}@supports (color: color-mix(in lab,red,red)){.border-border\/40{border-color:color-mix(in oklab,var(--border) 40%,transparent)}}.border-border\/60{border-color:var(--border)}@supports (color: color-mix(in lab,red,red)){.border-border\/60{border-color:color-mix(in oklab,var(--border) 60%,transparent)}}.bg-accent{background-color:var(--accent)}.bg-background{background-color:var(--background)}.bg-background\/80{background-color:var(--background)}@supports (color: color-mix(in lab,red,red)){.bg-background\/80{background-color:color-mix(in oklab,var(--background) 80%,transparent)}}.bg-background\/95{background-color:var(--background)}@supports (color: color-mix(in lab,red,red)){.bg-background\/95{background-color:color-mix(in oklab,var(--background) 95%,transparent)}}.bg-blue-500{background-color:var(--color-blue-500)}.bg-blue-500\/10{background-color:color-mix(in srgb,oklch(62.3% .214 259.815) 10%,transparent)}@supports (color: color-mix(in lab,red,red)){.bg-blue-500\/10{background-color:color-mix(in oklab,var(--color-blue-500) 10%,transparent)}}.bg-blue-500\/15{background-color:color-mix(in srgb,oklch(62.3% .214 259.815) 15%,transparent)}@supports (color: color-mix(in lab,red,red)){.bg-blue-500\/15{background-color:color-mix(in oklab,var(--color-blue-500) 15%,transparent)}}.bg-card{background-color:var(--card)}.bg-card\/50{background-color:var(--card)}@supports (color: color-mix(in lab,red,red)){.bg-card\/50{background-color:color-mix(in oklab,var(--card) 50%,transparent)}}.bg-card\/60{background-color:var(--card)}@supports (color: color-mix(in lab,red,red)){.bg-card\/60{background-color:color-mix(in oklab,var(--card) 60%,transparent)}}.bg-card\/95{background-color:var(--card)}@supports (color: color-mix(in lab,red,red)){.bg-card\/95{background-color:color-mix(in oklab,var(--card) 95%,transparent)}}.bg-green-400{background-color:var(--color-green-400)}.bg-green-500{background-color:var(--color-green-500)}.bg-muted{background-color:var(--muted)}.bg-muted-foreground\/50{background-color:var(--muted-foreground)}@supports (color: color-mix(in lab,red,red)){.bg-muted-foreground\/50{background-color:color-mix(in oklab,var(--muted-foreground) 50%,transparent)}}.bg-muted\/50{background-color:var(--muted)}@supports (color: color-mix(in lab,red,red)){.bg-muted\/50{background-color:color-mix(in oklab,var(--muted) 50%,transparent)}}.bg-orange-500{background-color:var(--color-orange-500)}.bg-pink-500{background-color:var(--color-pink-500)}.bg-pink-500\/10{background-color:color-mix(in srgb,oklch(65.6% .241 354.308) 10%,transparent)}@supports (color: color-mix(in lab,red,red)){.bg-pink-500\/10{background-color:color-mix(in oklab,var(--color-pink-500) 10%,transparent)}}.bg-primary{background-color:var(--primary)}.bg-primary-foreground{background-color:var(--primary-foreground)}.bg-purple-500{background-color:var(--color-purple-500)}.bg-purple-500\/8{background-color:color-mix(in srgb,oklch(62.7% .265 303.9) 8%,transparent)}@supports (color: color-mix(in lab,red,red)){.bg-purple-500\/8{background-color:color-mix(in oklab,var(--color-purple-500) 8%,transparent)}}.bg-purple-500\/10{background-color:color-mix(in srgb,oklch(62.7% .265 303.9) 10%,transparent)}@supports (color: color-mix(in lab,red,red)){.bg-purple-500\/10{background-color:color-mix(in oklab,var(--color-purple-500) 10%,transparent)}}.bg-purple-500\/15{background-color:color-mix(in srgb,oklch(62.7% .265 303.9) 15%,transparent)}@supports (color: color-mix(in lab,red,red)){.bg-purple-500\/15{background-color:color-mix(in oklab,var(--color-purple-500) 15%,transparent)}}.bg-secondary{background-color:var(--secondary)}.bg-secondary\/50{background-color:var(--secondary)}@supports (color: color-mix(in lab,red,red)){.bg-secondary\/50{background-color:color-mix(in oklab,var(--secondary) 50%,transparent)}}.bg-transparent{background-color:transparent}.bg-yellow-500\/10{background-color:color-mix(in srgb,oklch(79.5% .184 86.047) 10%,transparent)}@supports (color: color-mix(in lab,red,red)){.bg-yellow-500\/10{background-color:color-mix(in oklab,var(--color-yellow-500) 10%,transparent)}}.bg-gradient-to-br{--tw-gradient-position: to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position: to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-blue-600{--tw-gradient-from: var(--color-blue-600);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-purple-500{--tw-gradient-from: var(--color-purple-500);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-purple-600{--tw-gradient-from: var(--color-purple-600);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-transparent{--tw-gradient-from: transparent;--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-violet-500\/10{--tw-gradient-from: color-mix(in srgb, oklch(60.6% .25 292.717) 10%, transparent);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}@supports (color: color-mix(in lab,red,red)){.from-violet-500\/10{--tw-gradient-from: color-mix(in oklab, var(--color-violet-500) 10%, transparent)}}.via-border{--tw-gradient-via: var(--border);--tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-via-stops)}.via-card{--tw-gradient-via: var(--card);--tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-via-stops)}.via-cyan-500{--tw-gradient-via: var(--color-cyan-500);--tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-via-stops)}.via-pink-500{--tw-gradient-via: var(--color-pink-500);--tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-via-stops)}.via-primary\/50{--tw-gradient-via: var(--primary);--tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-via-stops)}@supports (color: color-mix(in lab,red,red)){.via-primary\/50{--tw-gradient-via: color-mix(in oklab, var(--primary) 50%, transparent)}}.via-purple-500{--tw-gradient-via: var(--color-purple-500);--tw-gradient-via-stops: var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-via-stops)}.to-blue-500{--tw-gradient-to: var(--color-blue-500);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-blue-500\/10{--tw-gradient-to: color-mix(in srgb, oklch(62.3% .214 259.815) 10%, transparent);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}@supports (color: color-mix(in lab,red,red)){.to-blue-500\/10{--tw-gradient-to: color-mix(in oklab, var(--color-blue-500) 10%, transparent)}}.to-orange-500{--tw-gradient-to: var(--color-orange-500);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-pink-500{--tw-gradient-to: var(--color-pink-500);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-teal-400{--tw-gradient-to: var(--color-teal-400);--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-transparent{--tw-gradient-to: transparent;--tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.p-1\.5{padding:calc(var(--spacing) * 1.5)}.p-2{padding:calc(var(--spacing) * 2)}.p-2\.5{padding:calc(var(--spacing) * 2.5)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-\[1px\]{padding:1px}.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-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-8{padding-inline:calc(var(--spacing) * 8)}.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-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-3\.5{padding-block:calc(var(--spacing) * 3.5)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-6{padding-block:calc(var(--spacing) * 6)}.py-12{padding-block:calc(var(--spacing) * 12)}.py-16{padding-block:calc(var(--spacing) * 16)}.py-20{padding-block:calc(var(--spacing) * 20)}.py-32{padding-block:calc(var(--spacing) * 32)}.pt-6{padding-top:calc(var(--spacing) * 6)}.pt-10{padding-top:calc(var(--spacing) * 10)}.pt-12{padding-top:calc(var(--spacing) * 12)}.pt-16{padding-top:calc(var(--spacing) * 16)}.pt-20{padding-top:calc(var(--spacing) * 20)}.pt-\[15vh\]{padding-top:15vh}.pb-4{padding-bottom:calc(var(--spacing) * 4)}.pb-10{padding-bottom:calc(var(--spacing) * 10)}.pb-12{padding-bottom:calc(var(--spacing) * 12)}.pb-20{padding-bottom:calc(var(--spacing) * 20)}.pb-24{padding-bottom:calc(var(--spacing) * 24)}.text-center{text-align:center}.text-left{text-align:left}.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-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading, var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading, var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading, var(--text-5xl--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-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.leading-\[1\.1\]{--tw-leading: 1.1;line-height:1.1}.leading-\[1\.05\]{--tw-leading: 1.05;line-height:1.05}.leading-relaxed{--tw-leading: var(--leading-relaxed);line-height:var(--leading-relaxed)}.leading-snug{--tw-leading: var(--leading-snug);line-height:var(--leading-snug)}.font-bold{--tw-font-weight: var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-extrabold{--tw-font-weight: var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.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-wider{--tw-tracking: var(--tracking-wider);letter-spacing:var(--tracking-wider)}.text-foreground{color:var(--foreground)}.text-muted-foreground{color:var(--muted-foreground)}.text-muted-foreground\/50{color:var(--muted-foreground)}@supports (color: color-mix(in lab,red,red)){.text-muted-foreground\/50{color:color-mix(in oklab,var(--muted-foreground) 50%,transparent)}}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-transparent{color:transparent}.text-white{color:var(--color-white)}.text-yellow-600{color:var(--color-yellow-600)}.uppercase{text-transform:uppercase}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0%}.opacity-60{opacity:60%}.opacity-75{opacity:75%}.shadow-2xl{--tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / .25));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, rgb(0 0 0 / .1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / .1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-primary\/25{--tw-shadow-color: var(--primary)}@supports (color: color-mix(in lab,red,red)){.shadow-primary\/25{--tw-shadow-color: color-mix(in oklab, color-mix(in oklab, var(--primary) 25%, transparent) var(--tw-shadow-alpha), transparent)}}.blur{--tw-blur: blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.blur-\[100px\]{--tw-blur: blur(100px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.blur-\[120px\]{--tw-blur: blur(120px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur{--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,)}.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,)}.backdrop-blur-xl{--tw-backdrop-blur: blur(var(--blur-xl));-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: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))}.delay-100{transition-delay:.1s}.delay-150{transition-delay:.15s}.delay-200{transition-delay:.2s}.delay-300{transition-delay:.3s}.delay-500{transition-delay:.5s}.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}.delay-100{animation-delay:100ms;animation-delay:.1s;--tw-animation-delay: 100ms ;--tw-animation-delay: .1s}.delay-150{animation-delay:150ms;animation-delay:.15s;--tw-animation-delay: 150ms ;--tw-animation-delay: .15s}.delay-200{animation-delay:200ms;animation-delay:.2s;--tw-animation-delay: 200ms ;--tw-animation-delay: .2s}.delay-300{animation-delay:300ms;animation-delay:.3s;--tw-animation-delay: 300ms ;--tw-animation-delay: .3s}.delay-500{animation-delay:500ms;animation-delay:.5s;--tw-animation-delay: 500ms ;--tw-animation-delay: .5s}.outline-none{--tw-outline-style: none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.fade-in{--tw-enter-opacity: 0}.running{animation-play-state:running}.slide-in-from-bottom-2{--tw-enter-translate-y: calc(2*var(--spacing))}.slide-in-from-bottom-4{--tw-enter-translate-y: calc(4*var(--spacing))}.slide-in-from-top-2{--tw-enter-translate-y: calc(2*var(--spacing)*-1)}@media(hover:hover){.group-hover\:mr-1:is(:where(.group):hover *){margin-right:calc(var(--spacing) * 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)}}@media(hover:hover){.group-hover\:translate-x-1:is(:where(.group):hover *){--tw-translate-x: calc(var(--spacing) * 1);translate:var(--tw-translate-x) var(--tw-translate-y)}}@media(hover:hover){.group-hover\:translate-x-2:is(:where(.group):hover *){--tw-translate-x: calc(var(--spacing) * 2);translate:var(--tw-translate-x) var(--tw-translate-y)}}@media(hover:hover){.group-hover\:scale-110:is(:where(.group):hover *){--tw-scale-x: 110%;--tw-scale-y: 110%;--tw-scale-z: 110%;scale:var(--tw-scale-x) var(--tw-scale-y)}}@media(hover:hover){.group-hover\:bg-primary:is(:where(.group):hover *){background-color:var(--primary)}}@media(hover:hover){.group-hover\:text-foreground:is(:where(.group):hover *){color:var(--foreground)}}@media(hover:hover){.group-hover\:text-primary:is(:where(.group):hover *){color:var(--primary)}}@media(hover:hover){.group-hover\:text-primary-foreground:is(:where(.group):hover *){color:var(--primary-foreground)}}@media(hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:100%}}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}@media(hover:hover){.hover\:-translate-y-0\.5:hover{--tw-translate-y: calc(var(--spacing) * -.5);translate:var(--tw-translate-x) var(--tw-translate-y)}}@media(hover:hover){.hover\:-translate-y-1:hover{--tw-translate-y: calc(var(--spacing) * -1);translate:var(--tw-translate-x) var(--tw-translate-y)}}@media(hover:hover){.hover\:border-accent:hover{border-color:var(--accent)}}@media(hover:hover){.hover\:border-primary\/20:hover{border-color:var(--primary)}@supports (color: color-mix(in lab,red,red)){.hover\:border-primary\/20:hover{border-color:color-mix(in oklab,var(--primary) 20%,transparent)}}}@media(hover:hover){.hover\:border-transparent:hover{border-color:transparent}}@media(hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}}@media(hover:hover){.hover\:bg-accent\/50:hover{background-color:var(--accent)}@supports (color: color-mix(in lab,red,red)){.hover\:bg-accent\/50:hover{background-color:color-mix(in oklab,var(--accent) 50%,transparent)}}}@media(hover:hover){.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}}@media(hover:hover){.hover\:text-foreground:hover{color:var(--foreground)}}@media(hover:hover){.hover\:underline:hover{text-decoration-line:underline}}@media(hover:hover){.hover\:opacity-80:hover{opacity:80%}}@media(hover:hover){.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / .1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / .1));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){.hover\:shadow-sm:hover{--tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / .1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / .1));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){.hover\:shadow-xl:hover{--tw-shadow: 0 20px 25px -5px var(--tw-shadow-color, rgb(0 0 0 / .1)), 0 8px 10px -6px var(--tw-shadow-color, rgb(0 0 0 / .1));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){.hover\:shadow-primary\/30:hover{--tw-shadow-color: var(--primary)}@supports (color: color-mix(in lab,red,red)){.hover\:shadow-primary\/30:hover{--tw-shadow-color: color-mix(in oklab, color-mix(in oklab, var(--primary) 30%, transparent) var(--tw-shadow-alpha), transparent)}}}.focus\:not-sr-only:focus{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip-path:none;white-space:normal}.focus\:fixed:focus{position:fixed}.focus\:top-4:focus{top:calc(var(--spacing) * 4)}.focus\:left-4:focus{left:calc(var(--spacing) * 4)}.focus\:z-\[200\]:focus{z-index:200}.focus\:rounded-md:focus{border-radius:calc(var(--radius) - 2px)}.focus\:bg-primary:focus{background-color:var(--primary)}.focus\:px-4:focus{padding-inline:calc(var(--spacing) * 4)}.focus\:py-2:focus{padding-block:calc(var(--spacing) * 2)}.focus\:text-sm:focus{font-size:var(--text-sm);line-height:var(--tw-leading, var(--text-sm--line-height))}.focus\:font-semibold:focus{--tw-font-weight: var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.focus\:text-primary-foreground:focus{color:var(--primary-foreground)}.focus\:shadow-lg:focus{--tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / .1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / .1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.active\:scale-95:active{--tw-scale-x: 95%;--tw-scale-y: 95%;--tw-scale-z: 95%;scale:var(--tw-scale-x) var(--tw-scale-y)}.active\:scale-\[0\.96\]:active{scale:.96}.active\:scale-\[0\.97\]:active{scale:.97}.active\:scale-\[0\.98\]:active{scale:.98}@supports (backdrop-filter: var(--tw)){.supports-\[backdrop-filter\]\:bg-background\/60{background-color:var(--background)}@supports (color: color-mix(in lab,red,red)){.supports-\[backdrop-filter\]\:bg-background\/60{background-color:color-mix(in oklab,var(--background) 60%,transparent)}}}@media(width>=40rem){.sm\:ml-auto{margin-left:auto}}@media(width>=40rem){.sm\:block{display:block}}@media(width>=40rem){.sm\:hidden{display:none}}@media(width>=40rem){.sm\:inline{display:inline}}@media(width>=40rem){.sm\:inline-flex{display:inline-flex}}@media(width>=40rem){.sm\:flex-row{flex-direction:row}}@media(width>=40rem){.sm\:items-center{align-items:center}}@media(width>=48rem){.md\:top-8{top:calc(var(--spacing) * 8)}}@media(width>=48rem){.md\:right-6{right:calc(var(--spacing) * 6)}}@media(width>=48rem){.md\:right-8{right:calc(var(--spacing) * 8)}}@media(width>=48rem){.md\:bottom-6{bottom:calc(var(--spacing) * 6)}}@media(width>=48rem){.md\:col-span-2{grid-column:span 2 / span 2}}@media(width>=48rem){.md\:row-span-2{grid-row:span 2 / span 2}}@media(width>=48rem){.md\:mt-2{margin-top:calc(var(--spacing) * 2)}}@media(width>=48rem){.md\:flex{display:flex}}@media(width>=48rem){.md\:hidden{display:none}}@media(width>=48rem){.md\:inline-flex{display:inline-flex}}@media(width>=48rem){.md\:flex-1{flex:1}}@media(width>=48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(width>=48rem){.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(width>=48rem){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(width>=48rem){.md\:items-stretch{align-items:stretch}}@media(width>=48rem){.md\:gap-2{gap:calc(var(--spacing) * 2)}}@media(width>=48rem){.md\:gap-4{gap:calc(var(--spacing) * 4)}}@media(width>=48rem){.md\:gap-16{gap:calc(var(--spacing) * 16)}}@media(width>=48rem){.md\:p-8{padding:calc(var(--spacing) * 8)}}@media(width>=48rem){.md\:p-12{padding:calc(var(--spacing) * 12)}}@media(width>=48rem){.md\:py-16{padding-block:calc(var(--spacing) * 16)}}@media(width>=48rem){.md\:py-20{padding-block:calc(var(--spacing) * 20)}}@media(width>=48rem){.md\:pt-16{padding-top:calc(var(--spacing) * 16)}}@media(width>=48rem){.md\:pt-24{padding-top:calc(var(--spacing) * 24)}}@media(width>=48rem){.md\:pt-32{padding-top:calc(var(--spacing) * 32)}}@media(width>=48rem){.md\:pb-14{padding-bottom:calc(var(--spacing) * 14)}}@media(width>=48rem){.md\:pb-16{padding-bottom:calc(var(--spacing) * 16)}}@media(width>=48rem){.md\:pb-32{padding-bottom:calc(var(--spacing) * 32)}}@media(width>=48rem){.md\:text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading, var(--text-2xl--line-height))}}@media(width>=48rem){.md\:text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading, var(--text-3xl--line-height))}}@media(width>=48rem){.md\:text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading, var(--text-4xl--line-height))}}@media(width>=48rem){.md\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading, var(--text-5xl--line-height))}}@media(width>=48rem){.md\:text-7xl{font-size:var(--text-7xl);line-height:var(--tw-leading, var(--text-7xl--line-height))}}@media(width>=48rem){.md\:text-base{font-size:var(--text-base);line-height:var(--tw-leading, var(--text-base--line-height))}}@media(width>=48rem){.md\:text-lg{font-size:var(--text-lg);line-height:var(--tw-leading, var(--text-lg--line-height))}}@media(width>=48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading, var(--text-sm--line-height))}}@media(width>=48rem){.md\:text-xl{font-size:var(--text-xl);line-height:var(--tw-leading, var(--text-xl--line-height))}}@media(width>=64rem){.lg\:p-16{padding:calc(var(--spacing) * 16)}}@media(width>=64rem){.lg\:text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading, var(--text-5xl--line-height))}}.\[\&_a\]\:text-primary a{color:var(--primary)}.\[\&_a\]\:underline a{text-decoration-line:underline}.\[\&_a\]\:underline-offset-4 a{text-underline-offset:4px}.\[\&_a\:hover\]\:text-primary\/80 a:hover{color:var(--primary)}@supports (color: color-mix(in lab,red,red)){.\[\&_a\:hover\]\:text-primary\/80 a:hover{color:color-mix(in oklab,var(--primary) 80%,transparent)}}.\[\&_code\]\:rounded-md code{border-radius:calc(var(--radius) - 2px)}.\[\&_code\]\:bg-muted code{background-color:var(--muted)}.\[\&_code\]\:px-1\.5 code{padding-inline:calc(var(--spacing) * 1.5)}.\[\&_code\]\:py-0\.5 code{padding-block:calc(var(--spacing) * .5)}.\[\&_code\]\:font-mono code{font-family:var(--font-mono)}.\[\&_code\]\:text-sm code{font-size:var(--text-sm);line-height:var(--tw-leading, var(--text-sm--line-height))}.\[\&\>code\]\:rounded-md>code{border-radius:calc(var(--radius) - 2px)}.\[\&\>code\]\:bg-muted>code{background-color:var(--muted)}.\[\&\>code\]\:px-1\.5>code{padding-inline:calc(var(--spacing) * 1.5)}.\[\&\>code\]\:py-0\.5>code{padding-block:calc(var(--spacing) * .5)}.\[\&\>code\]\:font-mono>code{font-family:var(--font-mono)}.\[\&\>code\]\:text-sm>code{font-size:var(--text-sm);line-height:var(--tw-leading, var(--text-sm--line-height))}.\[\&\>h2\]\:mt-14>h2{margin-top:calc(var(--spacing) * 14)}.\[\&\>h2\]\:mb-5>h2{margin-bottom:calc(var(--spacing) * 5)}.\[\&\>h2\]\:text-2xl>h2{font-size:var(--text-2xl);line-height:var(--tw-leading, var(--text-2xl--line-height))}.\[\&\>h2\]\:font-extrabold>h2{--tw-font-weight: var(--font-weight-extrabold);font-weight:var(--font-weight-extrabold)}.\[\&\>h2\]\:tracking-tight>h2{--tw-tracking: var(--tracking-tight);letter-spacing:var(--tracking-tight)}.\[\&\>h2\]\:text-foreground>h2{color:var(--foreground)}.\[\&\>img\]\:my-8>img{margin-block:calc(var(--spacing) * 8)}.\[\&\>img\]\:w-full>img{width:100%}.\[\&\>img\]\:rounded-xl>img{border-radius:calc(var(--radius) + 4px)}.\[\&\>img\]\:border>img{border-style:var(--tw-border-style);border-width:1px}.\[\&\>img\]\:border-border\/40>img{border-color:var(--border)}@supports (color: color-mix(in lab,red,red)){.\[\&\>img\]\:border-border\/40>img{border-color:color-mix(in oklab,var(--border) 40%,transparent)}}.\[\&\>img\]\:shadow-md>img{--tw-shadow: 0 4px 6px -1px var(--tw-shadow-color, rgb(0 0 0 / .1)), 0 2px 4px -2px var(--tw-shadow-color, rgb(0 0 0 / .1));box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.\[\&\>ol\]\:mb-6>ol{margin-bottom:calc(var(--spacing) * 6)}.\[\&\>ol\]\:ml-6>ol{margin-left:calc(var(--spacing) * 6)}.\[\&\>ol\]\:list-decimal>ol{list-style-type:decimal}.\[\&\>ol\]\:text-foreground>ol{color:var(--foreground)}.\[\&\>ol\>li\]\:mb-2\.5>ol>li{margin-bottom:calc(var(--spacing) * 2.5)}.\[\&\>p\]\:mb-6>p{margin-bottom:calc(var(--spacing) * 6)}.\[\&\>p\]\:text-\[15px\]>p{font-size:15px}.\[\&\>p\]\:leading-\[1\.8\]>p{--tw-leading: 1.8;line-height:1.8}.\[\&\>p\]\:text-foreground>p{color:var(--foreground)}.\[\&\>pre\]\:mb-6>pre{margin-bottom:calc(var(--spacing) * 6)}.\[\&\>pre\]\:overflow-x-auto>pre{overflow-x:auto}.\[\&\>pre\]\:rounded-xl>pre{border-radius:calc(var(--radius) + 4px)}.\[\&\>pre\]\:border>pre{border-style:var(--tw-border-style);border-width:1px}.\[\&\>pre\]\:border-border\/40>pre{border-color:var(--border)}@supports (color: color-mix(in lab,red,red)){.\[\&\>pre\]\:border-border\/40>pre{border-color:color-mix(in oklab,var(--border) 40%,transparent)}}.\[\&\>pre\]\:bg-muted>pre{background-color:var(--muted)}.\[\&\>pre\]\:p-5>pre{padding:calc(var(--spacing) * 5)}.\[\&\>pre\]\:text-sm>pre{font-size:var(--text-sm);line-height:var(--tw-leading, var(--text-sm--line-height))}.\[\&\>pre_code\]\:bg-transparent>pre code{background-color:transparent}.\[\&\>pre_code\]\:p-0>pre code{padding:calc(var(--spacing) * 0)}.\[\&\>ul\]\:mb-6>ul{margin-bottom:calc(var(--spacing) * 6)}.\[\&\>ul\]\:ml-6>ul{margin-left:calc(var(--spacing) * 6)}.\[\&\>ul\]\:list-disc>ul{list-style-type:disc}.\[\&\>ul\]\:text-foreground>ul{color:var(--foreground)}.\[\&\>ul\>li\]\:mb-2\.5>ul>li{margin-bottom:calc(var(--spacing) * 2.5)}.\[\&\>ul\>li\]\:text-\[15px\]>ul>li{font-size:15px}.\[\&\>ul\>li\]\:leading-\[1\.7\]>ul>li{--tw-leading: 1.7;line-height:1.7}}.cdk-overlay-container,.cdk-global-overlay-wrapper{pointer-events:none;top:0;left:0;height:100%;width:100%}.cdk-overlay-container{position:fixed;z-index:1000}.cdk-overlay-container:empty{display:none}.cdk-global-overlay-wrapper{display:flex;position:absolute;z-index:1000}.cdk-overlay-pane{position:absolute;pointer-events:auto;box-sizing:border-box;display:flex;max-width:100%;max-height:100%;z-index:1000}.cdk-overlay-backdrop{position:absolute;inset:0;pointer-events:auto;-webkit-tap-highlight-color:transparent;opacity:0;touch-action:manipulation;z-index:1000;transition:opacity .4s cubic-bezier(.25,.8,.25,1)}@media(prefers-reduced-motion){.cdk-overlay-backdrop{transition-duration:1ms}}.cdk-overlay-backdrop-showing{opacity:1}@media(forced-colors:active){.cdk-overlay-backdrop-showing{opacity:.6}}.cdk-overlay-dark-backdrop{background:#00000052}.cdk-overlay-transparent-backdrop{transition:visibility 1ms linear,opacity 1ms linear;visibility:hidden;opacity:1}.cdk-overlay-transparent-backdrop.cdk-overlay-backdrop-showing,.cdk-high-contrast-active .cdk-overlay-transparent-backdrop{opacity:0;visibility:visible}.cdk-overlay-backdrop-noop-animation{transition:none}.cdk-overlay-connected-position-bounding-box{position:absolute;display:flex;flex-direction:column;min-width:1px;min-height:1px;z-index:1000}.cdk-global-scrollblock{position:fixed;width:100%;overflow-y:scroll}.cdk-overlay-popover{background:none;border:none;padding:0;outline:0;overflow:visible;position:fixed;pointer-events:none;white-space:normal;color:inherit;text-decoration:none;width:100%;height:100%;inset:0 auto auto 0}.cdk-overlay-popover::backdrop{display:none}.cdk-overlay-popover .cdk-overlay-backdrop{position:fixed;z-index:auto}@property --tw-animation-delay{syntax: "*"; inherits: false; initial-value: 0s;}@property --tw-animation-direction{syntax: "*"; inherits: false; initial-value: normal;}@property --tw-animation-duration{syntax: "*"; inherits: false;}@property --tw-animation-fill-mode{syntax: "*"; inherits: false; initial-value: none;}@property --tw-animation-iteration-count{syntax: "*"; inherits: false; initial-value: 1;}@property --tw-enter-blur{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-enter-opacity{syntax: "*"; inherits: false; initial-value: 1;}@property --tw-enter-rotate{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-enter-scale{syntax: "*"; inherits: false; initial-value: 1;}@property --tw-enter-translate-x{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-enter-translate-y{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-exit-blur{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-exit-opacity{syntax: "*"; inherits: false; initial-value: 1;}@property --tw-exit-rotate{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-exit-scale{syntax: "*"; inherits: false; initial-value: 1;}@property --tw-exit-translate-x{syntax: "*"; inherits: false; initial-value: 0;}@property --tw-exit-translate-y{syntax: "*"; inherits: false; initial-value: 0;}@layer base{:root{--background: oklch(1 0 0);--foreground: oklch(.145 0 0);--card: oklch(1 0 0);--card-foreground: oklch(.145 0 0);--popover: oklch(1 0 0);--popover-foreground: oklch(.145 0 0);--primary: oklch(.205 0 0);--primary-foreground: oklch(.985 0 0);--secondary: oklch(.965 0 0);--secondary-foreground: oklch(.205 0 0);--muted: oklch(.965 0 0);--muted-foreground: oklch(.556 0 0);--accent: oklch(.965 0 0);--accent-foreground: oklch(.205 0 0);--destructive: oklch(.577 .245 27.325);--border: oklch(.922 0 0);--input: oklch(.922 0 0);--ring: oklch(.708 0 0);--radius: .625rem;--font-sans: ui-sans-serif, system-ui, sans-serif;--font-mono: ui-monospace, SFMono-Regular, "Fira Code", monospace}.dark{--background: oklch(.145 0 0);--foreground: oklch(.985 0 0);--card: oklch(.145 0 0);--card-foreground: oklch(.985 0 0);--popover: oklch(.145 0 0);--popover-foreground: oklch(.985 0 0);--primary: oklch(.985 0 0);--primary-foreground: oklch(.205 0 0);--secondary: oklch(.269 0 0);--secondary-foreground: oklch(.985 0 0);--muted: oklch(.269 0 0);--muted-foreground: oklch(.708 0 0);--accent: oklch(.269 0 0);--accent-foreground: oklch(.985 0 0);--destructive: oklch(.396 .141 25.723);--border: oklch(.269 0 0);--input: oklch(.269 0 0);--ring: oklch(.439 0 0)}}@layer base{*{border-color:var(--border)}html{scroll-behavior:smooth;text-rendering:optimizeSpeed}body{background-color:var(--background);font-family:var(--font-sans);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html.theme-transition *,html.theme-transition *:before,html.theme-transition *:after{transition-property:background-color,border-color,color,box-shadow;transition-duration:.2s;transition-timing-function:ease}.animate-in{animation-fill-mode:both}@keyframes blob{0%{transform:translateZ(0) scale(1)}33%{transform:translate3d(30px,-50px,0) scale(1.1)}66%{transform:translate3d(-20px,20px,0) scale(.9)}to{transform:translateZ(0) scale(1)}}.animate-blob{animation:blob 8s ease-in-out infinite;will-change:transform;contain:layout style paint}.animation-delay-2000{animation-delay:2s}.animation-delay-4000{animation-delay:4s}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1.5s cubic-bezier(0,0,.2,1) infinite;will-change:transform,opacity}@media(prefers-reduced-motion:reduce){.animate-blob,.animate-ping,.animate-in{animation:none!important}}.line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}img{content-visibility:auto}.copy-btn{position:absolute;top:.5rem;right:.5rem;display:inline-flex;align-items:center;justify-content:center;padding:.4rem;border-radius:.375rem;border:1px solid var(--border);background-color:var(--card);color:var(--muted-foreground);cursor:pointer;opacity:0;transition:opacity .2s,background-color .2s,color .2s}pre:hover .copy-btn{opacity:1}.copy-btn:hover{background-color:var(--accent);color:var(--foreground)}pre code{color:var(--foreground)}}.flow-diagram{margin:2rem 0;padding:1.5rem;border-radius:1rem;border:1px solid var(--border);background:linear-gradient(135deg,var(--card),var(--muted));overflow-x:auto}.flow-diagram-title{text-align:center;font-size:.85rem;font-weight:700;color:var(--foreground);margin-bottom:1.5rem;letter-spacing:-.01em}.seq-diagram{display:flex;flex-direction:column;gap:0;min-width:600px}.seq-actors{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;margin-bottom:.5rem}.seq-actor{text-align:center;padding:.6rem .5rem;border-radius:.5rem;font-size:.75rem;font-weight:700;color:#fff;position:relative}.seq-actor:after{content:"";position:absolute;bottom:-4px;left:50%;width:2px;height:4px;background:inherit}.seq-actor.browser{background:#3b82f6}.seq-actor.sp{background:#22c55e}.seq-actor.idp{background:#7c3aed}.seq-actor-sub{font-size:.6rem;font-weight:400;opacity:.8;display:block}.seq-lifelines{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;position:relative}.seq-lifeline{position:relative;display:flex;flex-direction:column;align-items:center}.seq-lifeline:before{content:"";position:absolute;top:0;left:50%;width:2px;height:100%;background:repeating-linear-gradient(to bottom,var(--border) 0px,var(--border) 4px,transparent 4px,transparent 10px);opacity:.5}.seq-steps{display:flex;flex-direction:column;gap:0;position:relative}.seq-step{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;padding:.6rem 0;position:relative;opacity:0;animation:seq-fade-in .4s ease forwards;transition:background .2s,transform .2s;border-radius:.5rem}.seq-step:hover{background:var(--accent);transform:scale(1.01);z-index:2}.seq-step:nth-child(1){animation-delay:.1s}.seq-step:nth-child(2){animation-delay:.25s}.seq-step:nth-child(3){animation-delay:.4s}.seq-step:nth-child(4){animation-delay:.55s}.seq-step:nth-child(5){animation-delay:.7s}.seq-step:nth-child(6){animation-delay:.85s}.seq-step:nth-child(7){animation-delay:1s}.seq-step:nth-child(8){animation-delay:1.15s}.seq-step:nth-child(9){animation-delay:1.3s}.seq-step:nth-child(10){animation-delay:1.45s}@keyframes seq-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.seq-arrow{position:relative;display:flex;align-items:center;font-size:.7rem;font-weight:600;color:var(--foreground);white-space:nowrap;padding:.25rem .5rem;grid-column:span 2}.seq-arrow:before{content:"";flex:1;height:2px;min-width:30px;margin-right:.5rem;animation:arrow-draw .6s ease forwards}.seq-arrow:after{content:"";width:0;height:0;border-top:5px solid transparent;border-bottom:5px solid transparent;flex-shrink:0}.seq-arrow.right{grid-column:1 / 3}.seq-arrow.right:before{background:var(--arrow-color, #3b82f6)}.seq-arrow.right:after{border-left:8px solid var(--arrow-color, #3b82f6)}.seq-arrow.left{grid-column:1 / 3;direction:rtl}.seq-arrow.left:before{background:var(--arrow-color, #22c55e)}.seq-arrow.left:after{border-right:8px solid var(--arrow-color, #22c55e)}.seq-arrow.full-right{grid-column:1 / 4}.seq-arrow.full-right:before{background:var(--arrow-color, #3b82f6)}.seq-arrow.full-right:after{border-left:8px solid var(--arrow-color, #3b82f6)}.seq-arrow.full-left{grid-column:1 / 4;direction:rtl}.seq-arrow.full-left:before{background:var(--arrow-color, #7c3aed)}.seq-arrow.full-left:after{border-right:8px solid var(--arrow-color, #7c3aed)}.seq-arrow.right-23{grid-column:2 / 4}.seq-arrow.right-23:before{background:var(--arrow-color, #22c55e)}.seq-arrow.right-23:after{border-left:8px solid var(--arrow-color, #22c55e)}.seq-arrow.left-23{grid-column:2 / 4;direction:rtl}.seq-arrow.left-23:before{background:var(--arrow-color, #7c3aed)}.seq-arrow.left-23:after{border-right:8px solid var(--arrow-color, #7c3aed)}@keyframes arrow-draw{0%{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1);transform-origin:left}}.seq-num{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:.6rem;font-weight:800;color:#fff;flex-shrink:0;margin-right:.4rem}.seq-num.blue{background:#3b82f6}.seq-num.green{background:#22c55e}.seq-num.purple{background:#7c3aed}.seq-num.orange{background:#f97316}.seq-action{grid-column:span 1;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;padding:.35rem .6rem;border-radius:.375rem;border:1.5px dashed;animation:action-pulse 2s ease-in-out infinite}@keyframes action-pulse{0%,to{opacity:.7}50%{opacity:1}}.seq-backchannel{grid-column:2 / 4;border:2px dashed #f97316;border-radius:.5rem;padding:.5rem;background:#f973160d;position:relative}.seq-backchannel-label{position:absolute;top:-.5rem;right:.75rem;background:var(--card);padding:0 .4rem;font-size:.55rem;font-weight:800;color:#f97316;text-transform:uppercase;letter-spacing:.05em}.hub-diagram{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1rem 0}.hub-center{padding:1rem 2rem;border-radius:1rem;background:#7c3aed;color:#fff;font-weight:700;font-size:.9rem;text-align:center;box-shadow:0 0 30px #7c3aed4d;animation:hub-glow 3s ease-in-out infinite;position:relative}.hub-center-sub{font-size:.7rem;font-weight:400;opacity:.8;display:block}@keyframes hub-glow{0%,to{box-shadow:0 0 20px #7c3aed33}50%{box-shadow:0 0 40px #7c3aed80}}.hub-user{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;box-shadow:0 0 20px #3b82f64d;animation:user-bounce 2s ease-in-out infinite}@keyframes user-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.hub-arrow-label{font-size:.7rem;font-weight:700;color:var(--muted-foreground);display:flex;align-items:center;gap:.4rem}.hub-arrow-label .arrow-animated{display:inline-block;animation:arrow-bounce 1.5s ease-in-out infinite}@keyframes arrow-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.hub-apps{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;width:100%;max-width:500px}.hub-app{padding:.75rem .5rem;border-radius:.75rem;text-align:center;font-size:.75rem;font-weight:700;color:#fff;transition:transform .3s,box-shadow .3s;cursor:default;opacity:0;animation:hub-app-pop .4s ease forwards}.hub-app:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 8px 25px #0000004d}.hub-app:nth-child(1){background:#22c55e;animation-delay:.6s}.hub-app:nth-child(2){background:#f97316;animation-delay:.75s}.hub-app:nth-child(3){background:#ec4899;animation-delay:.9s}.hub-app:nth-child(4){background:#3b82f6;animation-delay:1.05s}.hub-app-icon{font-size:1.2rem;display:block;margin-bottom:.25rem}.hub-app-sub{font-size:.6rem;font-weight:400;opacity:.8;display:block}@keyframes hub-app-pop{0%{opacity:0;transform:scale(.8) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.hub-connector{font-size:.65rem;color:var(--muted-foreground);display:flex;gap:2rem;align-items:center}.hub-connector span{display:flex;align-items:center;gap:.3rem}.hub-dot-line{width:30px;height:2px;background:repeating-linear-gradient(90deg,var(--border) 0px,var(--border) 4px,transparent 4px,transparent 8px)}.hub-solid-line{width:30px;height:2px;background:var(--muted-foreground)}.jwt-diagram{display:flex;flex-direction:column;gap:1rem;align-items:center}.jwt-parts{display:flex;align-items:stretch;gap:0;width:100%;max-width:600px;border-radius:.75rem;overflow:hidden}.jwt-part{flex:1;padding:.75rem .5rem;text-align:center;color:#fff;cursor:default;transition:flex .4s ease,filter .3s;position:relative}.jwt-part:hover{flex:1.5;filter:brightness(1.15)}.jwt-part.header{background:#ef4444}.jwt-part.payload{background:#a855f7}.jwt-part.signature{background:#3b82f6}.jwt-part-label{font-size:.8rem;font-weight:800;display:block}.jwt-part-code{font-size:.55rem;font-family:var(--font-mono);opacity:.7;display:block;margin-top:.2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jwt-part-desc{font-size:.6rem;opacity:0;max-height:0;overflow:hidden;transition:opacity .3s,max-height .3s;margin-top:0}.jwt-part:hover .jwt-part-desc{opacity:.9;max-height:40px;margin-top:.3rem}.jwt-dot{display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:900;color:var(--foreground);width:24px;flex-shrink:0;background:var(--card)}.jwt-raw{font-family:var(--font-mono);font-size:.65rem;color:var(--muted-foreground);text-align:center;word-break:break-all;max-width:600px}.jwt-raw .h{color:#ef4444}.jwt-raw .p{color:#a855f7}.jwt-raw .s{color:#3b82f6}.vs-cards{display:grid;grid-template-columns:1fr auto 1fr;gap:.75rem;align-items:start}@media(max-width:640px){.vs-cards{grid-template-columns:1fr}.vs-badge{order:-1;justify-self:center}}.vs-card{border-radius:.75rem;overflow:hidden;border:1.5px solid var(--border);transition:transform .3s,box-shadow .3s}.vs-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0003}.vs-card-header{padding:.75rem 1rem;color:#fff;font-size:1.1rem;font-weight:800;text-align:center}.vs-card.saml .vs-card-header{background:#f97316}.vs-card.oidc .vs-card-header{background:#3b82f6}.vs-card-body{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem;background:var(--card)}.vs-row{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--foreground);padding:.3rem 0;border-bottom:1px solid var(--border);transition:background .2s}.vs-row:last-child{border-bottom:none}.vs-row:hover{background:var(--accent);border-radius:.25rem}.vs-row-icon{font-size:1rem;flex-shrink:0;width:22px;text-align:center}.vs-row-value{font-weight:700;margin-left:auto}.vs-badge{width:44px;height:44px;border-radius:50%;background:var(--card);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.8rem;color:var(--foreground);align-self:center;flex-shrink:0}.dtree{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem 0}.dtree-node{padding:.6rem 1.5rem;border-radius:2rem;font-size:.8rem;font-weight:700;text-align:center;color:#fff;transition:transform .3s,box-shadow .3s;cursor:default}.dtree-node:hover{transform:scale(1.05);box-shadow:0 6px 20px #00000040}.dtree-node.question{background:#7c3aed}.dtree-branches{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem;width:100%;max-width:600px}.dtree-branch{display:flex;flex-direction:column;align-items:center;gap:.4rem;text-align:center}.dtree-label{font-size:.7rem;font-weight:600;color:var(--muted-foreground);padding:.3rem .8rem;border-radius:1rem;border:1.5px solid var(--border);background:var(--card);transition:border-color .3s}.dtree-connector{width:2px;height:20px;position:relative}.dtree-connector:after{content:"";position:absolute;bottom:0;left:-3px;border-left:4px solid transparent;border-right:4px solid transparent}.dtree-connector.orange{background:#f97316}.dtree-connector.orange:after{border-top:6px solid #f97316}.dtree-connector.blue{background:#3b82f6}.dtree-connector.blue:after{border-top:6px solid #3b82f6}.dtree-connector.green{background:#22c55e}.dtree-connector.green:after{border-top:6px solid #22c55e}.dtree-answer{padding:.5rem 1rem;border-radius:.5rem;font-size:.75rem;font-weight:700;color:#fff;transition:transform .3s}.dtree-answer:hover{transform:scale(1.08)}.dtree-answer.saml{background:#f97316}.dtree-answer.oidc{background:#3b82f6}.dtree-answer.both{background:#22c55e}.dtree-answer-sub{font-size:.6rem;font-weight:400;opacity:.8;display:block}.pipeline{display:flex;align-items:center;gap:0;overflow-x:auto;padding:.5rem 0}.pipeline-step{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem .8rem;border-radius:.6rem;text-align:center;font-size:.7rem;font-weight:700;color:#fff;min-width:90px;transition:transform .3s,box-shadow .3s;cursor:default;opacity:0;animation:hub-app-pop .4s ease forwards}.pipeline-step:nth-child(odd):nth-of-type(n){animation-delay:calc(var(--i, 0) * .15s)}.pipeline-step:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 6px 20px #0000004d}.pipeline-step-icon{font-size:1.3rem}.pipeline-step-sub{font-size:.55rem;font-weight:400;opacity:.8}.pipeline-arrow{font-size:1.2rem;color:var(--muted-foreground);flex-shrink:0;padding:0 .2rem;animation:arrow-bounce 1.5s ease-in-out infinite}.cycle-diagram{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem 0}.cycle-ring{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem;width:100%;max-width:500px;position:relative}.cycle-ring:before{content:"";position:absolute;inset:20%;border:2px dashed var(--border);border-radius:50%;opacity:.3;animation:cycle-spin 20s linear infinite}@keyframes cycle-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cycle-node{padding:.6rem;border-radius:.6rem;text-align:center;font-size:.7rem;font-weight:700;color:#fff;transition:transform .3s,box-shadow .3s;cursor:default;z-index:1}.cycle-node:hover{transform:scale(1.08);box-shadow:0 6px 20px #0000004d}.cycle-node-icon{font-size:1.1rem;display:block;margin-bottom:.2rem}.cycle-center{grid-column:2;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;color:var(--foreground);padding:.8rem;border-radius:50%;border:2px solid var(--border);background:var(--card);z-index:2}.bar-chart{display:flex;align-items:flex-end;gap:.5rem;height:180px;padding:.5rem 0}.bar-chart-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:.3rem;height:100%;justify-content:flex-end}.bar-chart-bar{width:100%;max-width:50px;min-width:30px;border-radius:.4rem .4rem 0 0;transition:filter .3s;cursor:default;position:relative}.bar-chart-bar:hover{filter:brightness(1.2)}.bar-chart-bar:after{content:attr(data-value);position:absolute;top:-1.2rem;left:50%;transform:translate(-50%);font-size:.6rem;font-weight:700;color:var(--foreground);opacity:0;transition:opacity .2s}.bar-chart-bar:hover:after{opacity:1}.bar-h-5{height:5%}.bar-h-10{height:10%}.bar-h-15{height:15%}.bar-h-20{height:20%}.bar-h-25{height:25%}.bar-h-30{height:30%}.bar-h-35{height:35%}.bar-h-40{height:40%}.bar-h-45{height:45%}.bar-h-50{height:50%}.bar-h-55{height:55%}.bar-h-60{height:60%}.bar-h-65{height:65%}.bar-h-70{height:70%}.bar-h-75{height:75%}.bar-h-80{height:80%}.bar-h-85{height:85%}.bar-h-90{height:90%}.bar-red{background:#ef4444}.bar-orange{background:#f97316}.bar-purple{background:#a855f7}.bar-blue{background:#3b82f6}.bar-green{background:#22c55e}.bar-pink{background:#ec4899}.bar-gray{background:#6b7280}.bar-chart-label{font-size:.6rem;font-weight:600;color:var(--muted-foreground);text-align:center;white-space:nowrap}.layer-diagram{display:flex;flex-direction:column;gap:0;max-width:500px;margin:0 auto}.layer-item{padding:.7rem 1rem;text-align:center;font-size:.75rem;font-weight:700;color:#fff;transition:transform .3s,letter-spacing .3s;cursor:default;position:relative}.layer-item:first-child{border-radius:.6rem .6rem 0 0}.layer-item:last-child{border-radius:0 0 .6rem .6rem}.layer-item:hover{transform:scaleX(1.03);letter-spacing:.05em;z-index:2}.layer-item-sub{font-size:.6rem;font-weight:400;opacity:0;max-height:0;overflow:hidden;transition:opacity .3s,max-height .3s,margin .3s}.layer-item:hover .layer-item-sub{opacity:.85;max-height:30px;margin-top:.2rem}.timeline{display:flex;flex-direction:column;gap:0;padding:.5rem 0 .5rem 1.5rem;border-left:3px solid var(--border);position:relative}.timeline-item{padding:.5rem 0 .5rem 1.2rem;position:relative;transition:background .2s;border-radius:0 .5rem .5rem 0}.timeline-item:hover{background:var(--accent)}.timeline-item:before{content:"";position:absolute;left:-1.85rem;top:.75rem;width:12px;height:12px;border-radius:50%;border:2.5px solid var(--c, var(--foreground));background:var(--card)}.timeline-item-title{font-size:.75rem;font-weight:700;color:var(--foreground)}.timeline-item-desc{font-size:.65rem;color:var(--muted-foreground);margin-top:.1rem}@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-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-gradient-position{syntax: "*"; inherits: false;}@property --tw-gradient-from{syntax: "<color>"; inherits: false; initial-value: #0000;}@property --tw-gradient-via{syntax: "<color>"; inherits: false; initial-value: #0000;}@property --tw-gradient-to{syntax: "<color>"; inherits: false; initial-value: #0000;}@property --tw-gradient-stops{syntax: "*"; inherits: false;}@property --tw-gradient-via-stops{syntax: "*"; inherits: false;}@property --tw-gradient-from-position{syntax: "<length-percentage>"; inherits: false; initial-value: 0%;}@property --tw-gradient-via-position{syntax: "<length-percentage>"; inherits: false; initial-value: 50%;}@property --tw-gradient-to-position{syntax: "<length-percentage>"; inherits: false; initial-value: 100%;}@property --tw-leading{syntax: "*"; inherits: false;}@property --tw-font-weight{syntax: "*"; inherits: false;}@property --tw-tracking{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: 0px;}@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-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-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;}@keyframes ping{75%,to{transform:scale(2);opacity:0}}@keyframes pulse{50%{opacity:.5}}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@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-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-gradient-position: initial;--tw-gradient-from: #0000;--tw-gradient-via: #0000;--tw-gradient-to: #0000;--tw-gradient-stops: initial;--tw-gradient-via-stops: initial;--tw-gradient-from-position: 0%;--tw-gradient-via-position: 50%;--tw-gradient-to-position: 100%;--tw-leading: initial;--tw-font-weight: initial;--tw-tracking: 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: 0px;--tw-ring-offset-color: #fff;--tw-ring-offset-shadow: 0 0 #0000;--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-scale-x: 1;--tw-scale-y: 1;--tw-scale-z: 1;--tw-animation-delay: 0s;--tw-animation-direction: normal;--tw-animation-duration: initial;--tw-animation-fill-mode: none;--tw-animation-iteration-count: 1;--tw-enter-blur: 0;--tw-enter-opacity: 1;--tw-enter-rotate: 0;--tw-enter-scale: 1;--tw-enter-translate-x: 0;--tw-enter-translate-y: 0;--tw-exit-blur: 0;--tw-exit-opacity: 1;--tw-exit-rotate: 0;--tw-exit-scale: 1;--tw-exit-translate-x: 0;--tw-exit-translate-y: 0}}}
