@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
@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-scale-x:1;--tw-scale-y:1;--tw-scale-z:1;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-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}}}@layer theme{:root,:host{--font-sans:var(--font-geist-sans);--font-mono:var(--font-geist-mono);--color-pink-300:#fda5d5;--color-pink-400:#fb64b6;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-sm:24rem;--container-md:28rem;--container-lg:32rem;--container-xl:36rem;--container-2xl:42rem;--container-3xl:48rem;--container-4xl:56rem;--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:calc(1.5/1);--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:calc(2.25/1.875);--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5/2.25);--text-5xl:3rem;--text-5xl--line-height:1;--text-6xl:3.75rem;--text-6xl--line-height:1;--text-8xl:6rem;--text-8xl--line-height:1;--text-9xl:8rem;--text-9xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--tracking-tight:-.025em;--tracking-wider:.05em;--leading-relaxed:1.625;--leading-loose:2;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4,0,.6,1)infinite;--blur-sm:8px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}@supports (color:lab(0% 0 0)){:root,:host{--color-pink-300:lab(77.8308% 38.525 -10.5394);--color-pink-400:lab(64.5597% 64.3615 -12.7988)}}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}.font-mono{font-variant-numeric:tabular-nums}}@layer components;@layer utilities{.pointer-events-none{pointer-events:none}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing)*0)}.top-0{top:calc(var(--spacing)*0)}.right-0{right:calc(var(--spacing)*0)}.right-4{right:calc(var(--spacing)*4)}.bottom-0{bottom:calc(var(--spacing)*0)}.bottom-2{bottom:calc(var(--spacing)*2)}.bottom-4{bottom:calc(var(--spacing)*4)}.-left-\[4000px\]{left:-4000px}.left-0{left:calc(var(--spacing)*0)}.z-0{z-index:0}.z-10{z-index:10}.z-50{z-index:50}.z-\[100\]{z-index:100}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.m-0{margin:calc(var(--spacing)*0)}.mx-1{margin-inline:calc(var(--spacing)*1)}.mx-3{margin-inline:calc(var(--spacing)*3)}.mx-auto{margin-inline:auto}.my-2{margin-block:calc(var(--spacing)*2)}.mt-0\.5{margin-top:calc(var(--spacing)*.5)}.mt-1{margin-top:calc(var(--spacing)*1)}.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-6{margin-top:calc(var(--spacing)*6)}.mt-8{margin-top:calc(var(--spacing)*8)}.mt-12{margin-top:calc(var(--spacing)*12)}.mt-16{margin-top:calc(var(--spacing)*16)}.mt-auto{margin-top:auto}.mr-3{margin-right:calc(var(--spacing)*3)}.mb-0\.5{margin-bottom:calc(var(--spacing)*.5)}.mb-1{margin-bottom:calc(var(--spacing)*1)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-8{margin-bottom:calc(var(--spacing)*8)}.mb-12{margin-bottom:calc(var(--spacing)*12)}.ml-2{margin-left:calc(var(--spacing)*2)}.ml-4{margin-left:calc(var(--spacing)*4)}.block{display:block}.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-2{height:calc(var(--spacing)*2)}.h-3{height:calc(var(--spacing)*3)}.h-3\.5{height:calc(var(--spacing)*3.5)}.h-4{height:calc(var(--spacing)*4)}.h-5{height:calc(var(--spacing)*5)}.h-6{height:calc(var(--spacing)*6)}.h-8{height:calc(var(--spacing)*8)}.h-9{height:calc(var(--spacing)*9)}.h-10{height:calc(var(--spacing)*10)}.h-12{height:calc(var(--spacing)*12)}.h-16{height:calc(var(--spacing)*16)}.h-20{height:calc(var(--spacing)*20)}.h-32{height:calc(var(--spacing)*32)}.h-40{height:calc(var(--spacing)*40)}.h-48{height:calc(var(--spacing)*48)}.h-\[calc\(100vh-72px\)\]{height:calc(100vh - 72px)}.h-full{height:100%}.max-h-\[70vh\]{max-height:70vh}.max-h-\[80vh\]{max-height:80vh}.max-h-\[85vh\]{max-height:85vh}.min-h-0{min-height:calc(var(--spacing)*0)}.min-h-\[40px\]{min-height:40px}.min-h-\[48px\]{min-height:48px}.min-h-\[80px\]{min-height:80px}.min-h-\[200px\]{min-height:200px}.min-h-\[calc\(100vh-72px\)\]{min-height:calc(100vh - 72px)}.w-0{width:calc(var(--spacing)*0)}.w-0\.5{width:calc(var(--spacing)*.5)}.w-1{width:calc(var(--spacing)*1)}.w-1\.5{width:calc(var(--spacing)*1.5)}.w-3{width:calc(var(--spacing)*3)}.w-3\.5{width:calc(var(--spacing)*3.5)}.w-4{width:calc(var(--spacing)*4)}.w-5{width:calc(var(--spacing)*5)}.w-6{width:calc(var(--spacing)*6)}.w-8{width:calc(var(--spacing)*8)}.w-9{width:calc(var(--spacing)*9)}.w-10{width:calc(var(--spacing)*10)}.w-12{width:calc(var(--spacing)*12)}.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-64{width:calc(var(--spacing)*64)}.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-\[180px\]{max-width:180px}.max-w-\[1200px\]{max-width:1200px}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.max-w-sm{max-width:var(--container-sm)}.max-w-xl{max-width:var(--container-xl)}.min-w-0{min-width:calc(var(--spacing)*0)}.min-w-\[100px\]{min-width:100px}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.scale-110{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.scale-125{--tw-scale-x:125%;--tw-scale-y:125%;--tw-scale-z:125%;scale:var(--tw-scale-x)var(--tw-scale-y)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-crosshair{cursor:crosshair}.cursor-ew-resize{cursor:ew-resize}.cursor-move{cursor:move}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.resize{resize:both}.resize-none{resize:none}.list-disc{list-style-type:disc}.appearance-none{appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.gap-0\.5{gap:calc(var(--spacing)*.5)}.gap-1{gap:calc(var(--spacing)*1)}.gap-1\.5{gap:calc(var(--spacing)*1.5)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.gap-6{gap:calc(var(--spacing)*6)}.gap-8{gap:calc(var(--spacing)*8)}:where(.space-y-1>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*1)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*1)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*6)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*6)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-8>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*8)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*8)*calc(1 - var(--tw-space-y-reverse)))}.gap-x-4{column-gap:calc(var(--spacing)*4)}.gap-y-2{row-gap:calc(var(--spacing)*2)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-3xl{border-radius:var(--radius-3xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-r{border-right-style:var(--tw-border-style);border-right-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-\[var\(--border\)\]{border-color:var(--border)}.border-\[var\(--error\)\]\/30{border-color:var(--error)}@supports (color:color-mix(in lab, red, red)){.border-\[var\(--error\)\]\/30{border-color:color-mix(in oklab,var(--error)30%,transparent)}}.border-\[var\(--primary\)\],.border-\[var\(--primary\)\]\/30{border-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.border-\[var\(--primary\)\]\/30{border-color:color-mix(in oklab,var(--primary)30%,transparent)}}.border-\[var\(--primary\)\]\/40{border-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.border-\[var\(--primary\)\]\/40{border-color:color-mix(in oklab,var(--primary)40%,transparent)}}.border-\[var\(--success\)\],.border-\[var\(--success\)\]\/30{border-color:var(--success)}@supports (color:color-mix(in lab, red, red)){.border-\[var\(--success\)\]\/30{border-color:color-mix(in oklab,var(--success)30%,transparent)}}.border-\[var\(--warning\)\]{border-color:var(--warning)}.border-transparent{border-color:#0000}.border-white\/30{border-color:#ffffff4d}@supports (color:color-mix(in lab, red, red)){.border-white\/30{border-color:color-mix(in oklab,var(--color-white)30%,transparent)}}.border-t-white{border-top-color:var(--color-white)}.border-b-\[var\(--primary\)\]{border-bottom-color:var(--primary)}.border-l-\[var\(--primary\)\]{border-left-color:var(--primary)}.bg-\[var\(--background\)\]{background-color:var(--background)}.bg-\[var\(--border\)\]{background-color:var(--border)}.bg-\[var\(--error\)\]\/20{background-color:var(--error)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--error\)\]\/20{background-color:color-mix(in oklab,var(--error)20%,transparent)}}.bg-\[var\(--primary\)\],.bg-\[var\(--primary\)\]\/5{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--primary\)\]\/5{background-color:color-mix(in oklab,var(--primary)5%,transparent)}}.bg-\[var\(--primary\)\]\/10{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--primary\)\]\/10{background-color:color-mix(in oklab,var(--primary)10%,transparent)}}.bg-\[var\(--primary\)\]\/20{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--primary\)\]\/20{background-color:color-mix(in oklab,var(--primary)20%,transparent)}}.bg-\[var\(--primary\)\]\/50{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--primary\)\]\/50{background-color:color-mix(in oklab,var(--primary)50%,transparent)}}.bg-\[var\(--success\)\],.bg-\[var\(--success\)\]\/5{background-color:var(--success)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--success\)\]\/5{background-color:color-mix(in oklab,var(--success)5%,transparent)}}.bg-\[var\(--success\)\]\/10{background-color:var(--success)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--success\)\]\/10{background-color:color-mix(in oklab,var(--success)10%,transparent)}}.bg-\[var\(--success\)\]\/20{background-color:var(--success)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--success\)\]\/20{background-color:color-mix(in oklab,var(--success)20%,transparent)}}.bg-\[var\(--surface\)\],.bg-\[var\(--surface\)\]\/80{background-color:var(--surface)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--surface\)\]\/80{background-color:color-mix(in oklab,var(--surface)80%,transparent)}}.bg-\[var\(--surface-active\)\]{background-color:var(--surface-active)}.bg-\[var\(--surface-hover\)\]{background-color:var(--surface-hover)}.bg-\[var\(--warning\)\],.bg-\[var\(--warning\)\]\/20{background-color:var(--warning)}@supports (color:color-mix(in lab, red, red)){.bg-\[var\(--warning\)\]\/20{background-color:color-mix(in oklab,var(--warning)20%,transparent)}}.bg-black\/60{background-color:#0009}@supports (color:color-mix(in lab, red, red)){.bg-black\/60{background-color:color-mix(in oklab,var(--color-black)60%,transparent)}}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-\[var\(--primary\)\]{--tw-gradient-from:var(--primary);--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-\[var\(--success\)\]\/20{--tw-gradient-from:var(--success)}@supports (color:color-mix(in lab, red, red)){.from-\[var\(--success\)\]\/20{--tw-gradient-from:color-mix(in oklab,var(--success)20%,transparent)}}.from-\[var\(--success\)\]\/20{--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-\[var\(--primary\)\]\/20{--tw-gradient-to:var(--primary)}@supports (color:color-mix(in lab, red, red)){.to-\[var\(--primary\)\]\/20{--tw-gradient-to:color-mix(in oklab,var(--primary)20%,transparent)}}.to-\[var\(--primary\)\]\/20{--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-\[var\(--success\)\]{--tw-gradient-to:var(--success);--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))}.fill-current{fill:currentColor}.p-0\.5{padding:calc(var(--spacing)*.5)}.p-1{padding:calc(var(--spacing)*1)}.p-1\.5{padding:calc(var(--spacing)*1.5)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-6{padding:calc(var(--spacing)*6)}.p-8{padding:calc(var(--spacing)*8)}.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-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-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)}.pt-4{padding-top:calc(var(--spacing)*4)}.pt-\[72px\]{padding-top:72px}.pr-2{padding-right:calc(var(--spacing)*2)}.pr-4{padding-right:calc(var(--spacing)*4)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pb-4{padding-bottom:calc(var(--spacing)*4)}.pb-\[120px\]{padding-bottom:120px}.pl-6{padding-left:calc(var(--spacing)*6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:var(--font-geist-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-8xl{font-size:var(--text-8xl);line-height:var(--tw-leading,var(--text-8xl--line-height))}.text-9xl{font-size:var(--text-9xl);line-height:var(--tw-leading,var(--text-9xl--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}.leading-loose{--tw-leading:var(--leading-loose);line-height:var(--leading-loose)}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-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)}.break-words{overflow-wrap:break-word}.whitespace-nowrap{white-space:nowrap}.text-\[var\(--error\)\]{color:var(--error)}.text-\[var\(--primary\)\]{color:var(--primary)}.text-\[var\(--success\)\]{color:var(--success)}.text-\[var\(--text-muted\)\]{color:var(--text-muted)}.text-\[var\(--text-primary\)\]{color:var(--text-primary)}.text-\[var\(--text-secondary\)\]{color:var(--text-secondary)}.text-\[var\(--warning\)\]{color:var(--warning)}.text-black{color:var(--color-black)}.text-pink-400{color:var(--color-pink-400)}.text-white{color:var(--color-white)}.text-white\/80{color:#fffc}@supports (color:color-mix(in lab, red, red)){.text-white\/80{color:color-mix(in oklab,var(--color-white)80%,transparent)}}.uppercase{text-transform:uppercase}.italic{font-style:italic}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.accent-\[var\(--primary\)\]{accent-color:var(--primary)}.opacity-0{opacity:0}.opacity-20{opacity:.2}.opacity-30{opacity:.3}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.shadow-\[var\(--success\)\]\/20{--tw-shadow-alpha:20%;--tw-shadow:var(--success);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-\[var\(--primary-glow\)\]{--tw-shadow:var(--primary-glow);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-1{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-2{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.ring-\[var\(--primary\)\]\/30{--tw-ring-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.ring-\[var\(--primary\)\]\/30{--tw-ring-color:color-mix(in oklab,var(--primary)30%,transparent)}}.ring-\[var\(--success\)\]{--tw-ring-color:var(--success)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.backdrop-blur-sm{--tw-backdrop-blur:blur(var(--blur-sm));-webkit-backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,)var(--tw-backdrop-brightness,)var(--tw-backdrop-contrast,)var(--tw-backdrop-grayscale,)var(--tw-backdrop-hue-rotate,)var(--tw-backdrop-invert,)var(--tw-backdrop-opacity,)var(--tw-backdrop-saturate,)var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-transform{transition-property:transform,translate,scale,rotate;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-150{--tw-duration:.15s;transition-duration:.15s}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.duration-700{--tw-duration:.7s;transition-duration:.7s}.select-none{-webkit-user-select:none;user-select:none}.ring-inset{--tw-ring-inset:inset}@media (hover:hover){.group-hover\:opacity-100:is(:where(.group):hover *){opacity:1}.group-hover\/left\:bg-\[var\(--primary\)\]:is(:where(.group\/left):hover *){background-color:var(--primary)}.group-hover\/tab\:opacity-100:is(:where(.group\/tab):hover *){opacity:1}}.last\:border-0:last-child{border-style:var(--tw-border-style);border-width:0}@media (hover:hover){.hover\:scale-110:hover{--tw-scale-x:110%;--tw-scale-y:110%;--tw-scale-z:110%;scale:var(--tw-scale-x)var(--tw-scale-y)}.hover\:border-\[var\(--border-hover\)\]:hover{border-color:var(--border-hover)}.hover\:border-\[var\(--primary\)\]:hover{border-color:var(--primary)}.hover\:bg-\[var\(--error\)\]\/20:hover{background-color:var(--error)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-\[var\(--error\)\]\/20:hover{background-color:color-mix(in oklab,var(--error)20%,transparent)}}.hover\:bg-\[var\(--primary\)\]:hover,.hover\:bg-\[var\(--primary\)\]\/20:hover{background-color:var(--primary)}@supports (color:color-mix(in lab, red, red)){.hover\:bg-\[var\(--primary\)\]\/20:hover{background-color:color-mix(in oklab,var(--primary)20%,transparent)}}.hover\:bg-\[var\(--primary-hover\)\]:hover{background-color:var(--primary-hover)}.hover\:bg-\[var\(--surface-active\)\]:hover{background-color:var(--surface-active)}.hover\:bg-\[var\(--surface-hover\)\]:hover{background-color:var(--surface-hover)}.hover\:text-\[var\(--primary\)\]:hover{color:var(--primary)}.hover\:text-\[var\(--text\)\]:hover{color:var(--text)}.hover\:text-\[var\(--text-secondary\)\]:hover{color:var(--text-secondary)}.hover\:text-pink-300:hover{color:var(--color-pink-300)}.hover\:text-white:hover{color:var(--color-white)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-90:hover{opacity:.9}}.focus\:border-\[var\(--primary\)\]:focus{border-color:var(--primary)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.active\:bg-\[var\(--primary\)\]:active{background-color:var(--primary)}@media (min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:48rem){.md\:w-16{width:calc(var(--spacing)*16)}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-10{grid-template-columns:repeat(10,minmax(0,1fr))}.md\:text-6xl{font-size:var(--text-6xl);line-height:var(--tw-leading,var(--text-6xl--line-height))}}@media (min-width:64rem){.lg\:p-12{padding:calc(var(--spacing)*12)}}}:root{--background:#0a0a0a;--foreground:#f5f5f5;--surface:#141414;--surface-hover:#1a1a1a;--surface-active:#222;--border:#2a2a2a;--border-hover:#3a3a3a;--primary:#6366f1;--primary-hover:#818cf8;--primary-glow:#6366f14d;--success:#22c55e;--error:#ef4444;--warning:#f59e0b;--text-primary:#f5f5f5;--text-secondary:#a1a1aa;--text-muted:#71717a;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}*{box-sizing:border-box}body{background:var(--background);color:var(--foreground);font-family:var(--font-sans),system-ui,-apple-system,sans-serif;min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border-hover)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 0 20px var(--primary-glow)}.btn-secondary{background:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-hover);border-color:var(--border-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--surface);color:var(--text-primary)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.tab{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md)var(--radius-md)0 0;color:var(--text-secondary);cursor:pointer;border-bottom:none;align-items:center;gap:8px;padding:8px 16px;font-size:13px;transition:all .15s;display:flex}.tab:hover{background:var(--surface-hover);color:var(--text-primary)}.tab.active{background:var(--surface-active);color:var(--text-primary);border-color:var(--primary);border-bottom:2px solid var(--primary)}.input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);width:100%;padding:10px 14px;font-size:14px;transition:all .15s}.input:hover{border-color:var(--border-hover)}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-glow);outline:none}.digit{font-family:var(--font-mono),ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;text-align:center;font-variant-numeric:tabular-nums;-moz-font-feature-settings:"tnum";-webkit-font-feature-settings:"tnum";font-feature-settings:"tnum";width:1ch;font-size:18px;display:inline-block}.digit-correct{color:var(--success)}.digit-incorrect{color:var(--error)}.digit-current{background:var(--primary);color:#fff;border-radius:4px;padding:2px 4px}.kbd{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);min-width:24px;font-family:var(--font-mono);color:var(--text-secondary);justify-content:center;align-items:center;padding:4px 8px;font-size:12px;display:inline-flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{50%{opacity:.5}}.animate-fade-in{animation:.3s fadeIn}.animate-slide-up{animation:.3s slideUp}.animate-pulse{animation:2s infinite pulse}@keyframes float{0%{transform:translateY(0)}50%{transform:translateY(-15px)}to{transform:translateY(0)}}.animate-float{animation:8s ease-in-out infinite float}.landing{min-height:100vh;position:relative;overflow-x:hidden}.landing:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(90deg,#0000 calc(50% - 600px),#ffffff4d calc(50% - 600px),#0000 calc(50% - 599px)),linear-gradient(90deg,#0000 calc(50% + 600px),#ffffff4d calc(50% + 600px),#0000 calc(50% + 601px));position:absolute;inset:0}.landing-h1{letter-spacing:-.035em;color:var(--foreground);margin:0 0 28px;font-size:clamp(3.2rem,8vw,6.5rem);font-weight:800;line-height:.95}.landing-h1-accent{background:linear-gradient(135deg,var(--primary)0%,#06b6d4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-h2{letter-spacing:-.03em;color:var(--foreground);margin:0 0 48px;font-size:clamp(2rem,5vw,3.8rem);font-weight:700;line-height:1}.landing-h2-centered{letter-spacing:-.02em;color:var(--foreground);text-align:center;margin:0 0 16px;font-size:clamp(1.8rem,4vw,3rem);font-weight:700;line-height:1.05}.landing-h3{letter-spacing:-.01em;color:var(--foreground);margin:0 0 8px;font-size:1.15rem;font-weight:600}.landing-overline{letter-spacing:.08em;text-transform:uppercase;color:var(--primary);margin:0 0 16px;font-size:.8rem;font-weight:500}.landing-body{color:var(--text-secondary);max-width:440px;margin:0;font-size:1rem;line-height:1.65}.landing-body-centered{color:var(--text-muted);text-align:center;max-width:500px;margin:0 auto;font-size:.95rem;line-height:1.6}.landing-body-sm{color:var(--text-muted);margin:0;font-size:.875rem;line-height:1.6}.landing-container{max-width:1200px;margin:0 auto;padding:0 32px}.landing-section{padding:120px 0;position:relative}.landing-section-flush{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:0}.landing-section-alt{background:var(--surface)}.landing-hero{padding:80px 0 60px;position:relative}.landing-hero:before{content:"";pointer-events:none;background:radial-gradient(circle,#6366f112 0%,#06b6d408 40%,#0000 70%);width:800px;height:800px;position:absolute;top:-72px;right:-10%}.landing-hero:after{content:"";pointer-events:none;z-index:0;position:absolute;inset:0}.landing-hero-particles{z-index:1;height:1200px;position:absolute;top:0;left:0;right:0;overflow:hidden}.floating-particles-canvas{pointer-events:none;position:absolute;inset:0}.landing-hero-content{z-index:2;grid-template-columns:1fr 1fr;align-items:center;gap:48px;max-width:1200px;margin:0 auto;padding:0 32px;display:grid;position:relative}.landing-hero-text{text-align:left}.landing-hero-actions{gap:16px;margin-top:36px;display:flex}.landing-hero-visual{justify-content:center;align-items:center;display:flex;position:relative}.hero-scene-container{aspect-ratio:1;border-radius:24px;width:100%;max-width:560px;position:relative;overflow:hidden}.hero-scene-fallback{background:radial-gradient(#6366f10f 0%,#0000 70%)}.landing-btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;align-items:center;gap:8px;padding:14px 28px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .25s;display:inline-flex}.landing-btn-primary:hover{background:var(--primary-hover);box-shadow:0 0 30px var(--primary-glow);transform:translateY(-1px)}.landing-btn-lg{padding:18px 36px;font-size:1rem}.landing-btn-google{color:#1f1f1f;cursor:pointer;background:#fff;border:1px solid #dadce0;border-radius:10px;align-items:center;gap:10px;padding:14px 28px;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .25s;display:inline-flex}.landing-btn-google:hover{background:#f8f9fa;transform:translateY(-1px);box-shadow:0 1px 3px #00000026}.digit-stream{border-top:1px solid var(--border);background:var(--surface);max-width:1200px;margin:0 auto;padding:14px 0}.digit-stream-inner{max-width:1200px;margin:0 auto;overflow:hidden}.digit-stream-track{white-space:nowrap;font-family:var(--font-mono),ui-monospace,monospace;color:var(--text-muted);opacity:.35;letter-spacing:.15em;font-variant-numeric:tabular-nums;gap:0;font-size:.85rem;animation:30s linear infinite digitScroll;display:flex}.digit-stream-track span{flex-shrink:0}@keyframes digitScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.metrics-strip{position:relative;overflow:hidden}.metrics-glow{pointer-events:none;transition:background .3s;position:absolute;inset:0}.metrics-inner{grid-template-columns:repeat(4,1fr);gap:32px;max-width:1200px;margin:0 auto;padding:56px 32px;display:grid;position:relative}.metric{flex-direction:column;gap:6px;display:flex}.metric-value{letter-spacing:-.03em;color:var(--foreground);font-variant-numeric:tabular-nums;font-size:clamp(2rem,4vw,3rem);font-weight:800}.metric-pct{color:var(--primary);font-size:.6em}.metric-label{color:var(--text-muted);font-size:.85rem}.carousel-wrap{position:relative}.carousel-controls{z-index:2;justify-content:flex-end;gap:8px;margin-bottom:20px;display:flex;position:relative}.carousel-arrow{background:var(--surface);border:1px solid var(--border);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex}.carousel-arrow:hover:not(:disabled){background:var(--surface-hover);border-color:var(--border-hover);color:var(--foreground)}.carousel-arrow:disabled{opacity:.3;cursor:default}.carousel-track{scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:16px;margin:-12px -32px 0;padding:12px 32px 8px;display:flex;overflow-x:auto}.carousel-track::-webkit-scrollbar{display:none}.carousel-card{scroll-snap-align:start;background:var(--surface);border:1px solid var(--border);border-radius:16px;flex-direction:column;flex:0 0 280px;gap:8px;padding:28px;transition:border-color .2s,transform .2s;display:flex}.carousel-card:hover{border-color:var(--border-hover);transform:translateY(-2px)}.carousel-symbol{font-family:var(--font-mono),ui-monospace,monospace;font-variant-numeric:tabular-nums;font-size:2.5rem;font-weight:700;line-height:1}.carousel-name{color:var(--foreground);margin:4px 0 0;font-size:1rem;font-weight:600}.carousel-digits{font-family:var(--font-mono),ui-monospace,monospace;color:var(--text-muted);letter-spacing:.08em;font-variant-numeric:tabular-nums;font-size:.75rem}.carousel-desc{color:var(--text-muted);margin-top:auto;font-size:.8rem;line-height:1.5}.tilt-card{will-change:transform;position:relative}.tilt-card-glow{pointer-events:none;z-index:1;border-radius:20px;transition:opacity .3s;position:absolute;inset:0}.landing-bento{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.landing-bento-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;flex-direction:column;gap:24px;padding:32px;transition:border-color .2s,transform .4s cubic-bezier(.16,1,.3,1);display:flex;position:relative;overflow:hidden}.landing-bento-card:hover{border-color:var(--border-hover);transform:scale(1.02)}.landing-bento-wide{grid-column:span 2}.landing-bento-card-inner{z-index:2;flex-shrink:0;position:relative}.bento-expand-btn{border:1px solid var(--border);width:32px;height:32px;color:var(--text-muted);cursor:pointer;opacity:.6;z-index:3;background:#ffffff0d;border-radius:8px;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:16px;right:16px}.tilt-card:hover .bento-expand-btn{opacity:1}.landing-bento-card:hover .bento-expand-btn{background:var(--primary);color:#fff;border-color:var(--primary);opacity:1}.bento-expand-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.bento-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0000001a;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.bento-modal{background:var(--surface);border:1px solid var(--border);z-index:1001;border-radius:24px;flex-direction:column;width:95vw;max-width:1400px;max-height:95vh;margin:auto;animation:.3s slideUp;display:flex;position:relative;overflow-y:auto}.bento-modal-close{border:1px solid var(--border);width:36px;height:36px;color:var(--text-muted);cursor:pointer;z-index:2;background:0 0;border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:absolute;top:16px;right:16px}.bento-modal-close:hover{background:var(--surface-hover);color:var(--foreground)}.bento-modal-body{flex:1;padding:48px 40px 32px}.bento-modal-title{letter-spacing:-.02em;color:var(--foreground);margin:0 0 16px;font-size:2.2rem;font-weight:700}.bento-modal-desc{color:var(--text-secondary);margin:0 0 16px;font-size:1.15rem;line-height:1.65}.bento-modal-details{color:var(--text-muted);white-space:pre-wrap;margin:0;font-size:1rem;line-height:1.65}.bento-modal-footer{border-top:1px solid var(--border);gap:12px;padding:24px 40px;display:flex}.scroll-reveal{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(30px)}.scroll-reveal-visible{opacity:1;transform:translateY(0)}.landing-mockup{z-index:2;flex-direction:column;flex:1;min-height:0;display:flex;position:relative}.landing-mockup-panels{border:1px solid var(--border);background:#0d0d0d;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0000004d,0 0 0 1px #6366f10d}.landing-mockup-tab-bar{border-bottom:1px solid var(--border);gap:0;display:flex}.landing-mockup-tab{color:var(--text-muted);border-right:1px solid var(--border);padding:8px 16px;font-size:.75rem}.landing-mockup-tab.active{color:var(--text-primary);background:var(--surface);border-bottom:2px solid var(--primary)}.landing-mockup-body{padding:20px}.landing-mockup-digits{font-family:var(--font-mono),ui-monospace,monospace;letter-spacing:.12em;color:var(--text-muted);font-variant-numeric:tabular-nums;font-size:1.3rem}.landing-mockup-digits .d-hl{color:var(--primary)}.landing-mockup-major{flex-direction:column;gap:12px;display:flex}.landing-mockup-mapping{font-family:var(--font-mono),ui-monospace,monospace;color:var(--text-muted);flex-wrap:wrap;gap:8px;font-size:.75rem;display:flex}.landing-mockup-mapping span{border:1px solid var(--border);background:#0d0d0d;border-radius:6px;padding:4px 10px}.landing-mockup-word{color:var(--primary);letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.landing-mockup-stats{gap:16px;display:flex}.landing-mockup-stat{border:1px solid var(--border);background:#0d0d0d;border-radius:12px;flex-direction:column;flex:1;align-items:center;padding:16px 8px;display:flex}.stat-value{color:var(--foreground);font-variant-numeric:tabular-nums;font-size:1.5rem;font-weight:700}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:4px;font-size:.7rem}.landing-mockup-keys{grid-template-columns:auto 1fr;align-items:center;gap:8px 12px;display:grid}.landing-mockup-keys kbd{border:1px solid var(--border);min-width:36px;font-family:var(--font-mono),ui-monospace,monospace;color:var(--text-primary);background:#0d0d0d;border-radius:8px;justify-content:center;align-items:center;padding:6px 12px;font-size:.8rem;display:inline-flex}.key-label{color:var(--text-muted);font-size:.8rem}.landing-mockup-constants{flex-wrap:wrap;gap:10px;display:flex}.landing-const-chip{border:1px solid var(--border);background:#0d0d0d;border-radius:10px;align-items:center;gap:10px;padding:10px 16px;transition:border-color .15s;display:flex}.landing-const-chip:hover{border-color:var(--border-hover)}.const-sym{font-family:var(--font-mono),ui-monospace,monospace;color:var(--primary);font-size:1.1rem;font-weight:600}.const-name{color:var(--text-secondary);font-size:.8rem}.landing-const-chip-add{border-style:dashed}.landing-steps{grid-template-columns:repeat(3,1fr);gap:48px;display:grid}.landing-step{text-align:left}.landing-step-number{background:linear-gradient(135deg,var(--primary)0%,#06b6d4 100%);-webkit-text-fill-color:transparent;opacity:.8;letter-spacing:-.04em;-webkit-background-clip:text;background-clip:text;margin-left:-.05em;font-size:3.5rem;font-weight:800;line-height:1}.landing-split{grid-template-columns:1fr 1fr;align-items:center;gap:80px;display:grid}.landing-split-reverse{direction:rtl}.landing-split-reverse>*{direction:ltr}.landing-split-text{text-align:left}.landing-split-detail{grid-template-columns:repeat(3,auto);gap:8px 24px;margin-top:28px;display:grid}.landing-detail-row{display:contents}.detail-num{font-family:var(--font-mono),ui-monospace,monospace;color:var(--primary);font-size:1.1rem;font-weight:700}.detail-arrow{color:var(--text-muted);font-size:.9rem}.detail-sound{font-family:var(--font-mono),ui-monospace,monospace;color:var(--text-secondary);font-size:.9rem}.landing-feature-list{flex-direction:column;gap:10px;margin:24px 0 0;padding:0;list-style:none;display:flex}.landing-feature-list li{color:var(--text-secondary);padding-left:20px;font-size:.9rem;position:relative}.landing-feature-list li:before{content:"";background:var(--primary);border-radius:50%;width:6px;height:6px;position:absolute;top:8px;left:0}.landing-split-visual{justify-content:center;align-items:center;display:flex}.landing-float-mockup{border:1px solid var(--border);background:#0d0d0d;border-radius:16px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px #0006,0 0 0 1px #6366f10d,0 0 40px #6366f10a}.float-mockup-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:12px 16px;display:flex}.float-mockup-dot{background:var(--border);border-radius:50%;width:10px;height:10px}.float-mockup-title{color:var(--text-muted);margin-left:8px;font-size:.75rem}.float-mockup-content{flex-direction:column;gap:16px;padding:24px;display:flex}.float-mockup-input,.float-mockup-output,.float-mockup-result{flex-direction:column;gap:4px;display:flex}.fmi-label,.fmo-label,.fmr-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-size:.65rem}.fmi-value,.fmo-value{font-family:var(--font-mono),ui-monospace,monospace;color:var(--text-secondary);letter-spacing:.06em;font-variant-numeric:tabular-nums;font-size:1.05rem}.fmr-value{color:var(--primary);font-size:1.4rem;font-weight:700}.float-practice-digits{font-family:var(--font-mono),ui-monospace,monospace;letter-spacing:.08em;font-variant-numeric:tabular-nums;flex-wrap:wrap;gap:2px;font-size:1.6rem;display:flex}.fp-correct{color:var(--success)}.fp-wrong{color:var(--error)}.fp-cursor{background:var(--primary);align-self:center;width:2px;height:1.2em;animation:1s infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.float-practice-stats{color:var(--text-muted);font-size:.75rem;font-family:var(--font-mono),ui-monospace,monospace;font-variant-numeric:tabular-nums;gap:16px;display:flex}.float-progress-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.float-progress-item{flex-direction:column;gap:2px;display:flex}.fpi-val{color:var(--foreground);font-variant-numeric:tabular-nums;font-size:1.4rem;font-weight:700}.fpi-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-size:.65rem}.float-progress-bar-group{flex-direction:column;gap:6px;display:flex}.float-bar{background:linear-gradient(90deg,var(--primary)0%,#06b6d4 100%);opacity:.6;border-radius:2px;height:4px}.landing-grid-section{padding:80px 0 0;position:relative;overflow:hidden}.landing-grid-text{z-index:2;text-align:center;padding:0 32px;position:relative}.particle-grid-wrap{width:100%;height:100%;position:relative}.particle-grid-fallback{background:radial-gradient(#6366f10a 0%,#0000 70%)}.mouse-glow-section{position:relative;overflow:hidden}.mouse-glow-bg{pointer-events:none;transition:background .4s;position:absolute;inset:0}.landing-toolkit-grid{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.toolkit-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;transition:border-color .25s,transform .25s,box-shadow .25s;position:relative;overflow:hidden}.toolkit-card:hover{border-color:var(--border-hover);transform:translateY(-4px);box-shadow:0 8px 24px #00000040,0 0 0 1px #6366f114}.toolkit-card:before{content:"";opacity:0;pointer-events:none;background:radial-gradient(circle at 50% 0,#6366f10f,#0000 60%);border-radius:14px;transition:opacity .3s;position:absolute;inset:0}.toolkit-card:hover:before{opacity:1}.toolkit-dot{border-radius:50%;width:8px;height:8px;margin-bottom:12px}.toolkit-title{color:var(--foreground);margin:0 0 4px;font-size:.9rem;font-weight:600}.toolkit-desc{color:var(--text-muted);margin:0;font-size:.78rem;line-height:1.5}.landing-faq-container{grid-template-columns:1fr 1.5fr;align-items:start;gap:64px;display:grid}.landing-faq-header{position:sticky;top:100px}.faq-list{flex-direction:column;gap:0;display:flex}.faq-item{text-align:left;border:none;border-bottom:1px solid var(--border);cursor:pointer;width:100%;color:var(--foreground);background:0 0;padding:20px 0;display:block}.faq-q{justify-content:space-between;align-items:center;font-size:1rem;font-weight:500;display:flex}.faq-chevron{width:18px;height:18px;color:var(--text-muted);flex-shrink:0;transition:transform .25s}.faq-open .faq-chevron{transform:rotate(180deg)}.faq-a-wrap{max-height:0;transition:max-height .3s;overflow:hidden}.faq-open .faq-a-wrap{max-height:200px}.faq-a{color:var(--text-secondary);margin:0;padding-top:12px;font-size:.875rem;line-height:1.65}.landing-final-cta{border-top:1px solid var(--border);background:linear-gradient(160deg,#6366f10f 0%,#06b6d40a 50%,#0000 100%)}.landing-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:32px;font-size:.8rem}@media (max-width:1024px){.landing-bento{grid-template-columns:repeat(2,1fr)}.landing-bento-wide{grid-column:span 2}.landing-toolkit-grid{grid-template-columns:repeat(3,1fr)}.landing-faq-container{grid-template-columns:1fr;gap:32px}.landing-faq-header{position:static}.metrics-inner{grid-template-columns:repeat(2,1fr);gap:24px;padding:40px 32px}}@media (max-width:768px){.btn{padding:12px 16px;font-size:15px}.card{padding:16px}.digit{letter-spacing:1px;font-size:16px}.landing-hero-content{grid-template-columns:1fr;gap:40px;padding:0 20px}.landing-hero-visual{order:-1;max-height:320px}.hero-scene-container{max-width:340px;margin:0 auto}.landing-bento{grid-template-columns:1fr}.landing-bento-wide{grid-column:span 1}.landing-steps,.landing-split{grid-template-columns:1fr;gap:40px}.landing-split-reverse{direction:ltr}.landing-section{padding:80px 0}.landing-container{padding:0 20px}.landing-mockup-stats{flex-direction:column}.landing-toolkit-grid{grid-template-columns:repeat(2,1fr)}.metrics-inner{grid-template-columns:1fr 1fr;padding:32px 20px}.carousel-card{flex:0 0 240px}.float-practice-digits{font-size:1.2rem}.particle-grid-wrap{height:240px}.landing-split-detail{grid-template-columns:repeat(3,auto);gap:6px 16px}}@property --tw-scale-x{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-y{syntax:"*";inherits:false;initial-value:1}@property --tw-scale-z{syntax:"*";inherits:false;initial-value:1}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-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:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-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}@keyframes spin{to{transform:rotate(360deg)}}
