*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-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,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Cinzel,Inter,Georgia,serif;background-color:#0f172a;color:#e2e8f0;margin:0;padding:0;overflow:hidden;width:100vw;height:100vh;-moz-user-select:none;user-select:none;-webkit-user-select:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.invisible{visibility:hidden}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.inset-x-0{left:0;right:0}.inset-y-0{top:0;bottom:0}.-bottom-12{bottom:-3rem}.-left-12{left:-3rem}.-right-12{right:-3rem}.-top-12{top:-3rem}.bottom-0{bottom:0}.bottom-4{bottom:1rem}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.left-4{left:1rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-2{right:.5rem}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\.5{top:.375rem}.top-1\/2{top:50%}.top-3\.5{top:.875rem}.top-4{top:1rem}.top-\[1px\]{top:1px}.top-\[50\%\]{top:50%}.top-\[60\%\]{top:60%}.top-full{top:100%}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\[1\]{z-index:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-3\.5{margin-left:.875rem;margin-right:.875rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-0\.5{margin-top:.125rem;margin-bottom:.125rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.-ml-4{margin-left:-1rem}.-mt-4{margin-top:-1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.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}.aspect-video{aspect-ratio:16 / 9}.size-4{width:1rem;height:1rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-navigation-menu-viewport-height\)\]{height:var(--radix-navigation-menu-viewport-height)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-svh{height:100svh}.max-h-96{max-height:24rem}.max-h-\[300px\]{max-height:300px}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.min-h-0{min-height:0px}.min-h-\[60px\]{min-height:60px}.min-h-screen{min-height:100vh}.min-h-svh{min-height:100svh}.w-0{width:0px}.w-1{width:.25rem}.w-10{width:2.5rem}.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-\[--sidebar-width\]{width:var(--sidebar-width)}.w-\[100px\]{width:100px}.w-\[1px\]{width:1px}.w-auto{width:auto}.w-full{width:100%}.w-max{width:-moz-max-content;width:max-content}.w-px{width:1px}.min-w-0{min-width:0px}.min-w-10{min-width:2.5rem}.min-w-5{min-width:1.25rem}.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-\[--skeleton-width\]{max-width:var(--skeleton-width)}.max-w-lg{max-width:32rem}.max-w-max{max-width:-moz-max-content;max-width:max-content}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.grow-0{flex-grow:0}.basis-full{flex-basis:100%}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-px{--tw-translate-x: -1px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(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%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-\[-50\%\]{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-px{--tw-translate-x: 1px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(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%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-45{--tw-rotate: 45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(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:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-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-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.rounded-\[2px\]{border-radius:2px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-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(var(--radius) - 4px)}.border{border-width:1px}.border-2{border-width:2px}.border-\[1\.5px\]{border-width:1.5px}.border-y{border-top-width:1px;border-bottom-width:1px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-\[--color-border\]{border-color:var(--color-border)}.border-border\/50{border-color:hsl(var(--border) / .5)}.border-destructive\/50{border-color:hsl(var(--destructive) / .5)}.border-input{border-color:hsl(var(--input))}.border-primary{border-color:hsl(var(--primary))}.border-primary\/50{border-color:hsl(var(--primary) / .5)}.border-sidebar-border{border-color:hsl(var(--sidebar-border))}.border-transparent{border-color:transparent}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.bg-\[--color-bg\]{background-color:var(--color-bg)}.bg-accent{background-color:hsl(var(--accent))}.bg-background{background-color:hsl(var(--background))}.bg-background\/80{background-color:hsl(var(--background) / .8)}.bg-black\/30{background-color:#0000004d}.bg-black\/80{background-color:#000c}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-destructive{background-color:hsl(var(--destructive))}.bg-foreground{background-color:hsl(var(--foreground))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted\/50{background-color:hsl(var(--muted) / .5)}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-primary\/20{background-color:hsl(var(--primary) / .2)}.bg-secondary{background-color:hsl(var(--secondary))}.bg-sidebar{background-color:hsl(var(--sidebar-background))}.bg-sidebar-border{background-color:hsl(var(--sidebar-border))}.bg-transparent{background-color:transparent}.fill-current{fill:currentColor}.fill-primary{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{padding-left:.25rem;padding-right:.25rem}.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-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-3{padding-bottom:.75rem}.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-8{padding-right:2rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[0\.8rem\]{font-size:.8rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-accent-foreground{color:hsl(var(--accent-foreground))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-current{color:currentColor}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-sidebar-foreground{color:hsl(var(--sidebar-foreground))}.text-sidebar-foreground\/70{color:hsl(var(--sidebar-foreground) / .7)}.text-yellow-500{--tw-text-opacity: 1;color:rgb(234 179 8 / var(--tw-text-opacity))}.underline-offset-4{text-underline-offset:4px}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_0_1px_hsl\(var\(--sidebar-border\)\)\]{--tw-shadow: 0 0 0 1px hsl(var(--sidebar-border));--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);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 transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.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),var(--tw-shadow, 0 0 #0000)}.ring-ring{--tw-ring-color: hsl(var(--ring))}.ring-sidebar-ring{--tw-ring-color: hsl(var(--sidebar-ring))}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-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-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[left\,right\,width\]{transition-property:left,right,width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[margin\,opacity\]{transition-property:margin,opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[width\,height\,padding\]{transition-property:width,height,padding;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-\[width\]{transition-property:width;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}@keyframes enter{0%{opacity:var(--tw-enter-opacity, 1);transform:translate3d(var(--tw-enter-translate-x, 0),var(--tw-enter-translate-y, 0),0) scale3d(var(--tw-enter-scale, 1),var(--tw-enter-scale, 1),var(--tw-enter-scale, 1)) rotate(var(--tw-enter-rotate, 0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity, 1);transform:translate3d(var(--tw-exit-translate-x, 0),var(--tw-exit-translate-y, 0),0) scale3d(var(--tw-exit-scale, 1),var(--tw-exit-scale, 1),var(--tw-exit-scale, 1)) rotate(var(--tw-exit-rotate, 0))}}.animate-in{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.fade-in-0{--tw-enter-opacity: 0}.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)}.ease-linear{animation-timing-function:linear}#root{width:100%;height:100%;position:fixed;overflow:auto}.app{width:100%;min-height:100vh;background:radial-gradient(ellipse at 20% 20%,#0c1f3f,#0f172a,#070d1a);display:flex;flex-direction:column;align-items:center;padding:0;position:relative}.app:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:url(/bg-battle.png) center center / cover no-repeat;opacity:.06;pointer-events:none;z-index:0}.app>*{position:relative;z-index:1}.site-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.5rem;background:#0f172ad9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(34,211,238,.1);position:sticky;top:0;z-index:100;flex-shrink:0}.header-left{display:flex;align-items:center}.header-logo{height:34px;width:auto;cursor:pointer;filter:drop-shadow(0 0 6px rgba(255,255,255,.15));opacity:.95;transition:opacity .2s,filter .2s}.header-logo:hover{opacity:1;filter:drop-shadow(0 0 10px rgba(255,255,255,.25))}.header-right{display:flex;align-items:center;gap:.75rem}.sound-toggle{width:32px;height:32px;border-radius:8px;border:1px solid rgba(34,211,238,.2);background:#22d3ee14;color:#22d3ee;font-size:.9rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.sound-toggle:hover{background:#22d3ee26;border-color:#22d3ee66}.sound-toggle.sound-muted{color:#64748b;border-color:#ffffff1a;background:#ffffff08}.header-profile{display:flex;align-items:center;gap:.5rem;padding:.3rem .75rem;border-radius:20px;cursor:pointer;transition:all .2s ease;background:#ffffff0a;border:1px solid rgba(255,255,255,.08)}.header-profile:hover{background:#22d3ee14;border-color:#22d3ee40}.header-profile-disabled{opacity:.4;cursor:default;pointer-events:none}.header-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#22d3ee,#0891b2);color:#0f172a;font-size:.8rem;font-weight:800;display:flex;align-items:center;justify-content:center}.header-username{font-size:.8rem;font-weight:600;color:#cbd5e1}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;animation:modal-fade-in .2s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-card{max-width:380px;width:90%;padding:2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem}.modal-icon{font-size:2.5rem}.modal-title{font-size:1.2rem;font-weight:700;color:#e2e8f0}.modal-text{font-size:.85rem;color:#94a3b8;line-height:1.6}.modal-penalty{padding:.4rem 1rem;border-radius:8px;background:#f43f5e1a;border:1px solid rgba(244,63,94,.3);color:#f43f5e;font-size:.8rem;font-weight:600}.modal-actions{display:flex;gap:.75rem;margin-top:.5rem;width:100%}.modal-actions .btn{flex:1}.glass-panel{background:#0f172aa6;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(148,163,184,.1);border-radius:12px;box-shadow:0 4px 24px #0000004d}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1.4rem;border-radius:8px;font-size:.85rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s ease;border:none;outline:none;font-family:inherit}.btn:active:not(.disabled){transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,#22d3ee,#0891b2);color:#0f172a;box-shadow:0 0 20px #22d3ee4d}.btn-primary:hover:not(.disabled):not(:disabled){background:linear-gradient(135deg,#38e8ff,#0ea5e9);box-shadow:0 0 30px #22d3ee80;transform:translateY(-1px)}.btn-secondary{background:#f43f5e26;color:#f43f5e;border:1px solid rgba(244,63,94,.4)}.btn-secondary:hover{background:#f43f5e40;border-color:#f43f5e;box-shadow:0 0 20px #f43f5e33}.btn-ghost{background:#ffffff0d;color:#94a3b8;border:1px solid rgba(255,255,255,.1)}.btn-ghost:hover{background:#ffffff1a;color:#e2e8f0}.btn-large{padding:.9rem 2rem;font-size:1rem}.btn-sm{padding:.4rem .9rem;font-size:.8rem}.btn-confirm{width:100%;padding:.8rem;margin-top:.5rem}.btn.disabled,.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.auth-tabs{display:flex;margin-bottom:1.5rem;border-radius:10px;overflow:hidden;border:1px solid rgba(34,211,238,.15)}.auth-tab{flex:1;padding:.7rem 1rem;background:#ffffff08;color:#64748b;border:none;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s ease;font-family:inherit;text-transform:uppercase;letter-spacing:.15em}.auth-tab:hover{background:#22d3ee0d;color:#94a3b8}.auth-tab-active{background:#22d3ee1f;color:#22d3ee;box-shadow:inset 0 -2px #22d3ee}.lobby-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 52px);width:100%;padding:1rem}.lobby-card{width:100%;max-width:440px;padding:2.5rem}.lobby-header{text-align:center;margin-bottom:2rem}.lobby-logo{display:block;width:320px;max-width:100%;height:auto;margin:0 auto .25rem;filter:drop-shadow(0 0 20px rgba(34,211,238,.5));opacity:.95}.lobby-menu{display:flex;flex-direction:column;gap:.75rem}.lobby-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-label{font-size:.75rem;font-weight:700;color:#94a3b8;letter-spacing:.15em;text-transform:uppercase}.form-input{background:#ffffff0d;border:1px solid rgba(34,211,238,.2);border-radius:10px;padding:.7rem 1rem;color:#e2e8f0;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:#22d3ee;box-shadow:0 0 0 3px #22d3ee1a}.form-input::-moz-placeholder{color:#475569}.form-input::placeholder{color:#475569}.form-error{background:#f43f5e1a;border:1px solid rgba(244,63,94,.3);border-radius:8px;padding:.6rem .9rem;color:#f43f5e;font-size:.85rem}.form-actions{display:flex;gap:.75rem;justify-content:space-between;margin-top:.5rem}.lobby-rules{margin-top:2rem;padding-top:1.25rem;border-top:1px solid rgba(255,255,255,.06);text-align:center;color:#475569;font-size:.7rem;letter-spacing:.08em}.mode-select-card{width:100%;max-width:720px;padding:2rem}.mode-header{text-align:center;margin-bottom:1.5rem}.mode-user-bar{display:flex;align-items:center;justify-content:space-between;margin-top:1rem;padding:.6rem 1rem;border-radius:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.mode-welcome{font-size:.85rem;color:#94a3b8}.mode-welcome strong{color:#22d3ee}.mode-user-actions{display:flex;gap:.5rem}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mode-card{padding:1.5rem;text-align:center;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.5rem}.mode-card-available{cursor:pointer}.mode-card-available:hover{border-color:#22d3ee66;box-shadow:0 0 25px #22d3ee26;transform:translateY(-2px)}.mode-card-locked{opacity:.5;cursor:not-allowed}.mode-card-icon{font-size:2rem;margin-bottom:.25rem}.mode-card-title{font-size:.95rem;font-weight:700;color:#e2e8f0;letter-spacing:.12em;text-transform:uppercase}.mode-card-desc{font-size:.75rem;color:#64748b;line-height:1.5}.mode-card-badge{display:inline-block;padding:.25rem .8rem;border-radius:20px;font-size:.7rem;font-weight:700;margin-top:.25rem;text-transform:uppercase;letter-spacing:.06em}.mode-badge-active{background:#22d3ee1f;color:#22d3ee;border:1px solid rgba(34,211,238,.3)}.mode-badge-locked{background:#94a3b81a;color:#475569;border:1px solid rgba(148,163,184,.2)}.quick-sub-modal{max-width:420px;width:90%;padding:2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.quick-sub-title{font-family:Cinzel,serif;font-size:1.4rem;font-weight:700;color:#22d3ee;letter-spacing:.04em}.quick-sub-desc{font-size:.85rem;color:#94a3b8;margin:0}.quick-sub-options{display:flex;gap:1rem;width:100%}.quick-sub-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1rem;border-radius:12px;background:#22d3ee0f;border:1px solid rgba(34,211,238,.15);cursor:pointer;transition:all .2s ease}.quick-sub-btn:hover{background:#22d3ee1f;border-color:#22d3ee66;transform:translateY(-2px);box-shadow:0 8px 25px #22d3ee26}.quick-sub-ai{background:#f43f5e0f;border-color:#f43f5e26}.quick-sub-ai:hover{background:#f43f5e1f;border-color:#f43f5e66;box-shadow:0 8px 25px #f43f5e26}.quick-sub-icon{font-size:2rem}.quick-sub-label{font-family:Cinzel,serif;font-size:1rem;font-weight:700;color:#e2e8f0;letter-spacing:.03em}.quick-sub-hint{font-size:.75rem;color:#64748b;line-height:1.3}.quick-sub-close{margin-top:.25rem}.profile-card{width:100%;max-width:500px;padding:2.5rem}.profile-header{text-align:center;margin-bottom:2rem}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#22d3ee,#0891b2);color:#0f172a;font-size:2rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;box-shadow:0 0 30px #22d3ee4d}.profile-name{font-size:1.5rem;font-weight:700;color:#e2e8f0;margin-bottom:.5rem}.profile-rank-badge{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-bottom:.5rem}.rank-badge-icon{font-size:1.8rem;filter:drop-shadow(0 0 6px rgba(34,211,238,.5))}.rank-badge-info{display:flex;flex-direction:column;align-items:flex-start}.rank-badge-name{font-size:1rem;font-weight:700;color:#22d3ee;text-transform:uppercase;letter-spacing:.08em}.rank-badge-insignia{font-size:.65rem;color:#64748b;font-weight:600;letter-spacing:.1em}.rank-description{font-size:.75rem;color:#94a3b8;font-style:italic;max-width:300px;margin:0 auto;line-height:1.4}.rank-progress-section{margin-bottom:1.5rem;padding:.75rem 1rem;background:#22d3ee0d;border-radius:10px;border:1px solid rgba(34,211,238,.15)}.rank-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.rank-progress-label{font-size:.7rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.rank-progress-points{font-size:.7rem;color:#22d3ee;font-weight:700}.rank-progress-bar{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.rank-progress-fill{height:100%;background:linear-gradient(90deg,#22d3ee,#06b6d4);border-radius:3px;transition:width .5s ease;box-shadow:0 0 8px #22d3ee66}.profile-stats{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.stat-row{display:flex;gap:.75rem}.stat-item{flex:1;text-align:center;padding:.75rem .5rem;display:flex;flex-direction:column;gap:.2rem}.stat-value{font-size:1.3rem;font-weight:800;color:#22d3ee}.stat-label{font-size:.65rem;color:#64748b;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.profile-badges{margin-bottom:1.5rem}.profile-section-title{font-size:.8rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}.rank-progression{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.rank-card{text-align:center;padding:.75rem .5rem;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff08;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:.25rem}.rank-card-icon{font-size:1.4rem}.rank-card-name{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#475569}.rank-card-insignia{font-size:.55rem;color:#334155;font-weight:600}.rank-card-req{font-size:.5rem;color:#475569;font-weight:600}.rank-current{color:#22d3ee;border-color:#22d3ee66;background:#22d3ee1a;box-shadow:0 0 12px #22d3ee33}.rank-current .rank-card-name{color:#22d3ee}.rank-current .rank-card-insignia{color:#22d3eeb3}.rank-achieved{border-color:#22d3ee26;background:#22d3ee0d}.rank-achieved .rank-card-name{color:#94a3b8}.rank-achieved .rank-card-insignia{color:#64748b}.rank-locked{opacity:.5}.waiting-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 52px);width:100%}.waiting-card{text-align:center;padding:3rem 2.5rem;max-width:400px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem}.waiting-icon{font-size:3.5rem;animation:float 3s ease-in-out infinite;filter:drop-shadow(0 0 16px rgba(34,211,238,.5))}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.waiting-title{font-size:1.6rem;font-weight:700;color:#e2e8f0}.waiting-sub{color:#64748b;font-size:.9rem}.room-id-display{background:#22d3ee1a;border:2px solid rgba(34,211,238,.4);border-radius:12px;padding:.9rem 2rem;font-size:1.8rem;font-weight:800;letter-spacing:.2em;color:#22d3ee;font-family:Courier New,monospace;box-shadow:0 0 20px #22d3ee26}.waiting-status{display:flex;align-items:center;gap:.75rem;color:#94a3b8;font-size:.9rem}.spinner{width:18px;height:18px;border:2px solid rgba(34,211,238,.2);border-top-color:#22d3ee;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.phase-title{font-size:1.4rem;font-weight:700;background:linear-gradient(135deg,#22d3ee,#0ea5e9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.room-info{display:flex;align-items:center;gap:.6rem}.player-tag{padding:.2rem .6rem;border-radius:16px;font-size:.75rem;font-weight:600;letter-spacing:.02em;white-space:nowrap}.player-self{background:#22d3ee1f;color:#22d3ee;border:1px solid rgba(34,211,238,.25)}.player-enemy{background:#f43f5e1f;color:#f43f5e;border:1px solid rgba(244,63,94,.25)}.vs-tag{color:#475569;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em}.placement-timer{font-size:1.2rem;font-weight:800;color:#22d3ee;padding:.3rem .8rem;border-radius:8px;background:#22d3ee1a;border:1px solid rgba(34,211,238,.3);min-width:60px;text-align:center}.placement-timer.timer-urgent{color:#f43f5e;background:#f43f5e26;border-color:#f43f5e66;animation:timer-pulse 1s ease-in-out infinite}@keyframes timer-pulse{0%,to{box-shadow:0 0 5px #f43f5e33}50%{box-shadow:0 0 20px #f43f5e66}}.placement-notifications{display:flex;gap:.5rem}.notif{padding:.3rem .8rem;border-radius:8px;font-size:.75rem;font-weight:600;animation:notif-fade-in .3s ease}@keyframes notif-fade-in{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.notif-warning{background:#fbbf241f;color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.notif-info{background:#22d3ee14;color:#22d3ee;border:1px solid rgba(34,211,238,.2)}.grid{display:flex;flex-direction:column;gap:1px;width:100%}.grid-labels-row{display:grid;grid-template-columns:20px repeat(10,minmax(0,1fr));gap:1px}.grid-corner{height:20px}.grid-col-label{height:20px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#64748b;font-weight:600;letter-spacing:.05em}.grid-row{display:grid;grid-template-columns:20px repeat(10,minmax(0,1fr));gap:1px}.grid-row-label{display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#64748b;font-weight:600}.grid-cell{aspect-ratio:1;width:100%;border-radius:2px;border:1px solid rgba(255,255,255,.07);background:#0f172a80;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:all .15s ease;cursor:default;position:relative}.placement-cell{cursor:crosshair}.cell-ship{background:#22d3ee40;border-color:#22d3ee80;box-shadow:inset 0 0 6px #22d3ee33}.cell-hover-valid{background:#22d3ee59;border-color:#22d3ee;box-shadow:0 0 8px #22d3ee66}.cell-hover-invalid{background:#f43f5e40;border-color:#f43f5e80}.enemy-cell.cell-fireable{cursor:crosshair}.enemy-cell.cell-fireable:hover,.cell-targeting{background:#22d3ee33;border-color:#22d3ee99;box-shadow:0 0 10px #22d3ee4d;cursor:crosshair}.cell-hit{background:#f43f5e33;border-color:#f43f5e80;cursor:default}.cell-miss{background:#64748b1a;border-color:#64748b33;cursor:default}.cell-fired{cursor:default}.cell-my-ship{background:#22d3ee26;border-color:#22d3ee4d;box-shadow:inset 0 0 4px #22d3ee26}.cell-hit-mine{background:#f43f5e40;border-color:#f43f5e80}.cell-sunk{background:#64141e73;border-color:#f43f5e99}.cell-miss-on-me{background:#64748b14;border-color:#64748b26}.hit-marker{font-size:.85rem;color:#fb7185;font-weight:800;text-shadow:0 0 6px rgba(244,63,94,.6);line-height:1}.miss-marker{color:#64748b;font-size:1.2rem;line-height:1;opacity:.7}.sunk-marker{color:#f43f5e;font-size:.85rem;font-weight:800;text-shadow:0 0 8px rgba(244,63,94,.8);line-height:1}.placement-container{display:flex;flex-direction:column;gap:1rem;width:100%;max-width:1000px;margin:0 auto;padding:1rem}.placement-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;flex-wrap:wrap;gap:.75rem}.placement-main{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap}.placement-controls{flex:0 0 220px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.controls-header{display:flex;align-items:center;justify-content:space-between}.controls-title{font-size:.9rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.orientation-btn{font-size:.75rem;padding:.3rem .7rem}.ship-list{display:flex;flex-direction:column;gap:.5rem}.ship-item{display:flex;align-items:center;justify-content:space-between;padding:.55rem .75rem;border-radius:8px;border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:all .15s ease;background:#ffffff05}.ship-item.ship-selected{border-color:#22d3ee;background:#22d3ee1a;box-shadow:0 0 10px #22d3ee26}.ship-item.ship-placed{border-color:#22d3ee4d;background:#22d3ee0d;opacity:.75}.ship-item.ship-unplaced:hover{border-color:#22d3ee66;background:#22d3ee14}.ship-item-info{display:flex;flex-direction:column;gap:.3rem}.ship-item-name{font-size:.8rem;font-weight:600;color:#cbd5e1}.ship-cells-preview{display:flex;gap:2px}.ship-cell-preview{width:10px;height:10px;border-radius:2px;background:#ffffff26;border:1px solid rgba(255,255,255,.1)}.ship-cell-preview.placed{background:#22d3ee66;border-color:#22d3ee99}.ship-cell-preview.selected{background:#22d3ee99;border-color:#22d3ee}.ship-size-badge{font-size:.7rem;font-weight:700;color:#475569;width:18px;text-align:center}.ship-placed-badge{color:#22d3ee;font-size:.75rem}.placement-actions{display:flex;gap:.5rem}.waiting-confirm{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;border-radius:10px;background:#22d3ee14;border:1px solid rgba(34,211,238,.2);color:#94a3b8;font-size:.85rem}.placement-grid-wrap{flex:1;padding:1.25rem;min-width:0}.grid-title{font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.18em;margin-bottom:.6rem}.battle-container{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:1100px;margin:0 auto;padding:.75rem}.battle-header{display:flex;flex-direction:column;padding:.75rem 1.25rem;gap:.5rem}.battle-header-top{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.turn-indicator{display:flex;align-items:center;gap:.5rem}.turn-badge{padding:.35rem .9rem;border-radius:20px;font-size:.75rem;font-weight:700;letter-spacing:.1em;white-space:nowrap;text-transform:uppercase}.turn-you{background:#22d3ee26;color:#22d3ee;border:1px solid rgba(34,211,238,.4);box-shadow:0 0 15px #22d3ee33;animation:pulse-cyan 1.5s ease-in-out infinite}.turn-enemy{background:#f43f5e1a;color:#f43f5e;border:1px solid rgba(244,63,94,.3)}.turn-timer{padding:.25rem .6rem;border-radius:8px;font-size:.95rem;font-weight:800;color:#22d3ee;background:#22d3ee1a;border:1px solid rgba(34,211,238,.3);min-width:44px;text-align:center}.turn-timer-urgent{color:#f43f5e;background:#f43f5e26;border-color:#f43f5e66;animation:timer-pulse .8s ease-in-out infinite}.turn-warning{font-size:.7rem;font-weight:600;color:#fbbf24;background:#fbbf241a;border:1px solid rgba(251,191,36,.25);padding:.2rem .6rem;border-radius:6px;animation:notif-fade-in .3s ease;text-align:center}@keyframes pulse-cyan{0%,to{box-shadow:0 0 15px #22d3ee33}50%{box-shadow:0 0 25px #22d3ee66}}.battle-main{display:flex;gap:1rem;align-items:flex-start;flex-wrap:wrap;width:100%;min-width:0}.grid-toggle-bar{display:none;gap:0;border-radius:10px;overflow:hidden;border:1px solid rgba(34,211,238,.15);background:#0f172a80}.grid-toggle-btn{flex:1;padding:.5rem 1rem;background:transparent;border:none;color:#e2e8f080;font-family:Cinzel,serif;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .2s ease;letter-spacing:.15em;text-transform:uppercase}.grid-toggle-btn.grid-toggle-active{background:#22d3ee1f;color:#22d3ee;box-shadow:inset 0 -2px #22d3ee}.grid-toggle-btn:not(.grid-toggle-active):hover{background:#22d3ee0f;color:#e2e8f0cc}.grids-row{display:flex;gap:1rem;flex-wrap:wrap;flex:1;min-width:0}.grid-section{flex:1;min-width:0;padding:1rem}.grid-section-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;margin-bottom:.4rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.enemy-title{color:#f43f5e}.my-title{color:#22d3ee}.shot-count{font-size:.6rem;font-weight:500;color:#475569;text-transform:none;letter-spacing:.04em}.battle-sidebar{flex:0 0 260px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;max-height:calc(100vh - 160px);overflow:hidden}.sidebar-title{font-size:.75rem;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.18em;margin-bottom:.5rem}.fleet-status-section{padding-bottom:.75rem;border-bottom:1px solid rgba(255,255,255,.06)}.fleet-ships{display:flex;flex-direction:column;gap:.35rem}.fleet-ship{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.3rem 0}.fleet-ship-name{font-size:.65rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;min-width:70px}.fleet-ship-sunk .fleet-ship-name{color:#f43f5e;text-decoration:line-through}.fleet-ship-segments{display:flex;gap:3px}.fleet-segment{width:14px;height:8px;border-radius:2px;transition:all .3s ease}.fleet-segment-ok{background:#22d3ee66;border:1px solid rgba(34,211,238,.6)}.fleet-segment-hit{background:#f43f5e99;border:1px solid rgba(244,63,94,.8);box-shadow:0 0 4px #f43f5e4d}.fleet-ship-sunk .fleet-segment{background:#f43f5e4d;border-color:#f43f5e66}@keyframes cellHitFlash{0%{box-shadow:0 0 #f43f5e00}50%{box-shadow:0 0 12px #f43f5ecc}to{box-shadow:0 0 #f43f5e00}}@keyframes cellMissRipple{0%{box-shadow:0 0 #22d3ee00}50%{box-shadow:0 0 8px #22d3ee66}to{box-shadow:0 0 #22d3ee00}}.cell-hit,.cell-hit-mine{animation:cellHitFlash .4s ease-out}.cell-miss,.cell-miss-on-me{animation:cellMissRipple .4s ease-out}.battle-log-section{flex:1;overflow:hidden;display:flex;flex-direction:column}.battle-log{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem;max-height:200px;scrollbar-width:thin;scrollbar-color:rgba(34,211,238,.2) transparent}.battle-log::-webkit-scrollbar{width:4px}.battle-log::-webkit-scrollbar-track{background:transparent}.battle-log::-webkit-scrollbar-thumb{background:#22d3ee33;border-radius:2px}.log-empty{color:#334155;font-size:.8rem;text-align:center;padding:1rem 0}.log-entry{font-size:.75rem;color:#94a3b8;padding:.3rem .5rem;border-radius:4px;background:#ffffff05;border-left:3px solid rgba(148,163,184,.15);line-height:1.4}.log-entry:first-child{color:#e2e8f0}.log-hit{border-left-color:#f43f5e99;background:#f43f5e0d}.log-miss{border-left-color:#22c55e80;background:#22c55e08}.log-sunk{border-left-color:#f43f5e;background:#f43f5e14;color:#f43f5e;font-weight:600}.log-system{border-left-color:#22d3ee66;background:#22d3ee0a;color:#22d3ee}.log-info{border-left-color:#94a3b833}.quick-chat{display:flex;flex-direction:column;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;overflow:hidden}.quick-chat-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;cursor:pointer;background:#ffffff08;transition:background .15s}.quick-chat-header:hover{background:#ffffff0f}.quick-chat-title{font-size:.75rem;font-weight:600;color:#94a3b8}.quick-chat-toggle{font-size:.7rem;color:#475569}.quick-chat-messages{max-height:100px;overflow-y:auto;padding:.25rem .5rem;scrollbar-width:thin;scrollbar-color:rgba(34,211,238,.15) transparent}.chat-empty{text-align:center;font-size:.7rem;color:#334155;padding:.5rem 0}.chat-msg{padding:.2rem 0;font-size:.72rem;display:flex;gap:.4rem}.chat-msg-sender{font-weight:700;flex-shrink:0}.chat-msg-me .chat-msg-sender{color:#22d3ee}.chat-msg-them .chat-msg-sender{color:#f43f5e}.chat-msg-text{color:#94a3b8}.quick-chat-buttons{display:flex;flex-wrap:wrap;gap:.3rem;padding:.5rem;border-top:1px solid rgba(255,255,255,.06)}.quick-msg-btn{font-size:.65rem;padding:.25rem .5rem;border-radius:6px}.quick-msg-friendly{border-color:#22d3ee33}.quick-msg-react{border-color:#fbbf2433}.quick-msg-taunt{border-color:#f43f5e33}.retire-section{padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06)}.retire-btn{width:100%;color:#64748b;border-color:#ffffff0f}.retire-btn:hover{color:#f43f5e;border-color:#f43f5e4d}.retire-confirm{display:flex;flex-direction:column;gap:.5rem}.retire-warning{font-size:.75rem;color:#fbbf24;line-height:1.5}.retire-actions{display:flex;gap:.5rem}.game-over-section{display:flex;flex-direction:column;gap:.75rem}.game-over-banner{border-radius:12px;padding:1rem;text-align:center;display:flex;flex-direction:column;gap:.3rem}.banner-win{background:#22d3ee1a;border:1px solid rgba(34,211,238,.3)}.banner-lose{background:#f43f5e1a;border:1px solid rgba(244,63,94,.3)}.game-over-icon{font-size:2rem}.game-over-text{font-size:1.1rem;font-weight:800}.banner-win .game-over-text{color:#22d3ee}.banner-lose .game-over-text{color:#f43f5e}.game-over-sub{font-size:.75rem;color:#64748b}.tactical-action-bar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;flex-wrap:wrap}.action-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.6rem 1rem;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;cursor:pointer;transition:all .2s ease;min-width:80px;font-family:inherit}.action-btn:hover:not(.action-btn-disabled){background:#22d3ee14;border-color:#22d3ee4d;transform:translateY(-1px)}.action-btn-selected{background:#22d3ee1f;border-color:#22d3ee;box-shadow:0 0 15px #22d3ee4d,inset 0 0 8px #22d3ee1a}.action-btn-disabled{opacity:.35;cursor:not-allowed;transform:none}.action-icon{font-size:1.3rem}.action-name{font-size:.7rem;font-weight:600;color:#cbd5e1;white-space:nowrap}.action-cost{font-size:.65rem;font-weight:700;color:#22d3ee;padding:.1rem .4rem;border-radius:6px;background:#22d3ee1a;border:1px solid rgba(34,211,238,.2)}.ap-display{display:flex;align-items:baseline;gap:.25rem;padding:.3rem .75rem;border-radius:8px;background:#22d3ee14;border:1px solid rgba(34,211,238,.2)}.ap-value{font-size:1.2rem;font-weight:800;color:#22d3ee}.ap-low{color:#fbbf24;animation:ap-pulse 1s ease-in-out infinite}@keyframes ap-pulse{0%,to{opacity:1}50%{opacity:.5}}.ap-label{font-size:.75rem;font-weight:600;color:#64748b}.turn-plan{display:flex;flex-direction:column}.plan-empty{font-size:.78rem;color:#475569;text-align:center;padding:.75rem .5rem;line-height:1.5}.plan-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.plan-item{display:flex;align-items:center;gap:.4rem;padding:.4rem .5rem;border-radius:6px;background:#22d3ee0d;border:1px solid rgba(34,211,238,.12);font-size:.75rem;animation:notif-fade-in .2s ease}.plan-number{font-weight:700;color:#22d3ee;min-width:16px}.plan-action-type{font-weight:600;color:#cbd5e1;flex:1}.plan-target{font-weight:700;color:#e2e8f0;font-family:Courier New,monospace}.plan-cost{font-size:.65rem;font-weight:600;color:#64748b}.plan-remove{background:none;border:none;color:#475569;cursor:pointer;font-size:.7rem;padding:.15rem .3rem;border-radius:4px;transition:all .15s;font-family:inherit}.plan-remove:hover{color:#f43f5e;background:#f43f5e1a}.plan-remove:disabled{opacity:.3;cursor:not-allowed}.cell-queued{background:#22d3ee33;border:2px dashed rgba(34,211,238,.6);box-shadow:0 0 8px #22d3ee40}.queued-marker{font-size:.8rem;color:#22d3ee;font-weight:800}.cell-radar-occupied{background:#22c55e26;border-color:#22c55e66;box-shadow:inset 0 0 6px #22c55e33}.cell-radar-empty{background:#94a3b80f;border-color:#94a3b833}.radar-marker{font-size:.7rem;color:#94a3b8}.cell-radar-occupied .radar-marker{color:#22c55e}.cell-missile-hit{background:#fb923c4d;border-color:#fb923c99;box-shadow:0 0 8px #fb923c4d}.missile-marker{font-size:.75rem}.btn-execute{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.5rem;border-radius:10px;font-size:.9rem;font-weight:700;letter-spacing:.03em;cursor:pointer;transition:all .2s ease;border:none;outline:none;font-family:inherit;background:linear-gradient(135deg,#22d3ee,#0891b2);color:#0f172a;box-shadow:0 0 20px #22d3ee4d;margin-left:auto}.btn-execute:hover:not(:disabled){background:linear-gradient(135deg,#38e8ff,#0ea5e9);box-shadow:0 0 30px #22d3ee80;transform:translateY(-1px)}.btn-execute:active:not(:disabled){transform:scale(.97)}.btn-execute:disabled{opacity:.4;cursor:not-allowed;transform:none}.executing-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;z-index:150;animation:modal-fade-in .2s ease}.executing-spinner{width:40px;height:40px;border:3px solid rgba(34,211,238,.2);border-top-color:#22d3ee;border-radius:50%;animation:spin .8s linear infinite}.executing-text{font-size:1rem;font-weight:600;color:#22d3ee;letter-spacing:.04em}.tactical-battle .battle-main{display:grid;grid-template-columns:1fr 280px;grid-template-rows:auto auto auto;gap:.75rem;flex-wrap:nowrap}.tactical-battle .grid-toggle-bar{grid-column:1 / -1;grid-row:1}.tactical-battle .grids-row{grid-column:1;grid-row:2;flex:none;min-width:0}.tactical-battle .tactical-action-bar{grid-column:1;grid-row:3}.tactical-battle .battle-sidebar{grid-column:2;grid-row:2 / 4;flex:none;width:auto;max-height:calc(100vh - 180px);overflow-y:auto}.tactical-grid .grid-labels-row,.tactical-grid .grid-row{grid-template-columns:18px repeat(12,minmax(0,1fr))}.tactical-grid .grid-cell{font-size:.65rem}.tactical-grid .grid-col-label,.tactical-grid .grid-row-label{font-size:.6rem}.tactical-placement-grid .grid{overflow-x:auto}.tactical-badge{font-size:.7rem;font-weight:700;color:#22d3ee;padding:.2rem .6rem;border-radius:6px;background:#22d3ee1a;border:1px solid rgba(34,211,238,.2);letter-spacing:.05em}.tactical-header-top{display:flex;align-items:center;gap:.75rem;width:100%}.tactical-turn-badge{font-size:.75rem;font-weight:700;color:#e2e8f0;padding:.2rem .6rem;border-radius:6px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);letter-spacing:.05em}.ep-display{display:flex;align-items:center}.ep-bar-wrap{position:relative;width:140px;height:26px;border-radius:8px;background:#0f172acc;border:1px solid rgba(34,211,238,.3);overflow:hidden}.ep-bar-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#22d3ee66,#22d3ee99);border-radius:7px;transition:width .4s ease}.ep-bar-text{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;height:100%;gap:.15rem}.ep-value{font-size:.95rem;font-weight:800;color:#22d3ee}.ep-low{color:#fbbf24;animation:ap-pulse 1s ease-in-out infinite}.ep-label{font-size:.65rem;font-weight:600;color:#94a3b8}.status-badge{font-size:.65rem;font-weight:700;padding:.2rem .5rem;border-radius:6px;letter-spacing:.04em;animation:notif-fade-in .3s ease}.status-shield{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:#4ade80}.status-jammer{background:#a855f726;border:1px solid rgba(168,85,247,.3);color:#c084fc}.status-emp{background:#fbbf2426;border:1px solid rgba(251,191,36,.3);color:#fbbf24}.cell-aoe-hover{background:#22d3ee26!important;border-color:#22d3ee80!important;box-shadow:0 0 6px #22d3ee33}.action-aoe{font-size:.55rem;font-weight:700;color:#fbbf24;padding:.05rem .3rem;border-radius:4px;background:#fbbf241a}.action-btn-emp{border-color:#fbbf244d}.action-btn-emp.action-btn-selected{border-color:#fbbf24;box-shadow:0 0 15px #fbbf244d}.action-bar-controls{display:flex;gap:.5rem;align-items:center;margin-left:auto}.sidebar-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:.5rem}.sidebar-tab{flex:1;padding:.5rem .3rem;background:none;border:none;border-bottom:2px solid transparent;color:#64748b;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;letter-spacing:.04em}.sidebar-tab:hover{color:#cbd5e1}.sidebar-tab-active{color:#22d3ee;border-bottom-color:#22d3ee}.powers-panel{display:flex;flex-direction:column;gap:.4rem}.powers-list{display:flex;flex-direction:column;gap:.35rem}.sidebar-power-card{padding:.5rem .6rem;border-radius:8px;border:1px solid rgba(255,255,255,.08);background:#ffffff05;cursor:default;transition:all .2s}.sidebar-power-available{cursor:pointer;border-color:#22d3ee33}.sidebar-power-available:hover{background:#22d3ee14;border-color:#22d3ee66;transform:translateY(-1px)}.sidebar-power-active{background:#22d3ee1f;border-color:#22d3ee;box-shadow:0 0 12px #22d3ee40}.sidebar-power-cooldown{opacity:.45}.sidebar-power-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.2rem}.sidebar-power-icon{font-size:1rem}.sidebar-power-name{font-size:.72rem;font-weight:700;color:#e2e8f0;flex:1}.sidebar-power-cd{font-size:.6rem;font-weight:700;color:#fbbf24;padding:.1rem .3rem;border-radius:4px;background:#fbbf241a}.sidebar-power-queued{font-size:.55rem;font-weight:800;color:#22d3ee;padding:.1rem .3rem;border-radius:4px;background:#22d3ee26;letter-spacing:.06em}.sidebar-power-desc{font-size:.65rem;color:#64748b;line-height:1.4}.plan-powers{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.plan-power-item{display:flex;align-items:center;justify-content:space-between;padding:.3rem .5rem;border-radius:6px;background:#a855f714;border:1px solid rgba(168,85,247,.2);font-size:.72rem;font-weight:600;color:#c084fc}.tactical-prep-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:1rem;max-width:900px;margin:0 auto;animation:notif-fade-in .4s ease}.tactical-prep-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.25rem 1.5rem;width:100%;text-align:center}.prep-subtitle{font-size:.85rem;color:#94a3b8;margin:0}.prep-meta{display:flex;align-items:center;gap:1rem}.prep-timer{font-size:1.1rem;font-weight:800;color:#22d3ee;padding:.3rem .7rem;border-radius:8px;background:#22d3ee1a;border:1px solid rgba(34,211,238,.2)}.prep-count{font-size:.8rem;font-weight:700;color:#cbd5e1}.prep-notif{font-size:.75rem;font-weight:600;color:#fbbf24;padding:.3rem .7rem;border-radius:6px;background:#fbbf241a;border:1px solid rgba(251,191,36,.2);animation:notif-fade-in .3s ease}.prep-notif-locked{color:#22d3ee;background:#22d3ee1a;border-color:#22d3ee33}.power-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;width:100%}.power-card{display:flex;flex-direction:column;padding:1rem;border-radius:14px;cursor:pointer;transition:all .25s ease;position:relative;overflow:hidden;min-height:160px}.power-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,rgba(34,211,238,.3),transparent);opacity:0;transition:opacity .3s}.power-card:hover:not(.power-card-disabled):before{opacity:1}.power-card:hover:not(.power-card-disabled){transform:translateY(-4px);border-color:#22d3ee4d;box-shadow:0 8px 25px #0000004d,0 0 20px #22d3ee1a}.power-card-selected{border-color:#22d3ee!important;box-shadow:0 0 25px #22d3ee4d,inset 0 0 15px #22d3ee14!important;background:#22d3ee0f!important}.power-card-selected:before{opacity:1!important;background:linear-gradient(90deg,#22d3ee,#0891b2,#22d3ee)!important}.power-card-disabled{opacity:.35;cursor:not-allowed;transform:none!important}.power-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.6rem}.power-card-icon{font-size:1.5rem}.power-card-name{font-size:.85rem;font-weight:800;color:#e2e8f0;letter-spacing:.03em}.power-card-body{flex:1;display:flex;flex-direction:column;gap:.4rem}.power-card-desc{font-size:.75rem;color:#cbd5e1;line-height:1.5;margin:0}.power-card-flavor{font-size:.65rem;color:#475569;font-style:italic;margin:0;line-height:1.4}.power-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.6rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06)}.power-card-cd{font-size:.65rem;font-weight:600;color:#64748b}.power-card-check{font-size:.6rem;font-weight:800;color:#22d3ee;padding:.15rem .5rem;border-radius:6px;background:#22d3ee26;letter-spacing:.08em;animation:notif-fade-in .2s ease}.prep-confirm-btn{width:100%;max-width:400px}@media (max-width: 768px){.app{padding:0;align-items:stretch}.site-header{padding:.4rem 1rem}.header-logo{height:28px}.header-username{display:none}.battle-container{padding:.25rem;gap:.4rem;max-width:100%}.placement-container{max-width:100%;padding:.25rem}.placement-main{flex-direction:column}.placement-controls{flex:none;width:100%}.placement-grid-wrap{padding:.25rem;width:100%}.battle-main{flex-direction:column;gap:.4rem;align-items:stretch}.grid-toggle-bar{display:flex}.grid-mobile-hidden{display:none!important}.grids-row{flex-direction:column;gap:0;width:100%}.grid-labels-row,.grid-row{grid-template-columns:16px repeat(10,minmax(0,1fr))}.tactical-grid .grid-labels-row,.tactical-grid .grid-row{grid-template-columns:14px repeat(12,minmax(0,1fr))}.grid-section{display:flex;flex-direction:column;width:100%;max-width:100%;padding:.25rem;border-radius:6px;border:none;background:#0f172a66;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.battle-sidebar{flex:none;width:100%;max-height:none}.battle-log{max-height:150px}.placement-header{flex-direction:column;align-items:flex-start;padding:.75rem 1rem}.battle-header{padding:.6rem .75rem;gap:.4rem}.battle-header-top{gap:.5rem}.lobby-card{padding:1.5rem}.room-id-display{font-size:1.3rem;padding:.7rem 1.2rem}.mode-grid{grid-template-columns:1fr}.mode-select-card{padding:1.5rem}.stat-row{flex-wrap:wrap}.tactical-action-bar{padding:.5rem .75rem;gap:.4rem}.action-btn{padding:.4rem .6rem;min-width:64px}.action-icon{font-size:1rem}.action-name{font-size:.6rem}.btn-execute{padding:.5rem 1rem;font-size:.8rem;width:100%;margin-left:0}.action-bar-controls{width:100%;margin-left:0}.tactical-battle .battle-main{display:flex;flex-direction:column;gap:.75rem}.tactical-battle .grids-row{flex-direction:column}.tactical-battle .battle-sidebar{width:100%;max-height:none;overflow-y:visible}.tactical-grid .grid-cell{font-size:.55rem}.tactical-grid .grid-col-label,.tactical-grid .grid-row-label{font-size:.5rem}.power-cards-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.power-card{min-height:120px;padding:.75rem}.ep-bar-wrap{width:110px;height:22px}}@media (max-width: 480px){.battle-container{padding:.15rem;gap:.3rem}.grid-section{padding:.2rem}.grid-labels-row,.grid-row{grid-template-columns:14px repeat(10,minmax(0,1fr))}.tactical-grid .grid-labels-row,.tactical-grid .grid-row{grid-template-columns:12px repeat(12,minmax(0,1fr))}.battle-header{padding:.4rem .5rem;border-radius:8px}.grid-col-label{font-size:.5rem;height:14px}.grid-row-label{font-size:.55rem}.grid-section-title{font-size:.6rem;margin-bottom:.2rem}.hit-marker,.sunk-marker{font-size:.7rem}.miss-marker{font-size:1rem}}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::file-selector-button{color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:-inset-2:after{content:var(--tw-content);top:-.5rem;right:-.5rem;bottom:-.5rem;left:-.5rem}.after\:inset-y-0:after{content:var(--tw-content);top:0;bottom:0}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-1:after{content:var(--tw-content);width:.25rem}.after\:w-\[2px\]:after{content:var(--tw-content);width:2px}.after\:-translate-x-1\/2:after{content:var(--tw-content);--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.first\:rounded-l-md:first-child{border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.first\:border-l:first-child{border-left-width:1px}.last\:rounded-r-md:last-child{border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.focus-within\:relative:focus-within{position:relative}.focus-within\:z-20:focus-within{z-index:20}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-destructive\/80:hover{background-color:hsl(var(--destructive) / .8)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-muted:hover{background-color:hsl(var(--muted))}.hover\:bg-muted\/50:hover{background-color:hsl(var(--muted) / .5)}.hover\:bg-primary:hover{background-color:hsl(var(--primary))}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary) / .8)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:bg-sidebar-accent:hover{background-color:hsl(var(--sidebar-accent))}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:text-muted-foreground:hover{color:hsl(var(--muted-foreground))}.hover\:text-primary-foreground:hover{color:hsl(var(--primary-foreground))}.hover\:text-sidebar-accent-foreground:hover{color:hsl(var(--sidebar-accent-foreground))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-\[0_0_0_1px_hsl\(var\(--sidebar-accent\)\)\]:hover{--tw-shadow: 0 0 0 1px hsl(var(--sidebar-accent));--tw-shadow-colored: 0 0 0 1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:after\:bg-sidebar-border:hover:after{content:var(--tw-content);background-color:hsl(var(--sidebar-border))}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:bg-primary:focus{background-color:hsl(var(--primary))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:text-primary-foreground:focus{color:hsl(var(--primary-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;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);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);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-1:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-sidebar-ring:focus-visible{--tw-ring-color: hsl(var(--sidebar-ring))}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width: 1px}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.active\:bg-sidebar-accent:active{background-color:hsl(var(--sidebar-accent))}.active\:text-sidebar-accent-foreground:active{color:hsl(var(--sidebar-accent-foreground))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group\/menu-item:focus-within .group-focus-within\/menu-item\:opacity-100{opacity:1}.group\/menu-item:hover .group-hover\/menu-item\:opacity-100{opacity:1}.group.toaster .group-\[\.toaster\]\:border-border{border-color:hsl(var(--border))}.group.toast .group-\[\.toast\]\:bg-muted{background-color:hsl(var(--muted))}.group.toast .group-\[\.toast\]\:bg-primary{background-color:hsl(var(--primary))}.group.toaster .group-\[\.toaster\]\:bg-background{background-color:hsl(var(--background))}.group.toast .group-\[\.toast\]\:text-muted-foreground{color:hsl(var(--muted-foreground))}.group.toast .group-\[\.toast\]\:text-primary-foreground{color:hsl(var(--primary-foreground))}.group.toaster .group-\[\.toaster\]\:text-foreground{color:hsl(var(--foreground))}.group.toaster .group-\[\.toaster\]\:shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.peer\/menu-button:hover~.peer-hover\/menu-button\:text-sidebar-accent-foreground{color:hsl(var(--sidebar-accent-foreground))}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\[data-variant\=inset\]\]\:bg-sidebar:has([data-variant=inset]){background-color:hsl(var(--sidebar-background))}.has-\[\:disabled\]\:opacity-50:has(:disabled){opacity:.5}.group\/menu-item:has([data-sidebar=menu-action]) .group-has-\[\[data-sidebar\=menu-action\]\]\/menu-item\:pr-8{padding-right:2rem}.aria-disabled\:pointer-events-none[aria-disabled=true]{pointer-events:none}.aria-disabled\:opacity-50[aria-disabled=true]{opacity:.5}.aria-selected\:bg-accent[aria-selected=true]{background-color:hsl(var(--accent))}.aria-selected\:bg-accent\/50[aria-selected=true]{background-color:hsl(var(--accent) / .5)}.aria-selected\:text-accent-foreground[aria-selected=true]{color:hsl(var(--accent-foreground))}.aria-selected\:text-muted-foreground[aria-selected=true]{color:hsl(var(--muted-foreground))}.aria-selected\:opacity-100[aria-selected=true]{opacity:1}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true],.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction=vertical]{height:1px}.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction=vertical]{width:100%}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(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: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(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: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x: 1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(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]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes accordion-up{0%{height:var(--radix-accordion-content-height)}to{height:0}}.data-\[state\=closed\]\:animate-accordion-up[data-state=closed]{animation:accordion-up .2s ease-out}@keyframes accordion-down{0%{height:0}to{height:var(--radix-accordion-content-height)}}.data-\[state\=open\]\:animate-accordion-down[data-state=open]{animation:accordion-down .2s ease-out}.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction=vertical]{flex-direction:column}.data-\[active\=true\]\:bg-sidebar-accent[data-active=true]{background-color:hsl(var(--sidebar-accent))}.data-\[selected\=true\]\:bg-accent[data-selected=true]{background-color:hsl(var(--accent))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=on\]\:bg-accent[data-state=on],.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:hsl(var(--accent) / .5)}.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:hsl(var(--secondary))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[active\=true\]\:font-medium[data-active=true]{font-weight:500}.data-\[active\=true\]\:text-sidebar-accent-foreground[data-active=true]{color:hsl(var(--sidebar-accent-foreground))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:hsl(var(--muted-foreground))}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{color:hsl(var(--accent-foreground))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:hsl(var(--foreground))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:hsl(var(--primary-foreground))}.data-\[state\=on\]\:text-accent-foreground[data-state=on],.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:hsl(var(--accent-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}.data-\[disabled\=true\]\:opacity-50[data-disabled=true],.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:opacity-100[data-state=open]{opacity:1}.data-\[state\=active\]\:shadow[data-state=active]{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.data-\[state\=closed\]\:duration-300[data-state=closed]{transition-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{transition-duration:.5s}.data-\[motion\^\=from-\]\:animate-in[data-motion^=from-],.data-\[state\=open\]\:animate-in[data-state=open],.data-\[state\=visible\]\:animate-in[data-state=visible]{animation-name:enter;animation-duration:.15s;--tw-enter-opacity: initial;--tw-enter-scale: initial;--tw-enter-rotate: initial;--tw-enter-translate-x: initial;--tw-enter-translate-y: initial}.data-\[motion\^\=to-\]\:animate-out[data-motion^=to-],.data-\[state\=closed\]\:animate-out[data-state=closed],.data-\[state\=hidden\]\:animate-out[data-state=hidden]{animation-name:exit;animation-duration:.15s;--tw-exit-opacity: initial;--tw-exit-scale: initial;--tw-exit-rotate: initial;--tw-exit-translate-x: initial;--tw-exit-translate-y: initial}.data-\[motion\^\=from-\]\:fade-in[data-motion^=from-]{--tw-enter-opacity: 0}.data-\[motion\^\=to-\]\:fade-out[data-motion^=to-],.data-\[state\=closed\]\:fade-out-0[data-state=closed],.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: -.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x: .5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x: -.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y: .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[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\=closed\]\:duration-300[data-state=closed]{animation-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{animation-duration:.5s}.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);left:0}.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction=vertical]:after{content:var(--tw-content);height:.25rem}.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction=vertical]:after{content:var(--tw-content);width:100%}.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction=vertical]:after{content:var(--tw-content);--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=open\]\:hover\:bg-accent:hover[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=open\]\:hover\:bg-sidebar-accent:hover[data-state=open]{background-color:hsl(var(--sidebar-accent))}.data-\[state\=open\]\:hover\:text-sidebar-accent-foreground:hover[data-state=open]{color:hsl(var(--sidebar-accent-foreground))}.data-\[state\=open\]\:focus\:bg-accent:focus[data-state=open]{background-color:hsl(var(--accent))}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:left-\[calc\(var\(--sidebar-width\)\*-1\)\]{left:calc(var(--sidebar-width) * -1)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:right-\[calc\(var\(--sidebar-width\)\*-1\)\]{right:calc(var(--sidebar-width) * -1)}.group[data-side=left] .group-data-\[side\=left\]\:-right-4{right:-1rem}.group[data-side=right] .group-data-\[side\=right\]\:left-0{left:0}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:-mt-8{margin-top:-2rem}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:hidden{display:none}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:\!size-8{width:2rem!important;height:2rem!important}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[--sidebar-width-icon\]{width:var(--sidebar-width-icon)}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)\)\]{width:calc(var(--sidebar-width-icon) + 1rem)}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:w-\[calc\(var\(--sidebar-width-icon\)_\+_theme\(spacing\.4\)_\+2px\)\]{width:calc(var(--sidebar-width-icon) + 1rem + 2px)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:w-0{width:0px}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group[data-side=right] .group-data-\[side\=right\]\:rotate-180,.group[data-state=open] .group-data-\[state\=open\]\:rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:overflow-hidden{overflow:hidden}.group[data-variant=floating] .group-data-\[variant\=floating\]\:rounded-lg{border-radius:var(--radius)}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border{border-width:1px}.group[data-side=left] .group-data-\[side\=left\]\:border-r{border-right-width:1px}.group[data-side=right] .group-data-\[side\=right\]\:border-l{border-left-width:1px}.group[data-variant=floating] .group-data-\[variant\=floating\]\:border-sidebar-border{border-color:hsl(var(--sidebar-border))}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:\!p-0{padding:0!important}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:\!p-2{padding:.5rem!important}.group[data-collapsible=icon] .group-data-\[collapsible\=icon\]\:opacity-0{opacity:0}.group[data-variant=floating] .group-data-\[variant\=floating\]\:shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:after\:left-full:after{content:var(--tw-content);left:100%}.group[data-collapsible=offcanvas] .group-data-\[collapsible\=offcanvas\]\:hover\:bg-sidebar:hover{background-color:hsl(var(--sidebar-background))}.peer\/menu-button[data-size=default]~.peer-data-\[size\=default\]\/menu-button\:top-1\.5{top:.375rem}.peer\/menu-button[data-size=lg]~.peer-data-\[size\=lg\]\/menu-button\:top-2\.5{top:.625rem}.peer\/menu-button[data-size=sm]~.peer-data-\[size\=sm\]\/menu-button\:top-1{top:.25rem}.peer\/menu-button[data-active=true]~.peer-data-\[active\=true\]\/menu-button\:text-sidebar-accent-foreground{color:hsl(var(--sidebar-accent-foreground))}.dark\:border-destructive:is(.dark *){border-color:hsl(var(--destructive))}@media (min-width: 640px){.sm\:mt-0{margin-top:0}.sm\:flex{display:flex}.sm\:max-w-sm{max-width:24rem}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2\.5{gap:.625rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1rem * var(--tw-space-x-reverse));margin-left:calc(1rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.sm\:rounded-lg{border-radius:var(--radius)}.sm\:text-left{text-align:left}}@media (min-width: 768px){.md\:absolute{position:absolute}.md\:block{display:block}.md\:flex{display:flex}.md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{width:var(--radix-navigation-menu-viewport-width)}.md\:w-auto{width:auto}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:opacity-0{opacity:0}.after\:md\:hidden:after{content:var(--tw-content);display:none}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:m-2{margin:.5rem}.peer[data-state=collapsed][data-variant=inset]~.md\:peer-data-\[state\=collapsed\]\:peer-data-\[variant\=inset\]\:ml-2{margin-left:.5rem}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:ml-0{margin-left:0}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:rounded-xl{border-radius:.75rem}.peer[data-variant=inset]~.md\:peer-data-\[variant\=inset\]\:shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}}.\[\&\:has\(\>\.day-range-end\)\]\:rounded-r-md:has(>.day-range-end){border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\>\.day-range-start\)\]\:rounded-l-md:has(>.day-range-start){border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:rounded-md:has([aria-selected]){border-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){background-color:hsl(var(--accent))}.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{border-top-left-radius:calc(var(--radius) - 2px);border-bottom-left-radius:calc(var(--radius) - 2px)}.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){background-color:hsl(var(--accent) / .5)}.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){border-top-right-radius:calc(var(--radius) - 2px);border-bottom-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>\[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)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>button\]\:hidden>button{display:none}.\[\&\>span\:last-child\]\:truncate>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y: -3px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:left-4>svg{left:1rem}.\[\&\>svg\]\:top-4>svg{top:1rem}.\[\&\>svg\]\:size-4>svg{width:1rem;height:1rem}.\[\&\>svg\]\:h-2\.5>svg{height:.625rem}.\[\&\>svg\]\:h-3>svg{height:.75rem}.\[\&\>svg\]\:h-3\.5>svg{height:.875rem}.\[\&\>svg\]\:w-2\.5>svg{width:.625rem}.\[\&\>svg\]\:w-3>svg{width:.75rem}.\[\&\>svg\]\:w-3\.5>svg{width:.875rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-destructive>svg{color:hsl(var(--destructive))}.\[\&\>svg\]\:text-foreground>svg{color:hsl(var(--foreground))}.\[\&\>svg\]\:text-muted-foreground>svg{color:hsl(var(--muted-foreground))}.\[\&\>svg\]\:text-sidebar-accent-foreground>svg{color:hsl(var(--sidebar-accent-foreground))}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:1.75rem}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0px}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{--tw-rotate: 90deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(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;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&_\.recharts-cartesian-axis-tick_text\]\:fill-muted-foreground .recharts-cartesian-axis-tick text{fill:hsl(var(--muted-foreground))}.\[\&_\.recharts-cartesian-grid_line\[stroke\=\'\#ccc\'\]\]\:stroke-border\/50 .recharts-cartesian-grid line[stroke="#ccc"]{stroke:hsl(var(--border) / .5)}.\[\&_\.recharts-curve\.recharts-tooltip-cursor\]\:stroke-border .recharts-curve.recharts-tooltip-cursor{stroke:hsl(var(--border))}.\[\&_\.recharts-dot\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-dot[stroke="#fff"]{stroke:transparent}.\[\&_\.recharts-layer\]\:outline-none .recharts-layer{outline:2px solid transparent;outline-offset:2px}.\[\&_\.recharts-polar-grid_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-polar-grid [stroke="#ccc"]{stroke:hsl(var(--border))}.\[\&_\.recharts-radial-bar-background-sector\]\:fill-muted .recharts-radial-bar-background-sector,.\[\&_\.recharts-rectangle\.recharts-tooltip-cursor\]\:fill-muted .recharts-rectangle.recharts-tooltip-cursor{fill:hsl(var(--muted))}.\[\&_\.recharts-reference-line_\[stroke\=\'\#ccc\'\]\]\:stroke-border .recharts-reference-line [stroke="#ccc"]{stroke:hsl(var(--border))}.\[\&_\.recharts-sector\[stroke\=\'\#fff\'\]\]\:stroke-transparent .recharts-sector[stroke="#fff"]{stroke:transparent}.\[\&_\.recharts-sector\]\:outline-none .recharts-sector,.\[\&_\.recharts-surface\]\:outline-none .recharts-surface{outline:2px solid transparent;outline-offset:2px}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-top:.375rem;padding-bottom:.375rem}.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{font-size:.75rem;line-height:1rem}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{font-weight:500}.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{color:hsl(var(--muted-foreground))}.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden])~[cmdk-group]{padding-top:0}.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{height:1.25rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{width:1.25rem}.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{height:3rem}.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{padding-top:.75rem;padding-bottom:.75rem}.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{height:1.25rem}.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{width:1.25rem}.\[\&_p\]\:leading-relaxed p{line-height:1.625}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0px}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}[data-side=left][data-collapsible=offcanvas] .\[\[data-side\=left\]\[data-collapsible\=offcanvas\]_\&\]\:-right-2{right:-.5rem}[data-side=left][data-state=collapsed] .\[\[data-side\=left\]\[data-state\=collapsed\]_\&\]\:cursor-e-resize{cursor:e-resize}[data-side=left] .\[\[data-side\=left\]_\&\]\:cursor-w-resize{cursor:w-resize}[data-side=right][data-collapsible=offcanvas] .\[\[data-side\=right\]\[data-collapsible\=offcanvas\]_\&\]\:-left-2{left:-.5rem}[data-side=right][data-state=collapsed] .\[\[data-side\=right\]\[data-state\=collapsed\]_\&\]\:cursor-w-resize{cursor:w-resize}[data-side=right] .\[\[data-side\=right\]_\&\]\:cursor-e-resize{cursor:e-resize}
