@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Noto+Sans+SC:wght@400;500;700&display=swap);*,: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:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height: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:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-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{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background:0 0% 100%;--foreground:220 14% 16%;--card:0 0% 100%;--card-foreground:220 14% 16%;--popover:0 0% 100%;--popover-foreground:220 14% 16%;--primary:221 83% 53%;--primary-foreground:0 0% 100%;--secondary:220 14% 96%;--secondary-foreground:220 14% 16%;--muted:220 14% 96%;--muted-foreground:220 9% 46%;--accent:221 83% 53%;--accent-foreground:0 0% 100%;--destructive:0 84% 60%;--destructive-foreground:0 0% 100%;--border:220 13% 91%;--input:220 13% 91%;--ring:221 83% 53%;--radius:0.5rem}*{border-color:#e5e7eb;border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:#23272f;color:hsl(var(--foreground))}[data-debug-wrapper=true]{display:contents!important}.\!container{width:100%!important}.container{width:100%}@media (min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.invisible{visibility:hidden}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.inset-y-0{bottom:0;top: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-4{right:1rem}.top-0{top:0}.top-1{top:.25rem}.top-1\/2{top:50%}.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-50{z-index:50}.z-\[100\]{z-index:100}.z-\[1\]{z-index:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-bottom:.25rem;margin-top:.25rem}.-ml-4{margin-left:-1rem}.-mt-4{margin-top:-1rem}.mb-1{margin-bottom:.25rem}.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-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}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.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}.max-h-\[--radix-context-menu-content-available-height\]{max-height:var(--radix-context-menu-content-available-height)}.max-h-\[--radix-select-content-available-height\]{max-height:var(--radix-select-content-available-height)}.max-h-\[300px\]{max-height:300px}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-screen{max-height:100vh}.min-h-\[60px\]{min-height:60px}.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-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[100px\]{width:100px}.w-\[1px\]{width:1px}.w-full{width:100%}.w-max{width:-webkit-max-content;width:max-content}.w-px{width:1px}.min-w-0{min-width:0}.min-w-10{min-width:2.5rem}.min-w-8{min-width:2rem}.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-lg{max-width:32rem}.max-w-max{max-width:-webkit-max-content;max-width:max-content}.flex-1{flex:1 1}.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}.origin-\[--radix-context-menu-content-transform-origin\]{transform-origin:var(--radix-context-menu-content-transform-origin)}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\[--radix-hover-card-content-transform-origin\]{transform-origin:var(--radix-hover-card-content-transform-origin)}.origin-\[--radix-menubar-content-transform-origin\]{transform-origin:var(--radix-menubar-content-transform-origin)}.origin-\[--radix-popover-content-transform-origin\]{transform-origin:var(--radix-popover-content-transform-origin)}.origin-\[--radix-select-content-transform-origin\]{transform-origin:var(--radix-select-content-transform-origin)}.origin-\[--radix-tooltip-content-transform-origin\]{transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-1\/2{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-1\/2{--tw-translate-y:-50%}.translate-x-\[-50\%\]{--tw-translate-x:-50%}.translate-x-\[-50\%\],.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-grab{cursor:grab}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;user-select:none}.list-none{list-style-type:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.375rem*var(--tw-space-y-reverse));margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - 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-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem;border-radius:var(--radius)}.rounded-md{border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(.5rem - 4px);border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.rounded-tl-sm{border-top-left-radius:calc(.5rem - 4px);border-top-left-radius:calc(var(--radius) - 4px)}.border{border-width:1px}.border-2{border-width:2px}.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-destructive{border-color:#ef4343;border-color:hsl(var(--destructive))}.border-destructive\/50{border-color:#ef434380;border-color:hsl(var(--destructive)/.5)}.border-input{border-color:#e5e7eb;border-color:hsl(var(--input))}.border-primary{border-color:#2463eb;border-color:hsl(var(--primary))}.border-transparent{border-color:#0000}.border-white{--tw-border-opacity:1;border-color:#fff;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-l-transparent{border-left-color:#0000}.border-t-transparent{border-top-color:#0000}.bg-accent{background-color:#2463eb;background-color:hsl(var(--accent))}.bg-background{background-color:#fff;background-color:hsl(var(--background))}.bg-black\/80{background-color:#000c}.bg-blue-500{--tw-bg-opacity:1;background-color:#3b82f6;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-border{background-color:#e5e7eb;background-color:hsl(var(--border))}.bg-card{background-color:#fff;background-color:hsl(var(--card))}.bg-destructive{background-color:#ef4343;background-color:hsl(var(--destructive))}.bg-foreground{background-color:#23272f;background-color:hsl(var(--foreground))}.bg-gray-300{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-muted{background-color:#f3f4f6;background-color:hsl(var(--muted))}.bg-muted\/50{background-color:#f3f4f680;background-color:hsl(var(--muted)/.5)}.bg-popover{background-color:#fff;background-color:hsl(var(--popover))}.bg-primary{background-color:#2463eb;background-color:hsl(var(--primary))}.bg-primary\/10{background-color:#2463eb1a;background-color:hsl(var(--primary)/.1)}.bg-primary\/20{background-color:#2463eb33;background-color:hsl(var(--primary)/.2)}.bg-secondary{background-color:#f3f4f6;background-color:hsl(var(--secondary))}.bg-transparent{background-color:initial}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.fill-current{fill:currentColor}.fill-primary{fill:#2463eb;fill:hsl(var(--primary))}.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\.5{padding-left:.375rem;padding-right:.375rem}.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-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.pb-4{padding-bottom:1rem}.pl-2{padding-left:.5rem}.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-6{padding-right:1.5rem}.pr-8{padding-right:2rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.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-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-accent-foreground{color:#fff;color:hsl(var(--accent-foreground))}.text-card-foreground{color:#23272f;color:hsl(var(--card-foreground))}.text-current{color:currentColor}.text-destructive{color:#ef4343;color:hsl(var(--destructive))}.text-destructive-foreground{color:#fff;color:hsl(var(--destructive-foreground))}.text-foreground{color:#23272f;color:hsl(var(--foreground))}.text-foreground\/50{color:#23272f80;color:hsl(var(--foreground)/.5)}.text-muted-foreground{color:#6b7280;color:hsl(var(--muted-foreground))}.text-popover-foreground{color:#23272f;color:hsl(var(--popover-foreground))}.text-primary{color:#2463eb;color:hsl(var(--primary))}.text-primary-foreground{color:#fff;color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:#23272f;color:hsl(var(--secondary-foreground))}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-\[0_2px_8px_rgba\(0\2c 0\2c 0\2c 0\.3\)\]{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-\[0_2px_8px_rgba\(0\2c 0\2c 0\2c 0\.3\)\]{--tw-shadow:0 2px 8px #0000004d;--tw-shadow-colored:0 2px 8px var(--tw-shadow-color)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-md{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid #0000;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),0 0 #0000;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(var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-1{--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),0 0 #0000;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-offset-background{--tw-ring-offset-color:hsl(var(--background))}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.drop-shadow,.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}@keyframes enter{0%{opacity:1;opacity:var(--tw-enter-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);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:1;opacity:var(--tw-exit-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);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{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.fade-in-0{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.duration-1000{animation-duration:1s}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.running{animation-play-state:running}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}[data-radix-slider-thumb]{background-color:#2563eb!important;border:3px solid #fff!important;box-shadow:0 2px 6px #00000059,0 0 0 1px #2563eb80!important;cursor:grab!important;height:20px!important;position:relative!important;width:20px!important;z-index:10!important}[data-radix-slider-thumb]:hover{background-color:#1d4ed8!important;transform:scale(1.1)!important}[data-radix-slider-thumb]:active{background-color:#1e40af!important;cursor:grabbing!important}[data-radix-slider-track]{background-color:#d1d5db!important;border-radius:4px!important;height:8px!important}[data-radix-slider-range]{border-radius:4px!important}[data-radix-slider-range],[data-state=checked]{background-color:#2563eb!important}::selection{background-color:#dbeafe;color:#1d4ed8}.app-footer{background:linear-gradient(135deg,#1e3a5f,#0f172a);border-top:1px solid #ffffff1a;color:#fff;margin-top:auto;padding:24px 16px;text-align:center}.footer-content{margin:0 auto;max-width:800px}.footer-title{color:#f0c674;font-size:16px;font-weight:600;letter-spacing:.5px;margin:0 0 8px}.footer-copyright{color:#ffffffb3;font-size:12px;line-height:1.5;margin:0}@media (max-width:768px){.app-footer{padding:20px 12px}.footer-title{font-size:14px}.footer-copyright{font-size:11px}}.auth-nav-buttons{gap:12px;margin-left:16px}.auth-nav-buttons,.login-link{align-items:center;display:flex}.login-link{background:#eff6ff;border:none;border-radius:8px;color:#2563eb;cursor:pointer;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s}.login-link:hover{background:#dbeafe}.admin-link{align-items:center;background:#f5f3ff;border:none;border-radius:8px;color:#7c3aed;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s}.admin-link:hover{background:#ede9fe}.user-menu{background:#f3f4f6;border-radius:8px;gap:8px;padding:6px 12px}.user-menu,.user-name-display{align-items:center;display:flex}.user-name-display{color:#374151;font-size:13px;font-weight:500;gap:6px}.logout-btn{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .2s;width:28px}.logout-btn:hover{background:#fef2f2;color:#ef4444}.app-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.app-loading .loading-icon{animation:spin 2s linear infinite;color:#2563eb}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.admin-link span,.auth-nav-buttons,.user-name-display span{display:none}}.mobile-header-auth{display:none}@media (max-width:768px){.mobile-header-auth{align-items:center;display:flex;gap:8px;position:absolute;right:16px;top:50%;transform:translateY(-50%)}.header{position:relative}}.mobile-header-login-btn{align-items:center;background:#2563eb;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 14px;transition:all .2s ease}.mobile-header-login-btn:hover{background:#1d4ed8}.mobile-header-user{align-items:center;display:flex;gap:6px}.mobile-header-admin-btn{align-items:center;background:#f5f3ff;border:none;border-radius:8px;color:#7c3aed;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.mobile-header-admin-btn:hover{background:#ede9fe}.mobile-header-logout-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.mobile-header-logout-btn:hover{background:#fef2f2;color:#ef4444}.file\:border-0::-webkit-file-upload-button{border-width:0}.file\:border-0::file-selector-button{border-width:0}.file\:bg-transparent::-webkit-file-upload-button{background-color:initial}.file\:bg-transparent::file-selector-button{background-color:initial}.file\:text-sm::-webkit-file-upload-button{font-size:.875rem;line-height:1.25rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::-webkit-file-upload-button{font-weight:500}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::-webkit-file-upload-button{color:#23272f;color:hsl(var(--foreground))}.file\:text-foreground::file-selector-button{color:#23272f;color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::placeholder{color:#6b7280;color:hsl(var(--muted-foreground))}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:inset-y-0:after{bottom:0;content:var(--tw-content);top:0}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-1:after{content:var(--tw-content);width:.25rem}.after\:-translate-x-1\/2:after{--tw-translate-x:-50%;content:var(--tw-content);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-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.first\:border-l:first-child{border-left-width:1px}.last\:rounded-r-md:last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.focus-within\:relative:focus-within{position:relative}.focus-within\:z-20:focus-within{z-index:20}.hover\:scale-110:hover{--tw-scale-x:1.1;--tw-scale-y:1.1;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))}.hover\:bg-accent:hover{background-color:#2463eb;background-color:hsl(var(--accent))}.hover\:bg-blue-600:hover{--tw-bg-opacity:1;background-color:#2563eb;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.hover\:bg-destructive\/80:hover{background-color:#ef4343cc;background-color:hsl(var(--destructive)/.8)}.hover\:bg-destructive\/90:hover{background-color:#ef4343e6;background-color:hsl(var(--destructive)/.9)}.hover\:bg-muted:hover{background-color:#f3f4f6;background-color:hsl(var(--muted))}.hover\:bg-muted\/50:hover{background-color:#f3f4f680;background-color:hsl(var(--muted)/.5)}.hover\:bg-primary:hover{background-color:#2463eb;background-color:hsl(var(--primary))}.hover\:bg-primary\/80:hover{background-color:#2463ebcc;background-color:hsl(var(--primary)/.8)}.hover\:bg-primary\/90:hover{background-color:#2463ebe6;background-color:hsl(var(--primary)/.9)}.hover\:bg-secondary:hover{background-color:#f3f4f6;background-color:hsl(var(--secondary))}.hover\:bg-secondary\/80:hover{background-color:#f3f4f6cc;background-color:hsl(var(--secondary)/.8)}.hover\:text-accent-foreground:hover{color:#fff;color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:#23272f;color:hsl(var(--foreground))}.hover\:text-muted-foreground:hover{color:#6b7280;color:hsl(var(--muted-foreground))}.hover\:text-primary-foreground:hover{color:#fff;color:hsl(var(--primary-foreground))}.hover\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:bg-accent:focus{background-color:#2463eb;background-color:hsl(var(--accent))}.focus\:bg-primary:focus{background-color:#2463eb;background-color:hsl(var(--primary))}.focus\:text-accent-foreground:focus{color:#fff;color:hsl(var(--accent-foreground))}.focus\:text-primary-foreground:focus{color:#fff;color:hsl(var(--primary-foreground))}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-1: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(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-1:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.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)}.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 #0000;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),0 0 #0000;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),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-blue-400:focus-visible{--tw-ring-opacity:1;--tw-ring-color:rgb(96 165 250/var(--tw-ring-opacity,1))}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:hsl(var(--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\:cursor-grabbing:active{cursor:grabbing}.active\:bg-blue-700:active{--tw-bg-opacity:1;background-color:#1d4ed8;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}.group.destructive .group-\[\.destructive\]\:border-muted\/40{border-color:#f3f4f666;border-color:hsl(var(--muted)/.4)}.group.toaster .group-\[\.toaster\]\:border-border{border-color:#e5e7eb;border-color:hsl(var(--border))}.group.toast .group-\[\.toast\]\:bg-muted{background-color:#f3f4f6;background-color:hsl(var(--muted))}.group.toast .group-\[\.toast\]\:bg-primary{background-color:#2463eb;background-color:hsl(var(--primary))}.group.toaster .group-\[\.toaster\]\:bg-background{background-color:#fff;background-color:hsl(var(--background))}.group.destructive .group-\[\.destructive\]\:text-red-300{--tw-text-opacity:1;color:#fca5a5;color:rgb(252 165 165/var(--tw-text-opacity,1))}.group.toast .group-\[\.toast\]\:text-muted-foreground{color:#6b7280;color:hsl(var(--muted-foreground))}.group.toast .group-\[\.toast\]\:text-primary-foreground{color:#fff;color:hsl(var(--primary-foreground))}.group.toaster .group-\[\.toaster\]\:text-foreground{color:#23272f;color:hsl(var(--foreground))}.group.toaster .group-\[\.toaster\]\:shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);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:#ef43434d;border-color:hsl(var(--destructive)/.3)}.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{background-color:#ef4343;background-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{color:#fff;color:hsl(var(--destructive-foreground))}.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{--tw-text-opacity:1;color:#fef2f2;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:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\:disabled\]\:opacity-50:has(:disabled){opacity:.5}.aria-selected\:bg-accent[aria-selected=true]{background-color:#2463eb;background-color:hsl(var(--accent))}.aria-selected\:bg-accent\/50[aria-selected=true]{background-color:#2463eb80;background-color:hsl(var(--accent)/.5)}.aria-selected\:text-accent-foreground[aria-selected=true]{color:#fff;color:hsl(var(--accent-foreground))}.aria-selected\:text-muted-foreground[aria-selected=true]{color:#6b7280;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-\[selected\=true\]\:bg-accent[data-selected=true]{background-color:#2463eb;background-color:hsl(var(--accent))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:#fff;background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-blue-600[data-state=checked]{--tw-bg-opacity:1;background-color:#2563eb;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#2463eb;background-color:hsl(var(--primary))}.data-\[state\=on\]\:bg-accent[data-state=on],.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:#2463eb;background-color:hsl(var(--accent))}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:#2463eb80;background-color:hsl(var(--accent)/.5)}.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:#f3f4f6;background-color:hsl(var(--secondary))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:#f3f4f6;background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-gray-300[data-state=unchecked]{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:#6b7280;color:hsl(var(--muted-foreground))}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{color:#fff;color:hsl(var(--accent-foreground))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:#23272f;color:hsl(var(--foreground))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:#fff;color:hsl(var(--primary-foreground))}.data-\[state\=on\]\:text-accent-foreground[data-state=on],.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:#fff;color:hsl(var(--accent-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:#6b7280;color:hsl(var(--muted-foreground))}.data-\[disabled\=true\]\:opacity-50[data-disabled=true],.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=active\]\:shadow[data-state=active]{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);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]{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.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]{--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial;animation-duration:.15s;animation-name:exit}.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{--tw-translate-y:-50%;content:var(--tw-content);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{--tw-translate-x:0px;content:var(--tw-content);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\]\:focus\:bg-accent:focus[data-state=open],.data-\[state\=open\]\:hover\:bg-accent:hover[data-state=open]{background-color:#2463eb;background-color:hsl(var(--accent))}.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))}.dark\:border-destructive:is(.dark *){border-color:#ef4343;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\: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-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.sm\:rounded-lg{border-radius:.5rem;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\: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\:text-sm{font-size:.875rem;line-height:1.25rem}}.\[\&\+div\]\:text-xs+div{font-size:.75rem;line-height:1rem}.\[\&\:has\(\>\.day-range-end\)\]\:rounded-r-md:has(>.day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\>\.day-range-start\)\]\:rounded-l-md:has(>.day-range-start){border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:rounded-md:has([aria-selected]){border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){background-color:#2463eb;background-color:hsl(var(--accent))}.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){background-color:#2463eb80;background-color:hsl(var(--accent)/.5)}.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\]>[role=checkbox]{--tw-translate-y:2px;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))}.\[\&\>span\]\:line-clamp-1>span{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden}.\[\&\>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{height:1rem;width:1rem}.\[\&\>svg\]\:h-3\.5>svg{height:.875rem}.\[\&\>svg\]\:w-3\.5>svg{width:.875rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-destructive>svg{color:#ef4343;color:hsl(var(--destructive))}.\[\&\>svg\]\:text-foreground>svg{color:#23272f;color:hsl(var(--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}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-bottom:.375rem;padding-top:.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:#6b7280;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-bottom:.75rem;padding-top:.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{height:1rem;width: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}:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#dbeafe;--text-primary:#1f2937;--text-secondary:#6b7280;--text-muted:#9ca3af;--bg-white:#fff;--bg-gray:#f9fafb;--bg-light:#f3f4f6;--border-color:#e5e7eb;--border-dark:#d1d5db;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-full:9999px}*{box-sizing:border-box;margin:0;padding:0}body{background:#fff;background:var(--bg-white);color:#1f2937;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.app-container{display:flex;flex-direction:column;min-height:100vh}.header{background:#fff;background:var(--bg-white);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);justify-content:space-between;padding:16px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header,.header-left{align-items:center;display:flex}.header-left{gap:12px}.header-icon{color:#2563eb;color:var(--primary);height:32px;width:32px}.header-title{color:#1f2937;color:var(--text-primary);font-size:18px;font-weight:600;letter-spacing:-.02em}.header-subtitle{color:#9ca3af;color:var(--text-muted);font-size:12px}.header-nav{gap:8px}.header-nav,.nav-link{align-items:center;display:flex}.nav-link{border-radius:9999px;border-radius:var(--radius-full);color:#6b7280;color:var(--text-secondary);font-size:14px;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:background-color .2s,color .2s}.nav-link:hover{background:#f3f4f6;background:var(--bg-light);color:#1f2937;color:var(--text-primary)}.nav-link.active{background:#dbeafe;background:var(--primary-light);color:#2563eb;color:var(--primary)}.nav-link-primary{background:#2563eb!important;background:var(--primary)!important;color:#fff!important;font-weight:600}.nav-link-primary:hover{background:#1d4ed8!important;background:var(--primary-hover)!important;color:#fff!important}.header-hint{align-items:center;background:#f3f4f6;background:var(--bg-light);border-radius:9999px;border-radius:var(--radius-full);color:#6b7280;color:var(--text-secondary);display:flex;font-size:12px;gap:6px;padding:6px 12px}.project-selector-bar{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2d4a6f);border-bottom:1px solid #ffffff1a;display:flex;justify-content:space-between;padding:8px 24px}.project-selector-left{align-items:center;display:flex;gap:12px}.project-label{color:#ffffffb3;font-size:13px;font-weight:500}.project-dropdown-wrapper{position:relative}.project-dropdown-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;min-width:180px;padding:8px 14px;transition:all .15s}.project-dropdown-btn:hover{background:#ffffff26;border-color:#ffffff4d}.project-dropdown-menu{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;left:0;overflow:hidden;position:absolute;top:calc(100% + 8px);width:280px;z-index:100}.project-dropdown-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#6b7280;display:flex;font-size:12px;font-weight:600;justify-content:space-between;padding:12px 16px;text-transform:uppercase}.project-new-btn{background:#2563eb;background:var(--primary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:11px;font-weight:600;padding:4px 10px}.project-new-btn:hover{background:#1d4ed8;background:var(--primary-hover)}.project-dropdown-list{max-height:240px;overflow-y:auto}.project-dropdown-item{align-items:center;background:#0000;border:none;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:0;text-align:left;transition:background-color .15s;width:100%}.project-dropdown-item:hover{background:#f9fafb}.project-dropdown-item.active{background:#eff6ff}.project-item-clickable{align-items:center;cursor:pointer;display:flex;flex:1 1;justify-content:space-between;padding:12px 12px 12px 16px}.project-item-info{display:flex;flex-direction:column;gap:2px}.project-item-name{color:#1f2937;font-size:14px;font-weight:500}.project-item-date{color:#9ca3af;font-size:11px}.project-item-check{background:#2563eb;background:var(--primary);border-radius:50%;color:#fff;font-size:12px;height:20px;width:20px}.project-item-check,.project-item-delete{align-items:center;display:flex;justify-content:center}.project-item-delete{background:#0000;border:none;border-left:1px solid #f3f4f6;color:#9ca3af;cursor:pointer;height:100%;padding:12px 8px;transition:all .15s;width:32px}.project-item-delete:hover{background:#fee2e2;color:#ef4444}.project-dropdown-empty{color:#9ca3af;font-size:13px;padding:24px 16px;text-align:center}.project-selector-right{align-items:center;display:flex;gap:8px}.project-action-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .15s}.project-action-btn:hover{background:#fff3}.hero-section{margin:0 auto;max-width:800px;padding:48px 32px 32px;text-align:center}.hero-title{color:#1f2937;color:var(--text-primary);font-size:36px;font-weight:700;letter-spacing:-.03em;line-height:1.2;margin-bottom:16px}.hero-highlight{color:#2563eb;color:var(--primary)}.hero-description{color:#6b7280;color:var(--text-secondary);font-size:16px;line-height:1.7;margin:0 auto 32px;max-width:600px}.features-row{display:flex;flex-wrap:wrap;gap:24px;justify-content:center}.feature-item{align-items:center;background:#f9fafb;background:var(--bg-gray);border-radius:9999px;border-radius:var(--radius-full);color:#6b7280;color:var(--text-secondary);display:flex;font-size:14px;gap:8px;padding:8px 16px}.feature-icon{font-size:16px}.main-content{align-items:center;display:flex;flex:1 1;flex-direction:column;padding:24px 32px;position:relative}.main-content.with-image{padding:0}.canvas-wrapper{background:#fff;background:var(--bg-white);border:2px dashed #d1d5db;border:2px dashed var(--border-dark);border-radius:12px;border-radius:var(--radius-lg);height:500px;max-width:800px;overflow:visible;position:relative;transition:all .3s ease;width:100%}.canvas-wrapper.expanded{border:none;border-radius:0;height:calc(100vh - 80px);max-width:100%}.compass-overlay{border-radius:50%;overflow:visible;pointer-events:auto;position:absolute;transition:box-shadow .2s ease;z-index:10}.compass-overlay svg{overflow:visible}.compass-overlay.locked{cursor:not-allowed!important}.compass-lock-badge{align-items:center;border-radius:50%;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:-8px;top:-8px;transition:all .2s ease;width:28px;z-index:20}.compass-lock-badge.unlocked{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-color);color:#6b7280;color:var(--text-secondary)}.compass-lock-badge.unlocked:hover{background:#f3f4f6;background:var(--bg-light);color:#2563eb;color:var(--primary)}.compass-lock-badge.locked{background:#dc2626;border:1px solid #dc2626;color:#fff}.compass-lock-badge.locked:hover{background:#b91c1c}.compass-list-panel{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg);left:16px;overflow:hidden;position:fixed;top:100px;-webkit-user-select:none;user-select:none;width:200px;z-index:30}.panel-drag-handle{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;cursor:grab;display:flex;font-size:11px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.panel-drag-handle:active{cursor:grabbing}.drag-handle-dots{display:flex;flex-direction:column;gap:2px}.drag-handle-dots span{background:#fff9;border-radius:50%;display:block;height:3px;width:3px}.compass-list-header{align-items:center;background:#f9fafb;background:var(--bg-gray);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);color:#1f2937;color:var(--text-primary);display:flex;font-size:13px;font-weight:600;justify-content:space-between;padding:12px 16px}.add-compass-btn{align-items:center;background:#2563eb;background:var(--primary);border:none;border-radius:9999px;border-radius:var(--radius-full);color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;transition:background-color .2s;width:28px}.add-compass-btn:hover{background:#1d4ed8;background:var(--primary-hover)}.floor-plan-section{padding-bottom:8px}.floor-plan-controls-row{align-items:center;display:flex;gap:4px;justify-content:space-around;padding:8px 12px}.floor-ctrl-btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:8px;color:#2563eb;color:var(--primary);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s;width:32px}.floor-ctrl-btn:hover:not(:disabled){background:#dbeafe;background:var(--primary-light);border-color:#2563eb;border-color:var(--primary)}.floor-ctrl-btn:disabled{cursor:not-allowed;opacity:.4}.floor-ctrl-btn.locked{background:#fee2e2;border-color:#dc2626;color:#dc2626}.floor-ctrl-btn.center{color:#059669}.floor-ctrl-btn.center:hover:not(:disabled){background:#d1fae5;border-color:#059669}.floor-ctrl-btn.delete{color:#ef4444}.floor-ctrl-btn.delete:hover:not(:disabled){background:#fee2e2;border-color:#ef4444}.compass-list{max-height:300px;overflow-y:auto}.compass-list-item{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;justify-content:space-between;padding:10px 16px;transition:background-color .15s}.compass-list-item:last-child{border-bottom:none}.compass-list-item:hover{background:#f3f4f6;background:var(--bg-light)}.compass-list-item.selected{background:#dbeafe;background:var(--primary-light)}.compass-name{color:#1f2937;color:var(--text-primary);font-size:13px;font-weight:500}.compass-item-actions{align-items:center;display:flex;gap:6px}.compass-item-actions button{align-items:center;background:#0000;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);cursor:pointer;display:flex;height:24px;justify-content:center;transition:all .15s;width:24px}.compass-item-actions button:hover{background:#f3f4f6;background:var(--bg-light);color:#1f2937;color:var(--text-primary)}.compass-item-actions .lock-btn.locked{background:#fef2f2;border-color:#fecaca;color:#dc2626}.compass-item-actions .star-btn.active,.compass-item-actions .star-btn:hover{background:#f3e8ff;border-color:#c084fc;color:#9333ea}.compass-item-actions .center-btn:hover{background:#ecfdf5;border-color:#6ee7b7;color:#059669}.compass-item-actions .delete-btn:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.main-door-marker{align-items:center;display:flex;flex-direction:column;position:absolute;transform-origin:center center;-webkit-user-select:none;user-select:none;z-index:15}.main-door-circle{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:4px solid #fff;border-radius:50%;box-shadow:0 4px 12px #2563eb66,0 0 0 2px #2563eb;color:#fff;display:flex;height:60px;justify-content:center;position:relative;transition:box-shadow .2s;width:60px}.main-door-marker:hover .main-door-circle{box-shadow:0 6px 16px #2563eb80,0 0 0 3px #2563eb;transform:scale(1.05)}.main-door-label{background:#2563eb;border-radius:12px;box-shadow:0 2px 6px #2563eb4d;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:4px 12px;white-space:nowrap}.main-door-rotation-label{background:#ffffffe6;border-radius:8px;color:#1e40af;font-size:10px;font-weight:600;margin-top:4px;padding:2px 8px}.door-rotation-handle{align-items:center;background:linear-gradient(135deg,#f97316,#ea580c);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #f9731666;color:#fff;cursor:grab;display:flex;height:24px;justify-content:center;position:absolute;right:-12px;top:-12px;transition:transform .15s,box-shadow .15s;width:24px;z-index:5}.door-rotation-handle:hover{box-shadow:0 4px 12px #f9731680;transform:scale(1.15)}.door-rotation-handle:active{cursor:grabbing;transform:scale(1.1)}.main-door-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.add-main-door-btn,.main-door-item{align-items:center;display:flex}.add-main-door-btn{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px dashed #2563eb;border-radius:0;color:#2563eb;cursor:pointer;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s;width:100%}.add-main-door-btn:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.north-marker{flex-direction:column;position:absolute;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none;z-index:15}.north-circle,.north-marker{align-items:center;display:flex}.north-circle{background:linear-gradient(135deg,#dc2626,#b91c1c);border:4px solid #fff;border-radius:50%;box-shadow:0 4px 12px #dc262666,0 0 0 2px #dc2626;height:60px;justify-content:center;transition:transform .2s,box-shadow .2s;width:60px}.north-marker:hover .north-circle{box-shadow:0 6px 16px #dc262680,0 0 0 3px #dc2626;transform:scale(1.05)}.north-letter{color:#fff;font-family:Georgia,serif;font-size:28px;font-weight:800;text-shadow:0 2px 4px #0003}.north-label{background:#dc2626;border-radius:12px;box-shadow:0 2px 6px #dc26264d;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:4px 12px;white-space:nowrap}.north-arrow{border-left:15px solid #0000;border-right:15px solid #0000;border-top:25px solid #dc2626;filter:drop-shadow(0 2px 4px rgba(220,38,38,.4));height:0;margin-top:6px;width:0}.north-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.add-north-btn{align-items:center;background:linear-gradient(135deg,#fef2f2,#fecaca);border:1px dashed #dc2626;border-radius:0;color:#dc2626;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s;width:100%}.add-north-btn:hover{background:linear-gradient(135deg,#fecaca,#fca5a5)}.water-element-marker{align-items:center;display:flex;flex-direction:column;position:absolute;-webkit-user-select:none;user-select:none;z-index:15}.water-element-circle{align-items:center;border-radius:50%;box-shadow:0 4px 12px #2563eb66,0 0 0 2px #c9a227;display:flex;justify-content:center;overflow:hidden;transition:transform .2s,box-shadow .2s}.water-element-marker:hover .water-element-circle{box-shadow:0 6px 16px #2563eb80,0 0 0 3px #c9a227;transform:scale(1.05)}.water-element-label{background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:12px;box-shadow:0 2px 6px #2563eb4d;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:4px 12px;white-space:nowrap}.water-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.water-item{background:linear-gradient(135deg,#eff6ff,#dbeafe)!important}.add-water-btn{align-items:center;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px dashed #2563eb;border-radius:0;color:#2563eb;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s;width:100%}.add-water-btn:hover{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.wood-element-marker{align-items:center;display:flex;flex-direction:column;position:absolute;-webkit-user-select:none;user-select:none;z-index:15}.wood-element-circle{align-items:center;border-radius:50%;box-shadow:0 4px 12px #16a34a66,0 0 0 2px #c9a227;display:flex;justify-content:center;overflow:hidden;transition:transform .2s,box-shadow .2s}.wood-element-marker:hover .wood-element-circle{box-shadow:0 6px 16px #16a34a80,0 0 0 3px #c9a227;transform:scale(1.05)}.wood-element-label{background:linear-gradient(135deg,#16a34a,#15803d);border-radius:12px;box-shadow:0 2px 6px #16a34a4d;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:4px 12px;white-space:nowrap}.wood-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.wood-item{background:linear-gradient(135deg,#f0fdf4,#dcfce7)!important}.add-wood-btn{align-items:center;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px dashed #16a34a;border-radius:0;color:#16a34a;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s;width:100%}.add-wood-btn:hover{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.fire-element-marker{align-items:center;display:flex;flex-direction:column;position:absolute;-webkit-user-select:none;user-select:none;z-index:15}.fire-element-circle{align-items:center;border-radius:50%;box-shadow:0 4px 12px #dc262666,0 0 0 2px #c9a227;display:flex;justify-content:center;overflow:hidden;transition:transform .2s,box-shadow .2s}.fire-element-marker:hover .fire-element-circle{box-shadow:0 6px 16px #dc262680,0 0 0 3px #c9a227;transform:scale(1.05)}.fire-element-label{background:linear-gradient(135deg,#dc2626,#b91c1c);border-radius:12px;box-shadow:0 2px 6px #dc26264d;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:4px 12px;white-space:nowrap}.fire-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.fire-item{background:linear-gradient(135deg,#fef2f2,#fecaca)!important}.add-fire-btn{align-items:center;background:linear-gradient(135deg,#fef2f2,#fecaca);border:1px dashed #dc2626;border-radius:0;color:#dc2626;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s;width:100%}.add-fire-btn:hover{background:linear-gradient(135deg,#fecaca,#fca5a5)}.earth-element-marker{align-items:center;display:flex;flex-direction:column;position:absolute;-webkit-user-select:none;user-select:none;z-index:15}.earth-element-circle{align-items:center;border-radius:50%;box-shadow:0 4px 12px #92400e66,0 0 0 2px #c9a227;display:flex;justify-content:center;overflow:hidden;transition:transform .2s,box-shadow .2s}.earth-element-marker:hover .earth-element-circle{box-shadow:0 6px 16px #92400e80,0 0 0 3px #c9a227;transform:scale(1.05)}.earth-element-label{background:linear-gradient(135deg,#92400e,#78350f);border-radius:12px;box-shadow:0 2px 6px #92400e4d;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:4px 12px;white-space:nowrap}.earth-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.earth-item{background:linear-gradient(135deg,#fef3c7,#fde68a)!important}.add-earth-btn{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px dashed #92400e;border-radius:0;color:#92400e;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s;width:100%}.add-earth-btn:hover{background:linear-gradient(135deg,#fde68a,#fcd34d)}.metal-element-marker{align-items:center;display:flex;flex-direction:column;position:absolute;-webkit-user-select:none;user-select:none;z-index:15}.metal-element-circle{align-items:center;border-radius:50%;box-shadow:0 4px 12px #6b728066,0 0 0 2px #9ca3af;display:flex;justify-content:center;overflow:hidden;transition:transform .2s,box-shadow .2s}.metal-element-marker:hover .metal-element-circle{box-shadow:0 6px 16px #6b728080,0 0 0 3px #9ca3af;transform:scale(1.05)}.metal-element-label{background:linear-gradient(135deg,#6b7280,#4b5563);border-radius:12px;box-shadow:0 2px 6px #6b72804d;color:#fff;font-size:11px;font-weight:700;letter-spacing:.5px;margin-top:8px;padding:4px 12px;white-space:nowrap}.metal-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.metal-item{background:linear-gradient(135deg,#f3f4f6,#e5e7eb)!important}.add-metal-btn{align-items:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border:1px dashed #6b7280;border-radius:0;color:#6b7280;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s;width:100%}.add-metal-btn:hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db)}.elements-section{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color)}.element-icon{align-items:center;border-radius:50%;color:#fff;display:inline-flex;flex-shrink:0;font-size:10px;font-weight:700;height:18px;justify-content:center;margin-right:6px;width:18px}.element-item{padding:8px 12px!important}.element-control-item{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);padding:8px 12px}.element-control-item.water-item{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.element-control-item.wood-item{background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.element-control-item.fire-item{background:linear-gradient(135deg,#fef2f2,#fecaca)}.element-control-item.earth-item{background:linear-gradient(135deg,#fef3c7,#fde68a)}.element-control-item.metal-item{background:linear-gradient(135deg,#f3f4f6,#e5e7eb)}.element-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.element-controls{display:flex;flex-direction:column;gap:4px}.element-slider{align-items:center;color:#6b7280;display:flex;font-size:11px;gap:8px}.element-slider span:first-child{flex-shrink:0;width:40px}.element-slider span:last-child{flex-shrink:0;text-align:right;width:32px}.element-slider input[type=range]{-webkit-appearance:none;appearance:none;background:#d1d5db;border-radius:2px;cursor:pointer;flex:1 1;height:4px}.element-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#3b82f6;border-radius:50%;cursor:pointer;height:12px;width:12px}.element-slider input[type=range]:disabled{cursor:not-allowed;opacity:.5}.add-elements-grid{background:#f9fafb;display:flex;flex-wrap:nowrap;gap:6px;justify-content:flex-start;padding:10px 12px}.add-element-btn{align-items:center;background:#fff;border:1px dashed #d1d5db;border-radius:8px;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s;width:32px}.add-element-btn:hover{border-color:#9ca3af;box-shadow:0 2px 8px #0000001a;transform:scale(1.1)}.add-element-btn .element-icon{margin-right:0}.add-elements-row{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;gap:8px;padding:8px 12px}.add-elements-row .row-label{color:#6b7280;flex-shrink:0;font-size:11px;width:36px}.add-elements-row .add-elements-grid{background:#0000;flex:1 1;padding:0}.add-text-btn{align-items:center;background:#fff;border:1px dashed #d1d5db;border-radius:8px;cursor:pointer;display:flex;height:32px;justify-content:center;min-width:32px;padding:0 6px;transition:all .2s}.add-text-btn:hover{border-color:#9ca3af;box-shadow:0 2px 8px #0000001a;transform:scale(1.05)}.text-label-marker{align-items:center;display:flex;justify-content:center;position:absolute;transition:transform .2s;-webkit-user-select:none;user-select:none;z-index:16}.text-label-marker:hover{filter:brightness(1.1)}.text-label-text{align-items:center;border-radius:20px;box-shadow:0 4px 12px #0003;color:#fff!important;display:inline-flex;font-weight:700;justify-content:center;letter-spacing:2px;line-height:1;padding:6px 14px;text-align:center;text-shadow:0 1px 2px #0003;white-space:nowrap}.locked-indicator{align-items:center;background:#fef2f2;border-radius:9999px;border-radius:var(--radius-full);color:#dc2626;display:flex;font-size:12px;font-weight:500;gap:4px;margin-left:8px;padding:4px 10px}.rotation-badge{align-items:center;background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:9999px;border-radius:var(--radius-full);bottom:24px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg);display:flex;gap:12px;left:50%;padding:12px 24px;position:fixed;transform:translateX(-50%);z-index:50}.rotation-degree{color:#2563eb;color:var(--primary);font-size:20px;font-weight:700}.rotation-direction{color:#6b7280;color:var(--text-secondary);font-family:Noto Sans SC,sans-serif;font-size:14px}.rotation-direction.rotation-24mtn{background:linear-gradient(135deg,#f3e8ff,#ede9fe);border-radius:8px;color:#7c3aed;font-size:16px;font-weight:600;padding:4px 12px}.direction-mode-toggle{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd;border-radius:6px;color:#1d4ed8;cursor:pointer;font-family:Noto Sans SC,sans-serif;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s}.direction-mode-toggle:hover{background:linear-gradient(135deg,#bfdbfe,#93c5fd);transform:scale(1.05)}.how-it-works{background:#f9fafb;background:var(--bg-gray);padding:48px 32px;width:100%}.section-title{color:#1f2937;color:var(--text-primary);font-size:24px;font-weight:600;margin-bottom:32px;text-align:center}.steps-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin:0 auto;max-width:1000px}.step-card{background:#fff;background:var(--bg-white);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:12px;border-radius:var(--radius-lg);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);padding:24px}.step-number{align-items:center;background:#2563eb;background:var(--primary);border-radius:9999px;border-radius:var(--radius-full);color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;margin-bottom:16px;width:32px}.step-card h4{color:#1f2937;color:var(--text-primary);font-size:16px;font-weight:600;margin-bottom:8px}.step-card p{color:#6b7280;color:var(--text-secondary);font-size:14px;line-height:1.6}.footer{background:#fff;background:var(--bg-white);border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);padding:24px 32px;text-align:center}.footer p{color:#9ca3af;color:var(--text-muted);font-size:13px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--bg-light)}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--border-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--text-muted)}.mobile-control-toggle,.mobile-enter-plotter-btn,.mobile-panel-toggle{display:none}@media (max-width:768px){.mobile-enter-plotter-btn{background:linear-gradient(135deg,#1e40af,#3b82f6);border:none;border-radius:12px;box-shadow:0 4px 12px #1e40af4d;color:#fff;cursor:pointer;display:block;font-size:16px;font-weight:600;margin:24px auto 0;max-width:300px;padding:14px 24px;transition:all .2s;width:100%}.mobile-enter-plotter-btn:hover{box-shadow:0 6px 16px #1e40af66;transform:translateY(-2px)}.header{flex-wrap:wrap;gap:12px;padding:12px 16px}.header-hint,.header-nav{display:none}.hero-section{padding:32px 16px 24px}.hero-title{font-size:28px}.features-row{gap:12px}.feature-item{font-size:12px;padding:6px 12px}.main-content{padding:16px}.canvas-wrapper{height:400px}.canvas-wrapper.expanded{height:calc(100vh - 70px);min-height:400px}.rotation-badge{bottom:16px;padding:8px 16px}.rotation-degree{font-size:16px}.how-it-works{padding:32px 16px}.steps-grid{gap:16px}.compass-list-panel{border-radius:16px 16px 0 0;bottom:0!important;box-shadow:0 -4px 20px #0003;left:0!important;max-height:60vh;overflow:hidden;position:fixed!important;right:0!important;top:auto!important;transform:translateY(calc(100% - 56px));transition:transform .3s ease;width:100%!important;z-index:100}.compass-list-panel.expanded{overflow-y:auto;transform:translateY(0)}.mobile-panel-toggle{align-items:center;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:16px 16px 0 0;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;height:56px;justify-content:center;position:relative}.mobile-panel-toggle:before{background:#fff6;border-radius:2px;content:"";height:4px;left:50%;position:absolute;top:8px;transform:translateX(-50%);width:40px}.panel-drag-handle{display:none}.compass-list-header{font-size:14px;padding:12px 16px}.compass-list-item,.element-control-item{padding:12px 16px}.element-slider{font-size:12px}.element-slider input[type=range]{height:8px}.element-slider input[type=range]::-webkit-slider-thumb{height:20px;width:20px}.add-elements-row{padding:12px 16px}.add-element-btn,.add-text-btn{height:40px;min-width:40px;width:40px}.compass-item-actions{gap:8px}.compass-item-actions button{height:32px;min-width:32px;width:32px}.compass-item-actions button svg{height:16px;width:16px}.floor-plan-controls-row{gap:8px}.floor-ctrl-btn{height:40px;width:40px}.earth-element-marker,.fire-element-marker,.floor-plan-canvas,.main-door-marker,.metal-element-marker,.north-marker,.text-label-marker,.water-element-marker,.wood-element-marker{touch-action:none}.earth-element-circle,.fire-element-circle,.metal-element-circle,.water-element-circle,.wood-element-circle{min-height:50px;min-width:50px}.project-selector-bar{flex-wrap:wrap;gap:8px;padding:8px 12px}.project-selector-left{width:100%}.project-selector-right{justify-content:space-between;width:100%}.control-panel-wrapper{height:100%!important;position:fixed!important;right:-320px!important;top:0!important;transition:right .3s ease;width:auto;z-index:99!important}.control-panel-wrapper.show-panel{right:0!important}.mobile-control-toggle{align-items:center;background:linear-gradient(135deg,#1e40af,#3b82f6);border-radius:8px 0 0 8px;box-shadow:-2px 0 8px #00000026;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:600;height:60px;justify-content:center;position:fixed;right:8px;top:50%;transform:translateY(-50%);width:36px;writing-mode:vertical-rl;z-index:98}}@media (max-width:480px){.compass-list-panel{max-height:70vh}.add-elements-grid{gap:6px}.add-element-btn,.add-text-btn{height:36px;min-width:36px;width:36px}.element-icon{font-size:9px;height:16px;width:16px}.row-label{font-size:10px!important;width:32px!important}.header-title{font-size:14px}.header-subtitle{font-size:10px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hero-section,.step-card{animation:fadeIn .5s ease-out}.step-card{animation-fill-mode:both}.step-card:first-child{animation-delay:.1s}.step-card:nth-child(2){animation-delay:.2s}.step-card:nth-child(3){animation-delay:.3s}.step-card:nth-child(4){animation-delay:.4s}.nav-link,button{transition:transform .15s ease,background-color .2s ease}.nav-link:hover,button:hover:not(:disabled){transform:translateY(-1px)}.nav-link:active,button:active:not(:disabled){transform:translateY(0)}[data-sonner-toast]{font-family:Inter,sans-serif!important}.auth-container{align-items:center;background:linear-gradient(135deg,#f5f7fa,#e4e8eb);display:flex;justify-content:center;min-height:100vh;padding:20px}.auth-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;max-width:420px;padding:40px;width:100%}.auth-card.register-card{max-width:480px}.auth-header{margin-bottom:32px;text-align:center}.auth-logo{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border-radius:16px;color:#fff;display:inline-flex;height:72px;justify-content:center;margin-bottom:20px;width:72px}.auth-header h1{color:#1f2937;font-size:24px;font-weight:700;margin:0 0 8px}.auth-header p{color:#6b7280;font-size:14px;margin:0}.auth-form{gap:20px}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{color:#374151;font-size:13px;font-weight:600}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:#9ca3af;left:14px;pointer-events:none;position:absolute}.form-group input,.form-group select{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;font-size:14px;outline:none;padding:12px 14px;transition:all .2s ease;width:100%}.input-wrapper input{padding-left:44px;padding-right:44px}.form-group input:focus,.form-group select:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.password-toggle{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px}.password-toggle:hover{color:#6b7280}.auth-submit-btn{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;margin-top:8px;padding:14px 24px;transition:all .2s ease;width:100%}.auth-submit-btn:hover:not(:disabled){box-shadow:0 4px 12px #2563eb66;transform:translateY(-2px)}.auth-submit-btn:disabled{cursor:not-allowed;opacity:.7}.auth-footer{border-top:1px solid #e5e7eb;margin-top:28px;padding-top:24px;text-align:center}.auth-footer p{color:#6b7280;font-size:14px;margin:0 0 12px}.auth-link-btn{align-items:center;background:none;border:none;color:#2563eb;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:0}.auth-link-btn:hover{color:#1d4ed8;text-decoration:underline}@media (max-width:480px){.auth-card{padding:28px 20px}.auth-header h1{font-size:20px}.form-row{grid-template-columns:1fr}}.admin-dashboard{background:#f8fafc;min-height:100vh}.admin-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.admin-header-left{gap:24px}.admin-header-left,.back-btn{align-items:center;display:flex}.back-btn{background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;gap:6px;padding:10px 16px;transition:all .2s}.back-btn:hover{background:#e5e7eb;color:#374151}.admin-title{align-items:center;color:#1e3a5f;display:flex;gap:14px}.admin-title svg{color:#2563eb}.admin-title h1{color:#1f2937;font-size:20px;font-weight:700;margin:0}.admin-title p{color:#6b7280;font-size:13px;margin:0}.create-user-btn{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .2s}.create-user-btn:hover{box-shadow:0 4px 12px #2563eb66;transform:translateY(-2px)}.admin-toolbar{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 32px}.search-wrapper{position:relative;width:400px}.search-wrapper .search-icon{color:#9ca3af;left:14px;position:absolute;top:50%;transform:translateY(-50%)}.search-wrapper input{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;font-size:14px;outline:none;padding:12px 40px 12px 44px;transition:all .2s;width:100%}.search-wrapper input:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.clear-search{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.user-count{color:#6b7280;font-size:14px;font-weight:500}.users-list{display:flex;flex-direction:column;gap:12px;padding:24px 32px}.user-card{grid-gap:16px;align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:grid;gap:16px;grid-template-columns:56px 1fr 140px 100px 100px 110px 160px;padding:20px 24px;transition:all .2s}.user-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0000000d}.user-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:18px;font-weight:600;height:48px;justify-content:center;width:48px}.user-info{min-width:0}.user-name{color:#1f2937;font-size:15px;font-weight:600;margin-bottom:4px}.user-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email,.user-field{color:#6b7280;font-size:13px}.not-set{color:#d1d5db}.zodiac-badge{background:#fef3c7;color:#92400e;font-size:13px;font-weight:500}.tier-badge,.zodiac-badge{align-items:center;border-radius:20px;display:inline-flex;padding:6px 12px}.tier-badge{font-size:12px;font-weight:600;gap:4px;text-transform:uppercase}.tier-badge.beginner{background:#f3f4f6;border:1px solid #e5e7eb;color:#6b7280}.tier-badge.pro{background:#fef3c7;border:1px solid #fcd34d;color:#b45309}.tier-badge svg{color:#f59e0b}.user-actions{gap:8px}.action-btn,.user-actions{align-items:center;display:flex}.action-btn{border:none;border-radius:8px;cursor:pointer;height:36px;justify-content:center;transition:all .2s;width:36px}.action-btn.edit{background:#eff6ff;color:#2563eb}.action-btn.edit:hover{background:#dbeafe}.action-btn.status{background:#ecfdf5;color:#10b981}.action-btn.status.inactive{background:#fffbeb;color:#f59e0b}.action-btn.status:hover{background:#d1fae5}.action-btn.permissions{background:#f5f3ff;color:#8b5cf6}.action-btn.permissions:hover{background:#ede9fe}.action-btn.delete{background:#fef2f2;color:#ef4444}.action-btn.delete:hover{background:#fee2e2}.action-btn:disabled{cursor:not-allowed;opacity:.4}.empty-state,.loading-state{align-items:center;color:#9ca3af;display:flex;flex-direction:column;justify-content:center;padding:80px 20px}.empty-state svg{margin-bottom:16px;opacity:.5}.modal-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal-content{background:#fff;border-radius:16px;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#1f2937;font-size:18px;font-weight:600;margin:0}.modal-close{background:none;border:none;color:#9ca3af;cursor:pointer;padding:4px}.modal-close:hover{color:#6b7280}.modal-form{display:flex;flex-direction:column;gap:20px;padding:24px}.modal-form .form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.modal-form .form-group{display:flex;flex-direction:column;gap:6px}.modal-form label{color:#374151;font-size:13px;font-weight:600}.modal-form input,.modal-form select{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;font-size:14px;outline:none;padding:12px 14px;transition:all .2s}.modal-form input:focus,.modal-form select:focus{background:#fff;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:12px}.btn-cancel{background:#f3f4f6;border:none;border-radius:10px;color:#6b7280;cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .2s}.btn-cancel:hover{background:#e5e7eb}.btn-save{align-items:center;background:linear-gradient(135deg,#2563eb,#1d4ed8);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s}.btn-save:hover:not(:disabled){box-shadow:0 4px 12px #2563eb66;transform:translateY(-1px)}.btn-save:disabled{cursor:not-allowed;opacity:.7}@media (max-width:1200px){.user-card{grid-template-columns:48px 1fr 120px 90px 140px}.date-field,.expiry-field{display:none}}@media (max-width:768px){.admin-header{flex-direction:column;gap:16px;padding:16px}.admin-header-left{flex-direction:column;gap:12px;width:100%}.back-btn{align-self:flex-start}.create-user-btn{justify-content:center;width:100%}.admin-toolbar{flex-direction:column;gap:12px;padding:16px}.search-wrapper{width:100%}.user-card,.users-list{padding:16px}.user-card{gap:12px;grid-template-columns:1fr}.user-avatar{font-size:16px;height:40px;width:40px}.user-actions{border-top:1px solid #f3f4f6;justify-content:flex-end;padding-top:12px}.modal-form .form-row{grid-template-columns:1fr}}
/*# sourceMappingURL=main.2444a8cf.css.map*/