*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.inset-y-0{top:0;bottom:0}.-bottom-12{bottom:-3rem}.-left-12{left:-3rem}.-right-12{right:-3rem}.-top-12{top:-3rem}.bottom-0{bottom:0}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-2{right:.5rem}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\.5{top:.375rem}.top-1\/2{top:50%}.top-2{top:.5rem}.top-3\.5{top:.875rem}.top-4{top:1rem}.top-\[1px\]{top:1px}.top-\[50\%\]{top:50%}.top-\[60\%\]{top:60%}.top-full{top:100%}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[1\]{z-index:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-3\.5{margin-left:.875rem;margin-right:.875rem}.mx-auto{margin-left:auto;margin-right:auto}.my-0\.5{margin-top:.125rem;margin-bottom:.125rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.-ml-4{margin-left:-1rem}.-mt-4{margin-top:-1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-24{margin-top:6rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-auto{margin-top:auto}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1/1}.aspect-video{aspect-ratio:16/9}.size-4{width:1rem;height:1rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-navigation-menu-viewport-height\)\]{height:var(--radix-navigation-menu-viewport-height)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-svh{height:100svh}.max-h-96{max-height:24rem}.max-h-\[300px\]{max-height:300px}.max-h-screen{max-height:100vh}.min-h-0{min-height:0}.min-h-\[80px\]{min-height:80px}.min-h-svh{min-height:100svh}.w-0{width:0}.w-1{width:.25rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[--sidebar-width\]{width:var(--sidebar-width)}.w-\[100px\]{width:100px}.w-\[1px\]{width:1px}.w-auto{width:auto}.w-full{width:100%}.w-max{width:max-content}.w-px{width:1px}.min-w-0{min-width:0}.min-w-10{min-width:2.5rem}.min-w-11{min-width:2.75rem}.min-w-5{min-width:1.25rem}.min-w-9{min-width:2.25rem}.min-w-\[12rem\]{min-width:12rem}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-\[--skeleton-width\]{max-width:var(--skeleton-width)}.max-w-lg{max-width:32rem}.max-w-max{max-width:max-content}.max-w-none{max-width:none}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.grow-0{flex-grow:0}.basis-full{flex-basis:100%}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-x-px{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-px{--tw-translate-x:-1px}.-translate-y-1\/2{--tw-translate-y:-50%}.-translate-y-1\/2,.translate-x-\[-50\%\]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-\[-50\%\]{--tw-translate-x:-50%}.translate-x-px{--tw-translate-x:1px}.translate-x-px,.translate-y-\[-50\%\]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y:-50%}.rotate-45{--tw-rotate:45deg}.rotate-45,.rotate-90{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate:90deg}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{user-select:none}.list-none{list-style-type:none}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.rounded-\[2px\]{border-radius:2px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.rounded-tl-sm{border-top-left-radius:calc(var(--radius) - 4px)}.border{border-width:1px}.border-2{border-width:2px}.border-\[1\.5px\]{border-width:1.5px}.border-y{border-top-width:1px}.border-b,.border-y{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[--color-border\]{border-color:var(--color-border)}.border-border\/50{border-color:hsl(var(--border)/.5)}.border-destructive{border-color:hsl(var(--destructive))}.border-destructive\/50{border-color:hsl(var(--destructive)/.5)}.border-input{border-color:hsl(var(--input))}.border-primary{border-color:hsl(var(--primary))}.border-sidebar-border{border-color:hsl(var(--sidebar-border))}.border-transparent{border-color:transparent}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-\[--color-bg\]{background-color:var(--color-bg)}.bg-accent{background-color:hsl(var(--accent))}.bg-background{background-color:hsl(var(--background))}.bg-black\/80{background-color:rgb(0 0 0/.8)}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-destructive{background-color:hsl(var(--destructive))}.bg-foreground{background-color:hsl(var(--foreground))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted\/50{background-color:hsl(var(--muted)/.5)}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-primary\/10{background-color:hsl(var(--primary)/.1)}.bg-secondary{background-color:hsl(var(--secondary))}.bg-sidebar{background-color:hsl(var(--sidebar-background))}.bg-sidebar-border{background-color:hsl(var(--sidebar-border))}.bg-transparent{background-color:transparent}.from-blue-400{--tw-gradient-from:#60a5fa var(--tw-gradient-from-position);--tw-gradient-to:rgb(96 165 250/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-700{--tw-gradient-from:#374151 var(--tw-gradient-from-position);--tw-gradient-to:rgb(55 65 81/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-green-400{--tw-gradient-from:#4ade80 var(--tw-gradient-from-position);--tw-gradient-to:rgb(74 222 128/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-400{--tw-gradient-from:#818cf8 var(--tw-gradient-from-position);--tw-gradient-to:rgb(129 140 248/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-pink-400{--tw-gradient-from:#f472b6 var(--tw-gradient-from-position);--tw-gradient-to:rgb(244 114 182/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-400{--tw-gradient-from:#c084fc var(--tw-gradient-from-position);--tw-gradient-to:rgb(192 132 252/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-400{--tw-gradient-from:#f87171 var(--tw-gradient-from-position);--tw-gradient-to:rgb(248 113 113/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-purple-500{--tw-gradient-to:rgb(168 85 247/0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#a855f7 var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-blue-600{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.to-gray-900{--tw-gradient-to:#111827 var(--tw-gradient-to-position)}.to-green-600{--tw-gradient-to:#16a34a var(--tw-gradient-to-position)}.to-pink-500{--tw-gradient-to:#ec4899 var(--tw-gradient-to-position)}.to-pink-600{--tw-gradient-to:#db2777 var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to:#9333ea var(--tw-gradient-to-position)}.to-red-600{--tw-gradient-to:#dc2626 var(--tw-gradient-to-position)}.fill-current{fill:currentColor}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\[1px\]{padding:1px}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pl-2\.5{padding-left:.625rem}.pl-4{padding-left:1rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pr-2\.5{padding-right:.625rem}.pr-8{padding-right:2rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[0\.8rem\]{font-size:.8rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-accent-foreground{color:hsl(var(--accent-foreground))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-current{color:currentColor}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-foreground\/50{color:hsl(var(--foreground)/.5)}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-sidebar-foreground{color:hsl(var(--sidebar-foreground))}.text-sidebar-foreground\/70{color:hsl(var(--sidebar-foreground)/.7)}.text-yellow-500{--tw-text-opacity:1;color:rgb(234 179 8/var(--tw-text-opacity,1))}.underline-offset-4{text-underline-offset:4px}.accent-foreground{accent-color:hsl(var(--foreground))}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\]{--tw-shadow:0 0 0 1px hsl(var(--sidebar-border));--tw-shadow-colored:0 0 0 1px var(--tw-shadow-color)}.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\],.shadow-lg{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px rgb(0 0 0/0.1),0 2px 4px -2px rgb(0 0 0/0.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-none{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}.shadow-sm{--tw-shadow:0 1px 2px 0 rgb(0 0 0/0.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-sm,.shadow-xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgb(0 0 0/0.1),0 8px 10px -6px rgb(0 0 0/0.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring,.ring-0{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-0{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-2{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-ring{--tw-ring-color:hsl(var(--ring))}.ring-sidebar-ring{--tw-ring-color:hsl(var(--sidebar-ring))}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[left\2c right\2c width\]{transition-property:left,right,width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[margin\2c opa\]{transition-property:margin,opa;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[width\2c height\2c padding\]{transition-property:width,height,padding;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[width\]{transition-property:width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@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))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial}.fade-in-0{--tw-enter-opacity:0}.fade-in-80{--tw-enter-opacity:0.8}.zoom-in-95{--tw-enter-scale:.95}.duration-1000{animation-duration:1s}.duration-200{animation-duration:.2s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{animation-timing-function:linear}.ease-out{animation-timing-function:cubic-bezier(0,0,.2,1)}*{margin:0;padding:0;box-sizing:border-box;touch-action:manipulation}html{height:100%}body{font-family:PingFang SC,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;color:#333;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:10px;overflow-x:hidden;overflow:hidden;scrollbar-width:none;-ms-overflow-style:none}body::-webkit-scrollbar{display:none}@media (min-width:768px){body{padding:20px;justify-content:center}}#__next{align-items:center;flex-grow:1}#__next,main#app{display:flex;flex-direction:column;width:100%}main#app{max-width:380px;background:white;border-radius:20px;box-shadow:0 10px 40px rgba(0,0,0,.15);overflow:hidden;min-height:auto;overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}main#app::-webkit-scrollbar{display:none}@media (min-width:768px){main#app{max-width:400px;min-height:calc(100vh - 40px);max-height:calc(100vh - 40px);overflow-y:auto}}.start-container{background:linear-gradient(135deg,#1a1a2e,#16213e 25%,#0f3460 50%,#533483 75%,#e94560);min-height:100vh;position:relative;overflow:hidden}.start-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 20%,rgba(233,69,96,.3) 0,transparent 50%),radial-gradient(circle at 70% 80%,rgba(83,52,131,.4) 0,transparent 50%),radial-gradient(circle at 20% 80%,rgba(15,52,96,.3) 0,transparent 50%);animation:ambient-glow 8s ease-in-out infinite alternate}.start-header{background:linear-gradient(135deg,#4a4a6a,#3d3d5c 50%,#2d2d4a);backdrop-filter:blur(20px);border-bottom:1px solid rgba(233,69,96,.2);padding:20px 20px 30px;position:relative;z-index:2;overflow:visible;border-radius:20px 20px 0 0}.start-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(255,107,157,.1),transparent 50%,rgba(233,69,96,.1));opacity:.8}.start-header-content{max-width:400px;margin:0 auto;position:relative;z-index:3}.development-notice-card{margin-top:20px;background:linear-gradient(135deg,rgba(255,107,157,.15),rgba(233,69,96,.1));backdrop-filter:blur(10px);border:1px solid rgba(255,107,157,.3);border-radius:12px;padding:16px;position:relative;z-index:3;box-shadow:0 4px 20px rgba(255,107,157,.2);transition:all .3s ease}.development-notice-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(255,107,157,.3);border-color:rgba(255,107,157,.5)}.notice-header{display:flex;align-items:center;gap:8px;margin-bottom:12px}.notice-icon{color:#ff6b9d;filter:drop-shadow(0 2px 4px rgba(255,107,157,.3))}.notice-title{font-size:1rem;font-weight:700;color:rgba(255,255,255,.95);margin:0;text-shadow:0 2px 4px rgba(0,0,0,.3)}.notice-content{position:relative}.notice-text{font-size:.85rem;line-height:1.5;color:rgba(255,255,255,.85);margin:0;text-shadow:0 1px 2px rgba(0,0,0,.2)}.contact-email{color:#ff6b9d;text-decoration:none;font-weight:600;transition:all .2s ease;border-bottom:1px solid transparent}.contact-email:hover{color:#ff1744;border-bottom-color:#ff1744;text-shadow:0 0 8px rgba(255,23,68,.4)}.game-logo{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;z-index:4}.logo-top-decoration{display:none}.main-title-area{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:5}.game-title-main{font-size:2rem;font-weight:900;background:linear-gradient(135deg,#ff6b9d,#ff1744,#e91e63);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:2px;line-height:1.1;text-shadow:0 2px 8px rgba(255,107,157,.3)}.game-subtitle-main,.logo-bottom-decoration{display:none}.start-content{flex:1;padding:20px;display:flex;flex-direction:column;position:relative;z-index:2;max-height:calc(100vh - 200px);overflow-y:auto;scrollbar-width:none;-ms-overflow-style:none}.start-content::-webkit-scrollbar{display:none}.welcome-section{display:none}.modes-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:25px}.mode-card{background:rgba(0,0,0,.4);backdrop-filter:blur(15px);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);position:relative;border:1px solid rgba(255,255,255,.1);min-height:70px;box-shadow:0 8px 32px rgba(0,0,0,.3);display:flex;align-items:center;padding:16px 20px}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent,rgba(233,69,96,.1) 50%,transparent);opacity:0;transition:opacity .4s ease;z-index:1}.mode-card:hover:before{opacity:1}.mode-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 20px 40px rgba(233,69,96,.3),0 0 20px rgba(255,107,157,.2);border-color:rgba(233,69,96,.5)}.mode-card:active{transform:translateY(-3px) scale(1.01)}.mode-gradient{display:none}.mode-icon-container{display:flex;align-items:center;justify-content:center;z-index:2;background:rgba(233,69,96,.2);padding:12px;border-radius:50%;backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);transition:all .3s ease;position:relative;margin-right:16px;flex-shrink:0}.mode-card:hover .mode-icon-container{transform:scale(1.1);background:rgba(233,69,96,.4);border-color:rgba(255,255,255,.4)}.mode-emoji{font-size:1.6rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));animation:emoji-pulse 2s ease-in-out infinite}.mode-info{flex:1;position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center}.mode-title{font-size:1.1rem;font-weight:700;margin-bottom:4px;color:#ffffff;position:relative;text-shadow:0 2px 4px rgba(0,0,0,.5)}.mode-desc{font-size:.8rem;color:rgba(255,255,255,.8);line-height:1.3;margin:0}.intimate-card{background:rgba(20,20,20,.8);border:1px solid rgba(233,69,96,.3)}.intimate-card .mode-icon-container{background:rgba(139,69,19,.3)}.intimate-card:hover{box-shadow:0 20px 40px rgba(233,69,96,.4),0 0 30px rgba(233,69,96,.3);border-color:rgba(233,69,96,.7)}.loading-indicator{display:flex;align-items:center;gap:8px;margin-top:8px;font-size:.8rem;color:#ff6b9d;justify-content:flex-start}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,107,157,.3);border-top-color:#ff6b9d;border-radius:50%;animation:spin 1s linear infinite}.game-tips{display:flex;flex-direction:column;gap:16px;background:rgba(0,0,0,.35);backdrop-filter:blur(15px);border-radius:20px;padding:24px 20px;border:1px solid rgba(233,69,96,.3);margin-bottom:20px;position:relative;overflow:hidden;min-height:120px}.game-tips:before{top:0;height:3px;background:linear-gradient(90deg,transparent,#ff6b9d,#e91e63,#ff6b9d,transparent);animation:tip-glow 3s ease-in-out infinite}.game-tips:after,.game-tips:before{content:"";position:absolute;left:0;right:0}.game-tips:after{bottom:0;height:2px;background:linear-gradient(90deg,transparent,rgba(255,107,157,.5),transparent);animation:tip-glow 3s ease-in-out infinite reverse}@media (min-width:480px){.game-tips{flex-direction:row;justify-content:space-around;min-height:100px}}.tip-item{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.95);font-size:.95rem;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.5);padding:8px 0}.tip-item svg{color:#ff6b9d;flex-shrink:0;filter:drop-shadow(0 0 6px rgba(255,107,157,.6));animation:icon-glow 2s ease-in-out infinite alternate}@keyframes ambient-glow{0%{opacity:.8}to{opacity:1}}@keyframes passionate-glow{0%{text-shadow:0 2px 8px rgba(255,107,157,.3)}to{text-shadow:0 2px 12px rgba(255,107,157,.5)}}@keyframes subtitle-pulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes icon-glow{0%{filter:drop-shadow(0 0 6px rgba(255,107,157,.6))}to{filter:drop-shadow(0 0 10px rgba(255,107,157,.9))}}@keyframes emoji-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes tip-glow{0%,to{opacity:.6}50%{opacity:1}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.game-container{display:flex;flex-direction:column;flex-grow:1;transition:border-color .3s ease;min-height:100%}.game-container.red-turn{border:3px solid #ff6b6b;box-shadow:0 0 20px rgba(255,107,107,.3)}.game-container.blue-turn{border:3px solid #3498db;box-shadow:0 0 20px rgba(52,152,219,.3)}.header{padding:15px 20px;background:linear-gradient(135deg,#ff7070,#ff9eb6);color:white;font-weight:700;font-size:1.1rem;box-shadow:0 2px 8px rgba(0,0,0,.1);position:sticky;top:0;z-index:100;transition:background .3s ease;display:flex;align-items:center;gap:15px}.header.red-turn{background:linear-gradient(135deg,#ff6b6b,#ff8e8e)}.header.blue-turn{background:linear-gradient(135deg,#3498db,#5dade2)}.back-button{background:rgba(255,255,255,.2);border:none;border-radius:8px;padding:8px;color:white;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.back-button:hover{background:rgba(255,255,255,.3);transform:translateX(-2px)}.header-title{flex:1;text-align:center}.header-spacer{width:36px}.content{flex-grow:1;display:flex;flex-direction:column;padding:10px;position:relative}.button{background:linear-gradient(135deg,#ff7070,#ff9eb6);color:white;padding:12px 20px;border-radius:30px;font-size:1rem;font-weight:700;margin:6px 0;box-shadow:0 4px 15px rgba(255,112,112,.4);cursor:pointer;transition:all .3s ease;border:2px solid transparent;display:inline-flex;align-items:center;justify-content:center;min-height:44px}.button:disabled{opacity:.7;cursor:not-allowed}.button:active{transform:scale(.98)}.button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px rgba(255,112,112,.5)}.button.blue{background:linear-gradient(135deg,#3498db,#5dade2);box-shadow:0 4px 15px rgba(52,152,219,.4)}.button.blue:hover:not(:disabled){box-shadow:0 6px 20px rgba(52,152,219,.5)}.board-container{position:relative;width:100%;padding-bottom:100%;margin:5px auto}.board{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:10px;overflow:hidden;display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(7,1fr);gap:3px;padding:5px}.cell{background:#ffffff;border-radius:8px;display:flex;justify-content:center;align-items:center;position:relative;font-size:.7rem;border:2px solid transparent;transition:all .3s ease;flex-direction:column}.cell.empty{background:transparent;border:none}.cell.path{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;box-shadow:inset 0 1px 3px rgba(33,150,243,.2)}.cell.path:before{content:"";position:absolute;width:12px;height:12px;background:rgba(33,150,243,.2);border-radius:50%;z-index:0}.cell .cell-icon-text{display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1;text-align:center;font-size:.6rem}.cell .cell-icon-text p{margin-top:2px}.cell .cell-icon-text.path-dot{font-size:.8rem;color:#2196f3;font-weight:700}.cell.start{background:linear-gradient(135deg,#fff3e0,#ffcc02);border:3px solid #ff9800;color:#e65100;font-weight:700;box-shadow:0 3px 10px rgba(255,152,0,.4);animation:glow-start 2s ease-in-out infinite alternate}.cell.end{background:linear-gradient(135deg,#e8f5e8,#4caf50);border:3px solid #2e7d32;color:white;font-weight:700;box-shadow:0 3px 10px rgba(76,175,80,.4);animation:glow-end 2s ease-in-out infinite alternate}.cell.star{background:linear-gradient(135deg,#fff8e1,#ffc107);border:3px solid #ff6f00;color:#e65100;font-weight:700;box-shadow:0 3px 10px rgba(255,193,7,.4)}.cell.trap{background:linear-gradient(135deg,#ffebee,#f44336);border:3px solid #c62828;color:white;font-weight:700;box-shadow:0 3px 10px rgba(244,67,54,.4)}.cell-number,.cell.end .cell-number,.cell.star .cell-number,.cell.start .cell-number,.cell.trap .cell-number{display:none}.player{position:absolute;width:36px;height:36px;border-radius:50%;z-index:3;display:flex;justify-content:center;align-items:center;color:white;font-weight:700;border:3px solid white;box-shadow:0 3px 10px rgba(0,0,0,.35);transition:all .3s cubic-bezier(.25,.46,.45,.94);top:50%;left:50%;transform:translate(-50%,-50%)}.player.moving{animation:move-bounce .3s ease-in-out;z-index:15}.player.red{background:linear-gradient(135deg,#ff6b6b,#ff4757)}.player.blue{background:linear-gradient(135deg,#3498db,#2980b9)}.player.red.stacked{transform:translate(-65%,-65%) scale(.85)}.player.blue.stacked{transform:translate(-35%,-35%) scale(.85)}.player.current-turn{box-shadow:0 0 15px rgba(255,215,0,1),0 2px 10px rgba(0,0,0,.4),0 0 0 2px rgba(255,215,0,.7);animation:pulse-glow 1.5s ease-in-out infinite}.turn-indicator{text-align:center;padding:8px;font-weight:700;font-size:1rem;margin-bottom:0;border-radius:25px;transition:all .3s ease;box-shadow:0 4px 12px rgba(0,0,0,.1)}.dice-area{display:flex;justify-content:center;align-items:center;padding:10px;margin-top:8px;margin-bottom:10px;border-radius:20px;transition:all .3s ease}.dice-area.red-turn{background:rgba(255,107,107,.1);border:2px solid rgba(255,107,107,.3)}.dice-area.blue-turn{background:rgba(52,152,219,.1);border:2px solid rgba(52,152,219,.3)}.dice{width:60px;height:60px;background:white;border-radius:12px;display:flex;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;box-shadow:0 4px 12px rgba(0,0,0,.15);margin:0 15px;border:3px solid transparent;transition:all .3s ease}.dice.red-turn{border-color:#ff6b6b;color:#ff4757}.dice.blue-turn{border-color:#3498db;color:#2980b9}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:rgba(0,0,0,.6);display:flex;justify-content:center;align-items:center;z-index:1000;padding:15px}.modal-content{background-color:white;padding:25px;border-radius:16px;width:90%;max-width:400px;box-shadow:0 10px 30px rgba(0,0,0,.25);text-align:center}.task-card{padding:20px;border-radius:15px;background:#f7f7f7;margin:20px 0;font-size:1.1rem;border:3px solid transparent;transition:all .3s ease;position:relative;overflow:hidden}.task-card.red-executor{background:linear-gradient(135deg,#ffe6e6,#fff0f0);border-color:#ff6b6b;box-shadow:0 4px 15px rgba(255,107,107,.3)}.task-card.blue-executor{background:linear-gradient(135deg,#e3f2fd,#f0f8ff);border-color:#3498db;box-shadow:0 4px 15px rgba(52,152,219,.3)}.task-title{font-weight:700;margin-bottom:15px;font-size:1.3rem;text-align:center}.task-card.red-executor .task-title{color:#ff6b6b}.task-card.blue-executor .task-title{color:#3498db}.executor{font-weight:700;margin-bottom:15px;padding:10px 18px;border-radius:25px;text-align:center;font-size:1.1rem;border:2px solid;animation:pulse-executor 2s ease-in-out infinite}.executor.red{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:white;border-color:#ff4757;box-shadow:0 4px 12px rgba(255,107,107,.4)}.executor.blue{background:linear-gradient(135deg,#3498db,#5dade2);color:white;border-color:#2980b9;box-shadow:0 4px 12px rgba(52,152,219,.4)}.task-description{margin-bottom:20px;padding:15px;background:rgba(255,255,255,.9);border-radius:10px;border-left:5px solid #ddd;font-size:1rem;line-height:1.6;text-align:left}.task-card.red-executor .task-description{border-left-color:#ff6b6b}.task-card.blue-executor .task-description{border-left-color:#3498db}.task-buttons{display:flex;justify-content:space-around;gap:15px;margin-top:20px}.task-button{padding:12px 20px;border:none;border-radius:25px;font-weight:700;cursor:pointer;font-size:1rem;transition:all .3s ease;flex:1;box-shadow:0 4px 12px rgba(0,0,0,.2);min-height:44px}.task-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.3)}.task-button:active{transform:translateY(0)}.complete-btn{background:linear-gradient(135deg,#2ecc71,#27ae60);color:white;border:2px solid #27ae60}.complete-btn:hover{background:linear-gradient(135deg,#27ae60,#229954);box-shadow:0 6px 20px rgba(46,204,113,.4)}.fail-btn{background:linear-gradient(135deg,#e74c3c,#c0392b);color:white;border:2px solid #c0392b}.fail-btn:hover{background:linear-gradient(135deg,#c0392b,#a93226);box-shadow:0 6px 20px rgba(231,76,60,.4)}.win-message{font-size:1.5rem;font-weight:700;color:#2d5e3e;margin-bottom:20px;text-align:center;animation:pulse-glow 2s ease-in-out infinite}.win-modal{z-index:1000}.win-card{background:linear-gradient(135deg,#ffeaa7,#fdcb6e 25%,#fd79a8 50%,#e84393 75%,#a29bfe);border-radius:20px;padding:20px;max-width:350px;width:95%;position:relative;overflow:hidden;box-shadow:0 15px 40px rgba(253,203,110,.3),0 8px 20px rgba(232,67,147,.2),inset 0 1px 0 rgba(255,255,255,.3);animation:win-card-appear .8s cubic-bezier(.68,-.55,.265,1.55)}.win-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(255,255,255,.1) 25%,transparent 0,transparent 75%,rgba(255,255,255,.1) 0);background-size:20px 20px;animation:shimmer 3s linear infinite;pointer-events:none}.win-celebration{text-align:center;margin-bottom:20px;position:relative;z-index:2}.confetti-container{position:absolute;top:-15px;left:0;right:0;height:60px;pointer-events:none;overflow:hidden}.confetti{position:absolute;width:6px;height:6px;background:#ff6b9d;animation:confetti-fall 2.5s linear infinite}.confetti:first-child{left:10%;background:#4ecdc4;animation-delay:0s;animation-duration:2.5s}.confetti:nth-child(2){left:30%;background:#45b7d1;animation-delay:.5s;animation-duration:3s}.confetti:nth-child(3){left:50%;background:#96ceb4;animation-delay:1s;animation-duration:2.8s}.confetti:nth-child(4){left:70%;background:#feca57;animation-delay:1.5s;animation-duration:3.2s}.confetti:nth-child(5){left:90%;background:#ff9ff3;animation-delay:2s;animation-duration:2.7s}.trophy-icon{margin:15px 0;color:#f39c12;animation:trophy-bounce 2s ease-in-out infinite}.win-title{font-size:1.4rem;font-weight:900;color:#2d3436;margin:10px 0;text-shadow:2px 2px 4px rgba(0,0,0,.1);animation:win-title-glow 2s ease-in-out infinite alternate}.win-subtitle{font-size:.9rem;color:#636e72;margin-bottom:15px;font-weight:500}.win-tasks-container{margin:20px 0;position:relative;z-index:2}.tasks-title{font-size:1rem;font-weight:700;color:#2d3436;text-align:center;margin-bottom:15px}.win-tasks-grid{display:flex;flex-direction:column;gap:10px}.win-task-card{background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(255,255,255,.7));border-radius:12px;padding:15px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:2px solid rgba(255,255,255,.3);position:relative;overflow:hidden;min-height:60px}.win-task-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .5s}.win-task-card:hover:before{left:100%}.win-task-card:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 8px 20px rgba(232,67,147,.25);border-color:rgba(232,67,147,.4)}.win-task-card.red-winner{border-left:4px solid #e74c3c}.win-task-card.blue-winner{border-left:4px solid #3498db}.task-number{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#fd79a8,#e84393);color:white;justify-content:center;font-weight:700;flex-shrink:0;box-shadow:0 3px 8px rgba(232,67,147,.3);font-size:.9rem}.task-content,.task-number{display:flex;align-items:center}.task-content{flex:1;gap:8px}.task-content svg{color:#fd79a8;flex-shrink:0;width:18px;height:18px}.task-content p{margin:0;font-size:.85rem;line-height:1.3;color:#2d3436;font-weight:500}.win-actions{text-align:center;margin-top:20px;position:relative;z-index:2}.skip-button{background:linear-gradient(135deg,#636e72,#2d3436);color:white;border:none;border-radius:20px;padding:10px 20px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:6px}.skip-button:hover{background:linear-gradient(135deg,#2d3436,#636e72);transform:translateY(-1px);box-shadow:0 6px 15px rgba(45,52,54,.3)}.win-task-modal{z-index:1001}.win-task-execution-card{background:linear-gradient(135deg,#74b9ff,#0984e3 50%,#6c5ce7);border-radius:20px;padding:25px;max-width:350px;width:95%;color:white;position:relative;overflow:hidden;box-shadow:0 20px 50px rgba(116,185,255,.3),0 10px 25px rgba(108,92,231,.2);animation:win-task-appear .6s cubic-bezier(.68,-.55,.265,1.55)}.win-task-execution-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.1) 0,transparent 50%);pointer-events:none}.task-header{text-align:center;margin-bottom:20px;position:relative;z-index:2}.task-header h2{font-size:1.3rem;font-weight:700;margin:8px 0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.task-star{color:#ffeaa7;animation:star-twinkle 2s ease-in-out infinite;width:28px;height:28px}.selected-task{background:rgba(255,255,255,.15);border-radius:12px;padding:15px;margin:15px 0;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);position:relative;z-index:2}.selected-task.red-executor{border-left:4px solid #e74c3c}.selected-task.blue-executor{border-left:4px solid #74b9ff}.task-executor{font-size:.85rem;font-weight:600;margin-bottom:12px;opacity:.9}.task-description-box{font-size:1rem;line-height:1.4;padding:12px;background:rgba(255,255,255,.1);border-radius:8px;border:1px solid rgba(255,255,255,.2);text-align:center;font-weight:500}.celebration-message{text-align:center;margin:15px 0;display:flex;align-items:center;justify-content:center;gap:8px;position:relative;z-index:2}.celebration-message svg{color:#fd79a8;animation:heart-pulse 1.5s ease-in-out infinite;width:20px;height:20px}.celebration-message p{margin:0;font-size:.9rem;opacity:.9}.win-task-actions{display:flex;gap:10px;justify-content:center;margin-top:20px;position:relative;z-index:2}.complete-win-task-btn,.restart-btn{padding:10px 16px;border:none;border-radius:20px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:6px;min-width:100px;justify-content:center}.complete-win-task-btn{background:linear-gradient(135deg,#00b894,#00a085);color:white;flex:1}.restart-btn{background:linear-gradient(135deg,#636e72,#2d3436);color:white}.complete-win-task-btn:hover{background:linear-gradient(135deg,#00a085,#00b894);transform:translateY(-1px);box-shadow:0 6px 15px rgba(0,184,148,.3)}.restart-btn:hover{background:linear-gradient(135deg,#2d3436,#636e72);transform:translateY(-1px);box-shadow:0 6px 15px rgba(45,52,54,.3)}@keyframes confetti-fall{0%{transform:translateY(-100px) rotate(0deg);opacity:1}to{transform:translateY(200px) rotate(1turn);opacity:0}}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}@keyframes win-card-appear{0%{opacity:0;transform:scale(.8) translateY(50px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes win-task-appear{0%{opacity:0;transform:scale(.9) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes trophy-bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-15px)}60%{transform:translateY(-10px)}}@keyframes win-title-glow{0%{text-shadow:2px 2px 4px rgba(0,0,0,.1)}to{text-shadow:2px 2px 4px rgba(0,0,0,.1),0 0 15px rgba(253,121,168,.3)}}@keyframes star-twinkle{0%,to{transform:scale(1) rotate(0deg);opacity:1}50%{transform:scale(1.2) rotate(180deg);opacity:.8}}@keyframes heart-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.path-lines-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.path-line{position:absolute;background:linear-gradient(90deg,rgba(52,152,219,.8),rgba(255,107,107,.8));height:4px;border-radius:2px;box-shadow:0 0 8px rgba(0,0,0,.2);animation:path-glow 2.5s infinite alternate}.cell-icon-text{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;z-index:1}.cell-icon-text>svg{margin-bottom:0}.cell-icon-text>p{font-size:.55rem;line-height:1;margin:0}.cell.path .cell-icon-text{font-size:1rem;color:#1976d2;font-weight:700}.toast{position:fixed;top:20px;left:50%;transform:translateX(-50%);padding:12px 20px;border-radius:8px;color:white;font-size:.9rem;font-weight:700;display:flex;align-items:center;gap:10px;z-index:2000;box-shadow:0 4px 15px rgba(0,0,0,.2);animation:toast-fade-in-out-top 3s ease-in-out forwards}.toast.success{background-color:#2ecc71}.toast.error{background-color:#e74c3c}@keyframes glow-start{0%{box-shadow:0 3px 10px rgba(255,152,0,.4)}to{box-shadow:0 3px 20px rgba(255,152,0,.8),0 0 10px rgba(255,152,0,.5)}}@keyframes glow-end{0%{box-shadow:0 3px 10px rgba(76,175,80,.4)}to{box-shadow:0 3px 20px rgba(76,175,80,.8),0 0 10px rgba(76,175,80,.5)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 15px rgba(255,215,0,.8),0 3px 8px rgba(0,0,0,.3);transform:translate(-50%,-50%) scale(1)}50%{box-shadow:0 0 25px rgba(255,215,0,1),0 3px 15px rgba(0,0,0,.4);transform:translate(-50%,-50%) scale(1.05)}}@keyframes pulse-red{0%,to{transform:scale(1);box-shadow:0 4px 12px rgba(255,107,107,.3)}50%{transform:scale(1.02);box-shadow:0 6px 20px rgba(255,107,107,.5)}}@keyframes pulse-blue{0%,to{transform:scale(1);box-shadow:0 4px 12px rgba(78,205,196,.3)}50%{transform:scale(1.02);box-shadow:0 6px 20px rgba(78,205,196,.5)}}@keyframes move-bounce{0%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-60%) scale(1.15)}to{transform:translate(-50%,-50%) scale(1)}}@keyframes pulse-executor{0%,to{transform:scale(1);box-shadow:0 4px 12px rgba(0,0,0,.2)}50%{transform:scale(1.02);box-shadow:0 6px 18px rgba(0,0,0,.25)}}@keyframes path-glow{0%{opacity:.8;box-shadow:0 0 8px rgba(52,152,219,.3)}to{opacity:1;box-shadow:0 0 12px rgba(52,152,219,.6),0 0 20px rgba(255,107,107,.4)}}@keyframes toast-fade-in-out-top{0%{opacity:0;transform:translateX(-50%) translateY(-40px)}10%{opacity:1;transform:translateX(-50%) translateY(0)}90%{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(-40px)}}.task-rewards{margin-top:15px;padding:12px;background:rgba(0,0,0,.05);border-radius:8px;border:1px solid rgba(0,0,0,.1)}.reward-info{display:flex;flex-direction:column;gap:8px}.reward-fail,.reward-success{padding:6px 10px;border-radius:6px;font-size:.85rem;font-weight:600;text-align:center}.reward-success{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724;border:1px solid #c3e6cb}.reward-fail{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:#721c24;border:1px solid #f5c6cb}.task-card.red-executor .reward-success{background:linear-gradient(135deg,#ffe6e6,#ffcccc);color:#cc0000;border-color:#ffcccc}.task-card.blue-executor .reward-success{background:linear-gradient(135deg,#e6f7f7,#cceeee);color:#3498db;border-color:#cceeee}.seo-hidden-content{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.seo-content{max-width:800px;margin:0 auto;padding:20px;font-family:PingFang SC,Microsoft YaHei,sans-serif;line-height:1.6;color:#333}.hero-seo{text-align:center;margin-bottom:40px}.seo-title{font-size:2rem;font-weight:700;color:#2c3e50;margin-bottom:15px;line-height:1.3}.seo-subtitle{font-size:1.1rem;color:#7f8c8d;margin-bottom:25px}.hero-features{display:flex;justify-content:center;gap:20px;flex-wrap:wrap}.feature-item{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f8f9fa;border-radius:20px;font-size:.9rem;color:#495057}.feature-icon{width:16px;height:16px;color:#e74c3c}.faq-section h2,.game-highlights h2,.game-modes-seo h2,.product-features h2,.related-keywords h2,.testimonials h2,.usage-scenarios h2{font-size:1.5rem;font-weight:700;color:#2c3e50;margin-bottom:25px;text-align:center}.features-grid,.scenarios-grid,.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px;margin-bottom:40px}.feature-card,.scenario-card,.testimonial-card{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.1);border-left:4px solid #e74c3c}.feature-header{display:flex;align-items:center;gap:12px;margin-bottom:15px}.card-icon{width:24px;height:24px;color:#e74c3c}.feature-card h3,.scenario-card h3,.testimonial-card h3{font-size:1.2rem;font-weight:600;color:#2c3e50;margin-bottom:10px}.highlights-list{display:grid;gap:20px;margin-bottom:40px}.highlight-item{display:flex;gap:15px;align-items:flex-start;padding:20px;background:#f8f9fa;border-radius:10px}.highlight-icon{font-size:2rem;min-width:50px}.highlight-content h3{font-size:1.1rem;font-weight:600;margin-bottom:8px;color:#2c3e50}.modes-description{display:grid;gap:20px;margin-bottom:40px}.mode-item{padding:20px;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:10px;border-left:4px solid #e74c3c}.mode-item h3{font-size:1.1rem;font-weight:600;margin-bottom:12px;color:#2c3e50}.faq-list{display:grid;gap:20px;margin-bottom:40px}.faq-item{padding:20px;background:#fff;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.faq-item h3{font-size:1.1rem;font-weight:600;margin-bottom:12px;color:#e74c3c}.stars{color:#ffc107;margin-bottom:10px}.reviewer{font-style:italic;color:#6c757d;font-size:.9rem}.keywords-cloud{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:40px}.keyword-tag{padding:6px 12px;background:linear-gradient(135deg,#e74c3c,#c0392b);color:white;border-radius:15px;font-size:.85rem;font-weight:500;transition:transform .2s ease}.keyword-tag:hover{transform:translateY(-2px)}@media (max-width:768px){.features-grid,.scenarios-grid,.testimonials-grid{grid-template-columns:1fr}.hero-features{flex-direction:column;align-items:center}.seo-title{font-size:1.5rem}}.language-selector-buttons{display:flex;gap:4px;align-items:center}.language-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;border-radius:6px;background:rgba(255,255,255,.05);cursor:pointer;transition:all .2s ease;font-size:14px;opacity:.7}.language-btn:hover{background:rgba(255,255,255,.1);opacity:1}.language-btn.active{background:rgba(255,255,255,.15);opacity:1;border-color:rgba(255,255,255,.2)}.language-flag{display:block;font-size:16px;line-height:1}.title-language-selector{margin-top:15px;display:flex;justify-content:center}.title-language-selector .language-selector-buttons{background:rgba(0,0,0,.1);padding:6px;border-radius:8px;backdrop-filter:blur(5px)}.title-language-selector .language-btn{background:transparent;border:none;color:rgba(255,255,255,.8)}.title-language-selector .language-btn:hover{background:rgba(255,255,255,.1);color:rgba(255,255,255,1)}.title-language-selector .language-btn.active{background:rgba(255,255,255,.15);border:none;color:rgba(255,255,255,1)}.github-link{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:rgba(255,255,255,.05);color:rgba(255,255,255,.7);text-decoration:none;transition:all .2s ease;margin-left:8px}.github-link:hover{background:rgba(255,255,255,.1);color:rgba(255,255,255,1);transform:translateY(-1px)}.title-github-link{margin-left:12px;background:rgba(0,0,0,.1);color:rgba(255,255,255,.8)}.title-github-link:hover{background:rgba(255,255,255,.1);color:rgba(255,255,255,1)}.custom-modes-section{margin-top:2rem;padding:2rem;background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.05));border-radius:1rem;backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1)}.delete-custom-mode-btn{position:absolute;top:-4px;right:-4px;width:20px;height:20px;background:rgba(239,68,68,.9);border:1px solid rgba(255,255,255,.5);border-radius:50%;color:white;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;transition:all .2s ease;z-index:10}.delete-custom-mode-btn:hover{background:rgba(239,68,68,1);transform:scale(1.1);box-shadow:0 2px 8px rgba(239,68,68,.4)}.task-count-badge{display:inline-block;background:rgba(34,197,94,.2);color:rgba(34,197,94,.9);border:1px solid rgba(34,197,94,.3);border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:500;margin-top:4px}.section-title{font-size:1.25rem;font-weight:700;margin-bottom:1rem;color:rgba(255,255,255,.9);text-align:center}.custom-modes-list{display:grid;gap:1rem;max-height:300px;overflow-y:auto;padding-right:.5rem}.custom-modes-list::-webkit-scrollbar{width:4px}.custom-modes-list::-webkit-scrollbar-track{background:rgba(255,255,255,.1);border-radius:2px}.custom-modes-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:2px}.custom-mode-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,rgba(255,255,255,.1),rgba(255,255,255,.05));border-radius:.75rem;border:1px solid rgba(255,255,255,.1);transition:all .3s ease;cursor:pointer}.custom-mode-item:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(34,197,94,.2);border-color:rgba(34,197,94,.3)}.custom-mode-content{flex:1;cursor:pointer}.custom-mode-info h4{font-size:1.1rem;font-weight:600;margin-bottom:.25rem;color:rgba(255,255,255,.9)}.custom-mode-info p{font-size:.875rem;color:rgba(255,255,255,.7);margin-bottom:.25rem}.task-count{font-size:.75rem;color:rgba(34,197,94,.8);font-weight:500}.delete-custom-mode{padding:.5rem;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:.5rem;color:rgba(239,68,68,.8);cursor:pointer;transition:all .2s ease}.delete-custom-mode:hover{background:rgba(239,68,68,.2);color:rgba(239,68,68,1);transform:scale(1.1)}.custom-mode-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;background-color:rgba(0,0,0,.95);display:flex;justify-content:center;align-items:flex-start;z-index:999999;overflow:hidden;padding-bottom:env(safe-area-inset-bottom,0)}.custom-mode-creator{width:100%;height:100%;max-width:800px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:0;overflow:hidden;border:none;box-shadow:none;animation:modal-fade-in .3s ease-out;position:relative;display:flex;flex-direction:column}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.creator-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,rgba(34,197,94,.15),rgba(34,197,94,.08));border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.creator-header h2{font-size:1.25rem;font-weight:700;color:rgba(255,255,255,.9);margin:0}.close-creator{padding:.75rem;background:rgba(255,255,255,.1);border:none;border-radius:.5rem;color:rgba(255,255,255,.7);cursor:pointer;transition:all .2s ease;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}.close-creator:hover{background:rgba(255,255,255,.2);color:rgba(255,255,255,1)}.creator-content{flex:1;padding:1.5rem;overflow-y:auto;position:relative}.creator-content::-webkit-scrollbar{width:6px}.creator-content::-webkit-scrollbar-track{background:rgba(255,255,255,.1);border-radius:3px}.creator-content::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:3px}.creator-content::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.5)}.creator-actions{display:flex;gap:1rem;justify-content:flex-end;padding:1rem 1.5rem calc(1rem + env(safe-area-inset-bottom, 0));background:rgba(255,255,255,.05);border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.cancel-btn,.create-btn{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s ease;user-select:none;-webkit-tap-highlight-color:transparent;justify-content:center;min-height:44px;font-size:1rem}.create-btn{background:linear-gradient(135deg,#34d399,#10b981);color:white;flex:1}.create-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(52,211,153,.3)}.create-btn:active:not(:disabled){transform:translateY(0)}.create-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.cancel-btn{background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.2);flex:1}.cancel-btn:hover{background:rgba(255,255,255,.15);color:rgba(255,255,255,1);transform:translateY(-1px)}.cancel-btn:active{transform:translateY(0)}@media (min-width:768px){.custom-mode-modal{align-items:center;padding:2rem}.custom-mode-creator{width:90vw;height:auto;max-height:90vh;max-width:800px;border-radius:1rem;box-shadow:0 20px 60px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1)}.creator-header{padding:1.5rem 2rem}.creator-header h2{font-size:1.5rem}.creator-content{padding:2rem;max-height:60vh}.creator-actions{padding:1.5rem 2rem;justify-content:flex-end}.cancel-btn,.create-btn{flex:none;min-width:120px}}.basic-info-section{margin-bottom:2rem}.input-group{margin-bottom:1rem}.input-group label{display:block;font-size:.875rem;font-weight:600;color:rgba(255,255,255,.8);margin-bottom:.5rem}.input-group input{width:100%;padding:.75rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:.5rem;color:rgba(255,255,255,.9);font-size:.875rem;transition:all .2s ease}.input-group input:focus{outline:none;border-color:rgba(34,197,94,.5);box-shadow:0 0 0 3px rgba(34,197,94,.1)}.input-group input::placeholder{color:rgba(255,255,255,.5)}.task-selection-section h3{font-size:1.25rem;font-weight:700;color:rgba(255,255,255,.9);margin-bottom:1.5rem}.task-selection-section h4{font-size:1rem;font-weight:600;color:rgba(255,255,255,.8);margin-bottom:1rem}.load-tasks-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:.5rem;color:white;font-weight:600;cursor:pointer;transition:all .2s ease;margin-bottom:1.5rem;user-select:none;-webkit-tap-highlight-color:transparent;position:relative;overflow:hidden}.load-tasks-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(59,130,246,.3)}.load-tasks-btn:active{transform:translateY(0)}.load-tasks-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.load-tasks-btn:disabled:after{content:"";position:absolute;top:50%;left:1rem;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin 1s linear infinite;transform:translateY(-50%)}.mode-tasks-grid{display:grid;gap:1.5rem;margin-bottom:2rem}.mode-tasks-section{background:rgba(255,255,255,.05);border-radius:.75rem;padding:1rem;border:1px solid rgba(255,255,255,.1)}.mode-section-title{font-size:.875rem;font-weight:600;color:rgba(255,255,255,.8);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.tasks-list{display:grid;gap:.5rem;max-height:200px;overflow-y:auto;padding-right:.5rem}.tasks-list::-webkit-scrollbar{width:4px}.tasks-list::-webkit-scrollbar-track{background:rgba(255,255,255,.1);border-radius:2px}.tasks-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:2px}.task-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:.5rem;cursor:pointer;transition:all .2s ease;user-select:none;-webkit-tap-highlight-color:transparent}.task-item:hover{background:rgba(255,255,255,.1);border-color:rgba(34,197,94,.3);transform:translateY(-1px)}.task-item:active{transform:translateY(0);background:rgba(255,255,255,.15)}.task-item.selected{background:rgba(34,197,94,.2);border-color:rgba(34,197,94,.5);transform:none}.task-item.selected:hover{background:rgba(34,197,94,.25);transform:translateY(-1px)}.task-text{font-size:.875rem;color:rgba(255,255,255,.8);flex:1}.task-item.selected .task-text{color:rgba(255,255,255,.9)}.manual-task-section{margin-bottom:2rem}.manual-task-input{display:flex;gap:.5rem;align-items:center}.manual-task-input input{flex:1;padding:.75rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:.5rem;color:rgba(255,255,255,.9);font-size:.875rem;transition:all .2s ease}.manual-task-input input:focus{outline:none;border-color:rgba(34,197,94,.5);box-shadow:0 0 0 3px rgba(34,197,94,.1)}.manual-task-input button{padding:.75rem;background:linear-gradient(135deg,#34d399,#10b981);border:none;border-radius:.5rem;color:white;cursor:pointer;transition:all .2s ease;user-select:none;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center}.manual-task-input button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(52,211,153,.3)}.manual-task-input button:active:not(:disabled){transform:translateY(0)}.manual-task-input button:disabled{opacity:.5;cursor:not-allowed;transform:none}.selected-tasks-section{margin-bottom:1rem}.selected-tasks-list{display:grid;gap:.5rem;max-height:200px;overflow-y:auto;padding-right:.5rem}.selected-tasks-list::-webkit-scrollbar{width:4px}.selected-tasks-list::-webkit-scrollbar-track{background:rgba(255,255,255,.1);border-radius:2px}.selected-tasks-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:2px}.selected-task-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.3);border-radius:.5rem;transition:all .2s ease}.selected-task-item:hover{background:rgba(34,197,94,.15)}.task-number{font-size:.75rem;font-weight:600;color:rgba(34,197,94,.8);min-width:1.5rem}.selected-task-item .task-text{flex:1;font-size:.875rem;color:rgba(255,255,255,.9)}.remove-task{padding:.25rem;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);border-radius:.25rem;color:rgba(239,68,68,.8);cursor:pointer;transition:all .2s ease;user-select:none;-webkit-tap-highlight-color:transparent;display:flex;align-items:center;justify-content:center}.remove-task:hover{background:rgba(239,68,68,.2);color:rgba(239,68,68,1);transform:scale(1.1)}.remove-task:active{transform:scale(1.05)}@media (max-width:767px){.input-group input,.load-tasks-btn{padding:1rem;font-size:1rem}.load-tasks-btn{width:100%}.task-item{padding:.875rem;min-height:44px}.manual-task-input{flex-direction:column;gap:.75rem}.manual-task-input button,.manual-task-input input{width:100%;padding:1rem;font-size:1rem}.manual-task-input button{min-height:48px}.selected-task-item{padding:1rem}.remove-task{padding:.5rem;min-width:36px;min-height:36px}}.file\:border-0::file-selector-button{border-width:0}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::file-selector-button{color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:-inset-2:after{content:var(--tw-content);inset:-.5rem}.after\:inset-y-0:after{content:var(--tw-content);top:0;bottom:0}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-1:after{content:var(--tw-content);width:.25rem}.after\:w-\[2px\]:after{content:var(--tw-content);width:2px}.after\:-translate-x-1\/2:after{content:var(--tw-content);--tw-translate-x:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.first\:rounded-l-md:first-child{border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.first\:border-l:first-child{border-left-width:1px}.last\:rounded-r-md:last-child{border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.focus-within\:relative:focus-within{position:relative}.focus-within\:z-20:focus-within{z-index:20}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-destructive\/80:hover{background-color:hsl(var(--destructive)/.8)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive)/.9)}.hover\:bg-muted:hover{background-color:hsl(var(--muted))}.hover\:bg-muted\/50:hover{background-color:hsl(var(--muted)/.5)}.hover\:bg-primary:hover{background-color:hsl(var(--primary))}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary)/.8)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary)/.9)}.hover\:bg-secondary:hover{background-color:hsl(var(--secondary))}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary)/.8)}.hover\:bg-sidebar-accent:hover{background-color:hsl(var(--sidebar-accent))}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:text-muted-foreground:hover{color:hsl(var(--muted-foreground))}.hover\:text-primary-foreground:hover{color:hsl(var(--primary-foreground))}.hover\:text-sidebar-accent-foreground:hover{color:hsl(var(--sidebar-accent-foreground))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover{--tw-shadow:0 0 0 1px hsl(var(--sidebar-accent));--tw-shadow-colored:0 0 0 1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:after\:bg-sidebar-border:hover:after{content:var(--tw-content);background-color:hsl(var(--sidebar-border))}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:bg-primary:focus{background-color:hsl(var(--primary))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:text-primary-foreground:focus{color:hsl(var(--primary-foreground))}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-1:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:hsl(var(--ring))}.focus-visible\:ring-sidebar-ring:focus-visible{--tw-ring-color:hsl(var(--sidebar-ring))}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width:1px}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color:hsl(var(--background))}.active\:bg-sidebar-accent:active{background-color:hsl(var(--sidebar-accent))}.active\:text-sidebar-accent-foreground:active{color:hsl(var(--sidebar-accent-foreground))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group\/menu-item:focus-within .group-focus-within\/menu-item\:opacity-100{opacity:1}.group:hover .group-hover\:opacity-100,.group\/menu-item:hover .group-hover\/menu-item\:opacity-100{opacity:1}.group.destructive .group-\[\.destructive\]\:border-muted\/40{border-color:hsl(var(--muted)/.4)}.group.toaster .group-\[\.toaster\]\:border-border{border-color:hsl(var(--border))}.group.toast .group-\[\.toast\]\:bg-muted{background-color:hsl(var(--muted))}.group.toast .group-\[\.toast\]\:bg-primary{background-color:hsl(var(--primary))}.group.toaster .group-\[\.toaster\]\:bg-background{background-color:hsl(var(--background))}.group.destructive .group-\[\.destructive\]\:text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.group.toast .group-\[\.toast\]\:text-muted-foreground{color:hsl(var(--muted-foreground))}.group.toast .group-\[\.toast\]\:text-primary-foreground{color:hsl(var(--primary-foreground))}.group.toaster .group-\[\.toaster\]\:text-foreground{color:hsl(var(--foreground))}.group.toaster .group-\[\.toaster\]\:shadow-lg{--tw-shadow:0 10px 15px -3px rgb(0 0 0/0.1),0 4px 6px -4px rgb(0 0 0/0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{border-color:hsl(var(--destructive)/.3)}.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{background-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{color:hsl(var(--destructive-foreground))}.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{--tw-text-opacity:1;color:rgb(254 242 242/var(--tw-text-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{--tw-ring-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(248 113 113/var(--tw-ring-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{--tw-ring-offset-color:#dc2626}.peer\/menu-button:hover~.peer-hover\/menu-button\:text-sidebar-accent-foreground{color:hsl(var(--sidebar-accent-foreground))}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\[data-variant\=inset\]\]\:bg-sidebar:has([data-variant=inset]){background-color:hsl(var(--sidebar-background))}.has-\[\:disabled\]\:opacity-50:has(:disabled){opacity:.5}.group\/menu-item:has([data-sidebar=menu-action]) .group-has-\[\[data-sidebar\=menu-action\]\]\/menu-item\:pr-8{padding-right:2rem}.aria-disabled\:pointer-events-none[aria-disabled=true]{pointer-events:none}.aria-disabled\:opacity-50[aria-disabled=true]{opacity:.5}.aria-selected\:bg-accent[aria-selected=true]{background-color:hsl(var(--accent))}.aria-selected\:bg-accent\/50[aria-selected=true]{background-color:hsl(var(--accent)/.5)}.aria-selected\:text-accent-foreground[aria-selected=true]{color:hsl(var(--accent-foreground))}.aria-selected\:text-muted-foreground[aria-selected=true]{color:hsl(var(--muted-foreground))}.aria-selected\:opacity-100[aria-selected=true]{opacity:1}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true],.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction=vertical]{height:1px}.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction=vertical]{width:100%}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:0.25rem}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom],.data-\[side\=left\]\:-translate-x-1[data-side=left]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:-0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right],.data-\[side\=top\]\:-translate-y-1[data-side=top]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:-0.25rem}.data-\[state\=checked\]\:translate-x-5[data-state=checked]{--tw-translate-x:1.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked],.data-\[swipe\=cancel\]\:translate-x-0[data-swipe=cancel]{--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end]{--tw-translate-x:var(--radix-toast-swipe-end-x)}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end],.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{--tw-translate-x:var(--radix-toast-swipe-move-x)}@keyframes accordion-up{0%{height:var(--radix-accordion-content-height)}to{height:0}}.data-\[state\=closed\]\:animate-accordion-up[data-state=closed]{animation:accordion-up .2s ease-out}@keyframes accordion-down{0%{height:0}to{height:var(--radix-accordion-content-height)}}.data-\[state\=open\]\:animate-accordion-down[data-state=open]{animation:accordion-down .2s ease-out}.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction=vertical]{flex-direction:column}.data-\[active\=true\]\:bg-sidebar-accent[data-active=true]{background-color:hsl(var(--sidebar-accent))}.data-\[active\]\:bg-accent\/50[data-active]{background-color:hsl(var(--accent)/.5)}.data-\[selected\=\'true\'\]\:bg-accent[data-selected=true]{background-color:hsl(var(--accent))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=on\]\:bg-accent[data-state=on],.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:hsl(var(--accent)/.5)}.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:hsl(var(--secondary))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[active\=true\]\:font-medium[data-active=true]{font-weight:500}.data-\[active\=true\]\:text-sidebar-accent-foreground[data-active=true]{color:hsl(var(--sidebar-accent-foreground))}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{color:hsl(var(--accent-foreground))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:hsl(var(--foreground))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:hsl(var(--primary-foreground))}.data-\[state\=on\]\:text-accent-foreground[data-state=on],.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:hsl(var(--accent-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}.data-\[disabled\=true\]\:opacity-50[data-disabled=true],.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:opacity-100[data-state=open]{opacity:1}.data-\[state\=active\]\:shadow-sm[data-state=active]{--tw-shadow:0 1px 2px 0 rgb(0 0 0/0.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.data-\[swipe\=move\]\:transition-none[data-swipe=move]{transition-property:none}.data-\[state\=closed\]\:duration-300[data-state=closed]{transition-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{transition-duration:.5s}.data-\[motion\^\=from-\]\:animate-in[data-motion^=from-],.data-\[state\=open\]\:animate-in[data-state=open],.data-\[state\=visible\]\:animate-in[data-state=visible]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial}.data-\[motion\^\=to-\]\:animate-out[data-motion^=to-],.data-\[state\=closed\]\:animate-out[data-state=closed],.data-\[state\=hidden\]\:animate-out[data-state=hidden],.data-\[swipe\=end\]\:animate-out[data-swipe=end]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial}.data-\[motion\^\=from-\]\:fade-in[data-motion^=from-]{--tw-enter-opacity:0}.data-\[motion\^\=to-\]\:fade-out[data-motion^=to-],.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:fade-out-80[data-state=closed]{--tw-exit-opacity:0.8}.data-\[state\=hidden\]\:fade-out[data-state=hidden]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open],.data-\[state\=visible\]\:fade-in[data-state=visible]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-90[data-state=open]{--tw-enter-scale:.9}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[motion\=from-end\]\:slide-in-from-right-52[data-motion=from-end]{--tw-enter-translate-x:13rem}.data-\[motion\=from-start\]\:slide-in-from-left-52[data-motion=from-start]{--tw-enter-translate-x:-13rem}.data-\[motion\=to-end\]\:slide-out-to-right-52[data-motion=to-end]{--tw-exit-translate-x:13rem}.data-\[motion\=to-start\]\:slide-out-to-left-52[data-motion=to-start]{--tw-exit-translate-x:-13rem}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-0.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:0.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-0.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:0.5rem}.data-\[state\=closed\]\:slide-out-to-bottom[data-state=closed]{--tw-exit-translate-y:100%}.data-\[state\=closed\]\:slide-out-to-left[data-state=closed]{--tw-exit-translate-x:-100%}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x:-50%}.data-\[state\=closed\]\:slide-out-to-right-full[data-state=closed],.data-\[state\=closed\]\:slide-out-to-right[data-state=closed]{--tw-exit-translate-x:100%}.data-\[state\=closed\]\:slide-out-to-top[data-state=closed]{--tw-exit-translate-y:-100%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-bottom[data-state=open]{--tw-enter-translate-y:100%}.data-\[state\=open\]\:slide-in-from-left[data-state=open]{--tw-enter-translate-x:-100%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x:-50%}.data-\[state\=open\]\:slide-in-from-right[data-state=open]{--tw-enter-translate-x:100%}.data-\[state\=open\]\:slide-in-from-top[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-top-full[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=closed\]\:duration-300[data-state=closed]{animation-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{animation-duration:.5s}.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);left:0}.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction=vertical]:after{content:var(--tw-content);height:.25rem}.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction=vertical]:after{content:var(--tw-content);width:100%}.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction=vertical]:after{content:var(--tw-content);--tw-translate-y:-50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=open\]\:hover\:bg-sidebar-accent:hover[data-state=open]{background-color:hsl(var(--sidebar-accent))}.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground:hover[data-state=open]{color:hsl(var(--sidebar-accent-foreground))}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\]{left:calc(var(--sidebar-width) * -1)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\]{right:calc(var(--sidebar-width) * -1)}.group[data-side=left] .group-data-\[side\=left\]\:-right-4{right:-1rem}.group[data-side=right] .group-data-\[side\=right\]\:left-0{left:0}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:-mt-8{margin-top:-2rem}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:hidden{display:none}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:\!size-8{width:2rem!important;height:2rem!important}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[--sidebar-width-icon\]{width:var(--sidebar-width-icon)}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)\)\]{width:calc(var(--sidebar-width-icon) + 1rem)}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)_\+2px\)\]{width:calc(var(--sidebar-width-icon) + 1rem + 2px)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:w-0{width:0}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:translate-x-0{--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group[data-side=right] .group-data-\[side\=right\]\:rotate-180,.group[data-state=open] .group-data-\[state\=open\]\:rotate-180{--tw-rotate:180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:overflow-hidden{overflow:hidden}.group[data-variant=floating] .group-data-\[variant\=floating\]\:rounded-lg{border-radius:var(--radius)}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border{border-width:1px}.group[data-side=left] .group-data-\[side\=left\]\:border-r{border-right-width:1px}.group[data-side=right] .group-data-\[side\=right\]\:border-l{border-left-width:1px}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border-sidebar-border{border-color:hsl(var(--sidebar-border))}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:\!p-0{padding:0!important}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:\!p-2{padding:.5rem!important}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:opacity-0{opacity:0}.group[data-variant=floating] .group-data-\[variant\=floating\]\:shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0/0.1),0 1px 2px -1px rgb(0 0 0/0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:after\:left-full:after{content:var(--tw-content);left:100%}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:hover\:bg-sidebar:hover{background-color:hsl(var(--sidebar-background))}.peer\/menu-button[data-size=default]~.peer-data-\[size\=default\]\/menu-button\:top-1\.5{top:.375rem}.peer\/menu-button[data-size=lg]~.peer-data-\[size\=lg\]\/menu-button\:top-2\.5{top:.625rem}.peer\/menu-button[data-size=sm]~.peer-data-\[size\=sm\]\/menu-button\:top-1{top:.25rem}.peer[data-variant=inset]~.peer-data-\[variant\=inset\]\:min-h-\[calc\(100svh-theme\(spacing\.4\)\)\]{min-height:calc(100svh - 1rem)}.peer\/menu-button[data-active=true]~.peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground{color:hsl(var(--sidebar-accent-foreground))}.dark\:border-destructive:is(.dark *){border-color:hsl(var(--destructive))}@media (min-width:640px){.sm\:bottom-0{bottom:0}.sm\:right-0{right:0}.sm\:top-auto{top:auto}.sm\:mt-0{margin-top:0}.sm\:flex{display:flex}.sm\:max-w-sm{max-width:24rem}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2\.5{gap:.625rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.sm\:rounded-lg{border-radius:var(--radius)}.sm\:text-left{text-align:left}.data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state=open]{--tw-enter-translate-y:100%}}@media (min-width:768px){.md\:absolute{position:absolute}.md\:block{display:block}.md\:flex{display:flex}.md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{width:var(--radix-navigation-menu-viewport-width)}.md\:w-auto{width:auto}.md\:max-w-\[420px\]{max-width:420px}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:opacity-0{opacity:0}.after\:md\:hidden:after{content:var(--tw-content);display:none}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:m-2{margin:.5rem}.peer[data-state=collapsed][data-variant=inset]~.md\:peer-data-\[state\=collapsed\]\:peer-data-\[variant\=inset\]\:ml-2{margin-left:.5rem}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:ml-0{margin-left:0}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:rounded-xl{border-radius:.75rem}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0/0.1),0 1px 2px -1px rgb(0 0 0/0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}}@media (min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){background-color:hsl(var(--accent))}.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){background-color:hsl(var(--accent)/.5)}.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>button\]\:hidden>button{display:none}.\[\&\>span\:last-child\]\:truncate>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y:-3px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:left-4>svg{left:1rem}.\[\&\>svg\]\:top-4>svg{top:1rem}.\[\&\>svg\]\:size-4>svg{width:1rem;height:1rem}.\[\&\>svg\]\:h-2\.5>svg{height:.625rem}.\[\&\>svg\]\:h-3>svg{height:.75rem}.\[\&\>svg\]\:h-3\.5>svg{height:.875rem}.\[\&\>svg\]\:w-2\.5>svg{width:.625rem}.\[\&\>svg\]\:w-3>svg{width:.75rem}.\[\&\>svg\]\:w-3\.5>svg{width:.875rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-destructive>svg{color:hsl(var(--destructive))}.\[\&\>svg\]\:text-foreground>svg{color:hsl(var(--foreground))}.\[\&\>svg\]\:text-muted-foreground>svg{color:hsl(var(--muted-foreground))}.\[\&\>svg\]\:text-sidebar-accent-foreground>svg{color:hsl(var(--sidebar-accent-foreground))}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:1.75rem}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{--tw-rotate:90deg}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div,.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{--tw-rotate:180deg}.\[\&_\.recharts-cartesian-axis-tick_text\]\:fill-muted-foreground .recharts-cartesian-axis-tick text{fill:hsl(var(--muted-foreground))}.\[\&_\.recharts-cartesian-grid_line\[stroke\=\'\#ccc\'\]\]\:stroke-border\/50 .recharts-cartesian-grid line[stroke="#ccc"]{stroke:hsl(var(--border)/.5)}.\[\&_\.recharts-curve\.recharts-tooltip-cursor\]\:stroke-border .recharts-curve.recharts-tooltip-cursor{stroke:hsl(var(--border))}.\[\&_\.recharts-dot\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-dot[stroke="#fff"]{stroke:transparent}.\[\&_\.recharts-layer\]\:outline-none .recharts-layer{outline:2px solid transparent;outline-offset:2px}.\[\&_\.recharts-polar-grid_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-polar-grid [stroke="#ccc"]{stroke:hsl(var(--border))}.\[\&_\.recharts-radial-bar-background-sector\]\:fill-muted .recharts-radial-bar-background-sector,.\[\&_\.recharts-rectangle\.recharts-tooltip-cursor\]\:fill-muted .recharts-rectangle.recharts-tooltip-cursor{fill:hsl(var(--muted))}.\[\&_\.recharts-reference-line_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-reference-line [stroke="#ccc"]{stroke:hsl(var(--border))}.\[\&_\.recharts-sector\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-sector[stroke="#fff"]{stroke:transparent}.\[\&_\.recharts-sector\]\:outline-none .recharts-sector,.\[\&_\.recharts-surface\]\:outline-none .recharts-surface{outline:2px solid transparent;outline-offset:2px}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-top:.375rem;padding-bottom:.375rem}.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{font-size:.75rem;line-height:1rem}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{font-weight:500}.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{color:hsl(var(--muted-foreground))}.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden])~[cmdk-group]{padding-top:0}.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{height:1.25rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{width:1.25rem}.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{height:3rem}.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{padding-top:.75rem;padding-bottom:.75rem}.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{height:1.25rem}.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{width:1.25rem}.\[\&_p\]\:leading-relaxed p{line-height:1.625}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}[data-side=left][data-collapsible=offcanvas] .\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-right-2{right:-.5rem}[data-side=left][data-state=collapsed] .\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize{cursor:e-resize}[data-side=left] .\[\[data-side\=left\]_\&\]\:cursor-w-resize{cursor:w-resize}[data-side=right][data-collapsible=offcanvas] .\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-left-2{left:-.5rem}[data-side=right][data-state=collapsed] .\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize{cursor:w-resize}[data-side=right] .\[\[data-side\=right\]_\&\]\:cursor-e-resize{cursor:e-resize}