*,: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}:root{--background: 0 0% 100%;--foreground: 222.2 84% 4.9%;--card: 0 0% 100%;--card-foreground: 222.2 84% 4.9%;--popover: 0 0% 100%;--popover-foreground: 222.2 84% 4.9%;--primary: 222.2 47.4% 11.2%;--primary-foreground: 210 40% 98%;--secondary: 210 40% 96.1%;--secondary-foreground: 222.2 47.4% 11.2%;--muted: 210 40% 96.1%;--muted-foreground: 215.4 16.3% 46.9%;--accent: 210 40% 96.1%;--accent-foreground: 222.2 47.4% 11.2%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 210 40% 98%;--border: 214.3 31.8% 91.4%;--input: 214.3 31.8% 91.4%;--ring: 215 20.2% 65.1%;--radius: .5rem;--chart-1: 12 76% 61%;--chart-2: 173 58% 39%;--chart-3: 197 37% 24%;--chart-4: 43 74% 66%;--chart-5: 27 87% 67%}.dark{--background: 0 0% 3.9%;--foreground: 0 0% 98%;--card: 0 0% 3.9%;--card-foreground: 0 0% 98%;--popover: 0 0% 3.9%;--popover-foreground: 0 0% 98%;--primary: 0 0% 98%;--primary-foreground: 0 0% 9%;--secondary: 0 0% 14.9%;--secondary-foreground: 0 0% 98%;--muted: 0 0% 14.9%;--muted-foreground: 0 0% 63.9%;--accent: 0 0% 14.9%;--accent-foreground: 0 0% 98%;--destructive: 0 62.8% 30.6%;--destructive-foreground: 0 0% 98%;--border: 0 0% 14.9%;--input: 0 0% 14.9%;--ring: 0 0% 83.1%;--chart-1: 220 70% 50%;--chart-2: 160 60% 45%;--chart-3: 30 80% 55%;--chart-4: 280 65% 60%;--chart-5: 340 75% 55%}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground))}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.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}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.bottom-0{bottom:0}.left-0{left:0}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-4{right:1rem}.top-1\/2{top:50%}.top-4{top:1rem}.top-\[50\%\]{top:50%}.z-10{z-index:10}.z-50{z-index:50}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.-ml-2{margin-left:-.5rem}.ml-auto{margin-left:auto}.mt-1{margin-top:.25rem}.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}.\!grid{display:grid!important}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-2{height:.5rem}.h-20{height:5rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1\.2rem\]{height:1.2rem}.h-\[95vh\]{height:95vh}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.max-h-60{max-height:15rem}.max-h-\[90vh\]{max-height:90vh}.min-h-0{min-height:0px}.min-h-\[80px\]{min-height:80px}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-16{width:4rem}.w-2{width:.5rem}.w-20{width:5rem}.w-24{width:6rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-\[1\.2rem\]{width:1.2rem}.w-\[100px\]{width:100px}.w-full{width:100%}.min-w-\[8rem\]{min-width:8rem}.max-w-7xl{max-width:80rem}.max-w-\[600px\]{max-width:600px}.max-w-lg{max-width:32rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-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-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-0{--tw-rotate: 0deg;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))}.scale-0{--tw-scale-x: 0;--tw-scale-y: 0;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))}.scale-100{--tw-scale-x: 1;--tw-scale-y: 1;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 spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear 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}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-rows-\[auto_1fr_auto\]{grid-template-rows:auto 1fr auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.place-content-center{place-content:center}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.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))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.whitespace-nowrap{white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.border{border-width:1px}.border-2{border-width:2px}.border-t{border-top-width:1px}.border-input{border-color:hsl(var(--input))}.border-primary{border-color:hsl(var(--primary))}.border-transparent{border-color:transparent}.bg-background{background-color:hsl(var(--background))}.bg-background\/95{background-color:hsl(var(--background) / .95)}.bg-black\/80{background-color:#000c}.bg-destructive{background-color:hsl(var(--destructive))}.bg-input{background-color:hsl(var(--input))}.bg-muted{background-color:hsl(var(--muted))}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-secondary{background-color:hsl(var(--secondary))}.fill-current{fill:currentColor}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-0{padding-left:0;padding-right:0}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-8{padding-left:2rem;padding-right:2rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-0{padding-bottom:0}.pb-16{padding-bottom:4rem}.pb-4{padding-bottom:1rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pr-6{padding-right:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-\[10px\]{font-size:10px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-current{color:currentColor}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-foreground\/60{color:hsl(var(--foreground) / .6)}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.underline-offset-4{text-underline-offset:4px}.accent-primary{accent-color:hsl(var(--primary))}.opacity-100{opacity:1}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.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)}.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-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{--tw-backdrop-blur: blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function: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-200{transition-duration:.2s}@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))}}.duration-200{animation-duration:.2s}.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-base::-moz-placeholder{font-size:1rem;line-height:1.5rem}.placeholder\:text-base::placeholder{font-size:1rem;line-height:1.5rem}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-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-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.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:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[state\=checked\]\:translate-x-5[data-state=checked]{--tw-translate-x: 1.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) 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))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:hsl(var(--primary-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=open\]\:animate-in[data-state=open]{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-\[state\=closed\]\:animate-out[data-state=closed]{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-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity: 0}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity: 0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale: .95}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale: .95}.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-left-1\/2[data-state=closed]{--tw-exit-translate-x: -50%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y: -48%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x: -50%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y: -48%}@supports (backdrop-filter: var(--tw)){.supports-\[backdrop-filter\]\:bg-background\/60{background-color:hsl(var(--background) / .6)}}.dark\:-rotate-90:is(.dark *){--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))}.dark\:rotate-0:is(.dark *){--tw-rotate: 0deg;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))}.dark\:scale-0:is(.dark *){--tw-scale-x: 0;--tw-scale-y: 0;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))}.dark\:scale-100:is(.dark *){--tw-scale-x: 1;--tw-scale-y: 1;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))}@media(min-width:640px){.sm\:max-w-\[425px\]{max-width:425px}.sm\:max-w-\[525px\]{max-width:525px}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:justify-between{justify-content:space-between}.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\:rounded-lg{border-radius:var(--radius)}.sm\:text-left{text-align:left}}@media(min-width:768px){.md\:block{display:block}.md\:pb-16{padding-bottom:4rem}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:opacity-0{opacity:0}.md\:placeholder\:text-sm::-moz-placeholder{font-size:.875rem;line-height:1.25rem}.md\:placeholder\:text-sm::placeholder{font-size:.875rem;line-height:1.25rem}.group:hover .md\:group-hover\:opacity-100{opacity:1}}.\[\&\:\:-moz-range-thumb\]\:h-4::-moz-range-thumb{height:1rem}.\[\&\:\:-moz-range-thumb\]\:w-4::-moz-range-thumb{width:1rem}.\[\&\:\:-moz-range-thumb\]\:cursor-pointer::-moz-range-thumb{cursor:pointer}.\[\&\:\:-moz-range-thumb\]\:rounded-full::-moz-range-thumb{border-radius:9999px}.\[\&\:\:-moz-range-thumb\]\:border-0::-moz-range-thumb{border-width:0px}.\[\&\:\:-moz-range-thumb\]\:bg-primary::-moz-range-thumb{background-color:hsl(var(--primary))}.\[\&\:\:-webkit-slider-thumb\]\:-mt-1::-webkit-slider-thumb{margin-top:-.25rem}.\[\&\:\:-webkit-slider-thumb\]\:h-4::-webkit-slider-thumb{height:1rem}.\[\&\:\:-webkit-slider-thumb\]\:w-4::-webkit-slider-thumb{width:1rem}.\[\&\:\:-webkit-slider-thumb\]\:cursor-pointer::-webkit-slider-thumb{cursor:pointer}.\[\&\:\:-webkit-slider-thumb\]\:appearance-none::-webkit-slider-thumb{-webkit-appearance:none;appearance:none}.\[\&\:\:-webkit-slider-thumb\]\:rounded-full::-webkit-slider-thumb{border-radius:9999px}.\[\&\:\:-webkit-slider-thumb\]\:bg-primary::-webkit-slider-thumb{background-color:hsl(var(--primary))}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.sign-in-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#f5f5f5;position:relative}.sign-in-close-button{position:absolute;top:20px;right:20px;background:transparent;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;color:#666;transition:color .2s;border-radius:.375rem}.sign-in-close-button:hover{color:#000;background-color:#0000000d}.sign-in-card{background:#fff;padding:3rem;border-radius:1rem;box-shadow:0 2px 8px #0000001a;text-align:center;max-width:400px;width:100%}.sign-in-card h1{font-size:2.5rem;margin:0 0 1rem}.sign-in-card p{color:#666;margin-bottom:2rem}.google-sign-in-btn{width:100%;padding:1rem;background-color:#4285f4;color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.google-sign-in-btn:hover:not(:disabled){background-color:#357ae8}.google-sign-in-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{color:#dc3545;margin-top:1rem;font-size:.9rem}.sign-in-hint{margin-top:1rem;font-size:.85rem;color:#666}.onboarding-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background-color:var(--background, white)}.onboarding-container{width:100%;max-width:600px}.onboarding-close-button{position:fixed;top:20px;right:20px;z-index:10}.onboarding-header{text-align:center;margin-bottom:2rem}.onboarding-header h1{margin:0 0 .5rem;font-size:2rem;font-weight:600}.onboarding-header p{margin:0;color:var(--muted-foreground, #666);font-size:1rem}.onboarding-form{display:flex;flex-direction:column;gap:1.5rem}.onboarding-avatar-section{display:flex;justify-content:center;margin-bottom:1rem}.onboarding-avatar-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.onboarding-avatar-button{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;border:none;flex-shrink:0;cursor:pointer;padding:0;background:none;position:relative}.onboarding-avatar-button img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.onboarding-avatar-placeholder{width:100%;height:100%;background-color:#0000000f;display:flex;align-items:center;justify-content:center}.onboarding-plus-icon{width:32px;height:32px;color:hsl(var(--muted-foreground))}.avatar-actions{display:flex;gap:.5rem}.error-message{padding:.75rem;border-radius:.375rem;background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb;font-size:.9rem;margin-bottom:0;border-bottom:none}.form-actions{display:flex;justify-content:center;margin-top:0;border-top:none!important;padding-top:0!important}.onboarding-form .form-actions{border-top:none!important;margin-top:0!important}.error-message+.form-actions{border-top:none!important;margin-top:0!important}.onboarding-form>*:last-child{border-top:none!important}.onboarding-form .form-group:last-of-type{border-bottom:none!important;margin-bottom:0}.submit-button{width:100%}.games-page{width:100%;max-width:600px;margin:0 auto;padding-top:120px}.page-header{display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:600px;z-index:40;background-color:hsl(var(--background));padding:1rem 0;margin:0;box-shadow:0 1px hsl(var(--border) / .1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.search-container{position:fixed;top:5rem;left:50%;transform:translate(-50%);width:100%;max-width:600px;z-index:39;background-color:hsl(var(--background));padding:0 0 1rem;margin:0;box-shadow:0 1px hsl(var(--border) / .1);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media(max-width:767px){.page-header{padding:1rem}.search-container{padding:4px 1rem 1rem}}.search-input{width:100%;border-radius:9999px}.search-results-count{margin-top:.5rem;font-size:.875rem;color:#666}.games-list{display:flex;flex-direction:column;gap:20px;position:relative;z-index:1}.game-list-item{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.game-list-content{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.game-list-name-wrapper{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.game-list-champion-desktop{display:none}@media(min-width:768px){.search-container{padding:5px 1rem 1rem}.games-list{padding-left:1rem;padding-right:1rem}.game-list-name-wrapper .game-list-champion{display:none}.game-list-champion-desktop{display:block}}.game-cover-art-container{position:relative;width:50px;height:50px;flex-shrink:0}.game-cover-art{width:50px;height:50px;-o-object-fit:cover;object-fit:cover;border-radius:8px;position:absolute;top:0;left:0;z-index:1}.game-cover-art-placeholder{width:50px;height:50px;border-radius:8px;background-color:hsl(var(--muted));display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;color:hsl(var(--muted-foreground));position:absolute;top:0;left:0;z-index:0}.game-list-name{font-size:1rem;font-weight:500;color:hsl(var(--foreground))}.game-list-champion{font-size:.875rem;color:hsl(var(--muted-foreground));display:flex;align-items:center;gap:.25rem}.game-list-champion.no-champion{color:hsl(var(--muted-foreground) / .7);font-style:italic}.add-button{padding:.75rem 1.5rem;background-color:#007bff;color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.add-button:hover{background-color:#0056b3}.game-item{position:relative}.delete-button{position:absolute;top:.5rem;right:.5rem;padding:.5rem;background-color:#dc3545;color:#fff;border:none;border-radius:.25rem;cursor:pointer;font-size:.85rem;opacity:0;transition:opacity .2s}.game-item:hover .delete-button{opacity:1}.delete-button:hover{background-color:#c82333}.empty-state{text-align:center;padding:3rem;color:#666}.empty-hint{font-size:.9rem;margin-top:.5rem}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:.5rem;max-width:500px;width:90%}.modal-content h2{margin:0 0 1.5rem}.modal-content input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:.5rem;font-size:1rem;margin-bottom:1rem;box-sizing:border-box}.form-actions{display:flex;gap:1rem;justify-content:flex-end}.form-actions button{padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;cursor:pointer;transition:background-color .2s}.form-actions button[type=button]{background-color:#6c757d;color:#fff}.form-actions button[type=button]:hover{background-color:#5a6268}.form-actions button[type=submit]{background-color:#007bff;color:#fff}.form-actions button[type=submit]:hover:not(:disabled){background-color:#0056b3}.form-actions button:disabled{opacity:.6;cursor:not-allowed}.match-row{display:flex;justify-content:space-between;align-items:center;gap:20px}.match-main-content{flex:1;display:flex;flex-direction:row;align-items:flex-start;gap:.75rem}.match-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.match-text{font-size:1rem;display:flex;align-items:center;row-gap:0;-moz-column-gap:.25rem;column-gap:.25rem;flex-wrap:wrap}.match-link{color:hsl(var(--primary));text-decoration:none;font-weight:500}.match-link:hover{text-decoration:underline}.match-date{color:hsl(var(--muted-foreground));font-size:.9rem}.match-row-deletable{cursor:pointer;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.match-row-deletable:active{opacity:.8}.match-winner-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.match-winner-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.match-winner-initials{color:#fff;font-weight:600;font-size:.875rem}.game-detail-page{width:100%;max-width:600px;margin:0 auto;padding-bottom:6rem}.game-detail-page .page-header{display:flex;flex-direction:column;align-items:center;position:relative}.page-header-nav{display:flex;justify-content:space-between;align-items:flex-start;width:100%;margin-bottom:1rem;position:relative}.back-button,.edit-button{margin:0}.game-cover-art-section{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%;margin-bottom:1rem;position:relative}.game-header-content{display:flex;flex-direction:column;align-items:center;width:100%;margin-bottom:1rem;position:relative}.game-cover-art-large{position:relative;width:100%;max-width:400px;flex-shrink:0}.game-cover-art-image{width:100%;max-width:400px;max-height:300px;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:8px;display:block;position:relative;z-index:1}.game-cover-art-placeholder-large{width:100%;aspect-ratio:1 / 1;border-radius:12px;background-color:hsl(var(--muted));display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:600;color:hsl(var(--muted-foreground));position:relative;z-index:0}.game-title-full-width{margin:1.5rem 0 0;text-align:center;word-break:break-word;width:100%}.start-session-button{width:auto;margin-top:20px;margin-bottom:1rem;display:block;height:3.5rem;padding:0 2rem;font-size:1.125rem}.start-session-button-mobile{display:block;position:fixed;bottom:0;left:50%;transform:translate(-50%);width:calc(100% - 2rem);max-width:600px;z-index:40}.start-session-button-desktop,.game-header-actions-desktop{display:none}.game-info{margin:2rem 0;padding:1rem;background:#f5f5f5;border-radius:.5rem}.info-item{display:flex;gap:1rem;margin-bottom:.5rem}.info-label{font-weight:600;min-width:100px}.matches-section{margin-top:20px}.matches-list{padding:0 1.25rem;display:flex;flex-direction:column;gap:1rem}.player-card{display:flex;align-items:center;gap:1rem;padding:1rem;border:1px solid hsl(var(--border));border-radius:.5rem;cursor:pointer;transition:box-shadow .2s,transform .1s;background:hsl(var(--card))}.player-card:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-2px)}.player-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.player-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.player-initials{color:#fff;font-weight:600;font-size:1rem}.player-info{flex:1}.player-name{margin:0;font-size:1.1rem;font-weight:500}.player-email{margin:.25rem 0 0;font-size:.875rem;color:hsl(var(--muted-foreground))}.players-page{width:100%;max-width:600px;margin:0 auto}.page-header h1{margin:0;font-size:2rem}.players-page{padding-top:4.5rem}.players-list{display:flex;flex-direction:column;gap:20px}@media(min-width:768px){.players-list{padding-left:1rem;padding-right:1rem}}.player-item{display:flex;align-items:center;justify-content:space-between}.player-item>:first-child{flex:1;min-width:0}.player-item .player-card{border:none;padding:0;margin:0;cursor:pointer;background:transparent;box-shadow:none;transform:none}.player-item .player-card:hover{box-shadow:none;transform:none}.player-item-deletable{cursor:pointer;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.player-item-deletable:active{opacity:.8}.player-detail-page{width:100%;max-width:600px;margin:0 auto}.player-detail-page .page-header{display:flex;flex-direction:column;align-items:center;position:relative;padding:0}.page-header-top{margin-bottom:1rem;width:100%;display:flex;align-items:center;position:relative}.player-header-content{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.player-header-info{display:flex;flex-direction:column;gap:.5rem;align-items:center;text-align:center;width:100%}.player-header-info h1{text-align:center;margin:0}.player-details{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem;align-items:center;text-align:center;width:100%}.player-location{font-size:.9rem;color:hsl(var(--muted-foreground));text-align:center}.player-bio{font-size:.95rem;color:hsl(var(--foreground));line-height:1.5;text-align:center}.player-avatar-large{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.5rem;flex-shrink:0}.player-avatar-large img{width:100%;height:100%;border-radius:50%;-o-object-fit:cover;object-fit:cover}.player-stats{display:flex;gap:2rem;margin:2rem 0;padding:1rem;background:hsl(var(--muted));border-radius:.5rem}.stat-item{display:flex;flex-direction:column;align-items:flex-start}.stat-value{font-size:2rem;font-weight:700;color:hsl(var(--foreground))}.stat-label{font-size:.9rem;color:hsl(var(--muted-foreground))}.matches-section{margin-top:0rem}.matches-section h2{margin-bottom:1rem}.player-detail-page .matches-list{display:flex;flex-direction:column;gap:20px;margin-left:-1.25rem;margin-right:-1.25rem}.profile-page{width:100%;max-width:600px;margin:0 auto;padding-top:4.5rem}.page-header{display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:600px;z-index:40;background-color:hsl(var(--background));padding:1rem 0;margin:0}@media(max-width:767px){.page-header{padding:1rem}}.page-header h1{margin:0;font-size:2rem;font-weight:600}.profile-content{display:flex;flex-direction:column;gap:1.5rem}.profile-section{padding:1.5rem;border:1px solid hsl(var(--border));border-radius:.5rem;background-color:hsl(var(--card));display:flex;flex-direction:column}.profile-section-footer{margin-top:auto;border-top:1px solid hsl(var(--border));margin-left:-1.5rem;margin-right:-1.5rem;margin-bottom:-1.5rem;padding:1rem 1.5rem;display:flex;justify-content:flex-end}.profile-avatar-container{display:flex;flex-direction:row;align-items:center;gap:1rem}.profile-avatar-button{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;border:none;flex-shrink:0;cursor:pointer;padding:0;background:none;position:relative}.profile-avatar-button img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.profile-avatar-placeholder{width:100%;height:100%;background-color:#0000000f;display:flex;align-items:center;justify-content:center}.profile-plus-icon{width:32px;height:32px;color:hsl(var(--muted-foreground))}.avatar-actions{display:flex;flex-direction:row;gap:.5rem;align-items:center}.profile-form{display:flex;flex-direction:column;gap:1.5rem;padding-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;font-size:.9rem}.form-input{padding:.75rem;border:1px solid var(--border, #e0e0e0);border-radius:.375rem;font-size:1rem;background-color:var(--background, white);color:var(--foreground, black)}.form-input:focus{outline:none;border-color:var(--primary, #007bff);box-shadow:0 0 0 2px #007bff40}.form-actions{display:flex;flex-direction:column;align-items:flex-start;gap:.75rem}.save-message{padding:.75rem;border-radius:.375rem;font-size:.9rem}.save-message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.save-message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.empty-state{text-align:center;padding:3rem 1rem;color:var(--muted-foreground, #666)}.loading{text-align:center;padding:2rem}.danger-zone-section{border-color:hsl(var(--destructive) / .3)}.theme-toggle-container{display:flex;align-items:center}.danger-zone h3{margin:0;font-size:1.25rem;font-weight:600;color:#dc2626}.danger-zone-description{margin:0;font-size:.9rem;color:var(--muted-foreground, #666)}.danger-zone-actions{display:flex;flex-direction:column;gap:.75rem}.sign-out-button,.delete-account-button{width:100%}.required{color:#dc2626}.form-hint{font-size:.8rem;color:var(--muted-foreground, #666);margin-top:-.25rem}.error-text{color:#dc2626;font-size:.875rem;margin-top:-.25rem}.activity-page{width:100%;max-width:600px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:600px;z-index:40;background-color:hsl(var(--background));padding:1rem;margin:0}.activity-page{padding-top:4.5rem}.page-header h1{margin:0;font-size:2rem;font-weight:700}.session-banner{position:fixed;top:4.5rem;left:50%;transform:translate(-50%);width:100%;max-width:600px;z-index:30;padding:0 1rem;background-color:hsl(var(--background))}.session-banner-link{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem 1rem;background-color:hsl(var(--accent));color:hsl(var(--accent-foreground));border:none;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .2s,opacity .2s;text-align:left}.session-banner-link:hover{background-color:hsl(var(--accent) / .8)}.session-banner-text{flex:1}.session-banner-arrow{font-size:1rem;margin-left:.5rem}.header-actions{display:flex;gap:.5rem}.refresh-button{padding:.75rem 1.5rem;background-color:#6c757d;color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.refresh-button:hover{background-color:#5a6268}.activity-page .matches-list{display:flex;flex-direction:column;gap:20px;margin-left:-1.25rem;margin-right:-1.25rem}@media(min-width:768px){.activity-page .matches-list{margin-left:0;margin-right:0;padding-left:1rem;padding-right:1rem}}.activity-page:has(.session-banner){padding-top:7.5rem}.activity-page:has(.session-banner) .matches-list{margin-top:0}.loading,.error{text-align:center;padding:2rem}.error{color:#dc3545}.add-game-form-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.add-game-form-content{background:hsl(var(--card));color:hsl(var(--card-foreground));padding:2rem;border-radius:.5rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.add-game-form-content h2{margin:0 0 1.5rem}.add-game-form-content h3{margin:1rem 0 .5rem;font-size:1.1rem}.form-section{margin-bottom:1.5rem}.form-section>label{display:block;margin-bottom:1rem}.form-section>label:not(:first-child){margin-top:1rem}.form-section label span{display:block;margin-bottom:.5rem;font-weight:500}.form-section input[type=text],.form-section input[type=number],.form-section select{width:100%;padding:.75rem;border:1px solid hsl(var(--input));background:hsl(var(--background));color:hsl(var(--foreground));border-radius:.5rem;font-size:1rem;box-sizing:border-box}.player-count-inputs{display:flex;gap:1rem}.player-count-inputs label{flex:1;margin-bottom:0}.toggle-label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.toggle-label input[type=checkbox]{width:auto;cursor:pointer}.toggle-label span{font-weight:500;margin:0}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid hsl(var(--border))}.player-selection{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.player-option{padding:.5rem 1rem;border:1px solid hsl(var(--border));border-radius:.5rem;background-color:hsl(var(--background));color:hsl(var(--foreground));cursor:pointer;transition:all .2s;font-size:.9rem}.player-option:hover:not(.disabled){background-color:hsl(var(--accent));border-color:hsl(var(--primary))}.player-option.selected{background-color:hsl(var(--primary));color:hsl(var(--primary-foreground));border-color:hsl(var(--primary))}.player-option.disabled{opacity:.5;cursor:not-allowed}.session-page{width:100%;max-width:600px;margin:0 auto;display:flex;flex-direction:column;padding-bottom:6rem;padding-top:1rem}.session-page .page-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem;width:100%;padding:1rem;box-sizing:border-box;min-height:-moz-fit-content;min-height:fit-content}.session-page .page-header-top{display:flex;justify-content:space-between;align-items:center;gap:1rem;width:100%}.session-page .page-header h1{margin:0;font-size:2rem;font-weight:700;text-align:left;width:100%}.session-page .header-actions{display:flex;gap:.5rem}.session-page .session-content{display:flex;flex-direction:column;gap:2rem;margin-top:0;padding-top:60px}.session-page .participants-section{display:flex;flex-direction:column;gap:1rem}.session-page .participants-section h2{margin:0;font-size:1.5rem;font-weight:600}.session-page .participants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.session-page .loading,.session-page .error{text-align:center;padding:2rem;font-size:1.1rem}.session-page .error{color:hsl(var(--destructive))}.session-page .empty-state{text-align:center;padding:2rem;color:hsl(var(--muted-foreground))}.session-page .matches-section{display:flex;flex-direction:column;gap:1rem}.session-page .matches-section-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.session-page .matches-section h2{margin:0;font-size:1.5rem;font-weight:600}.session-page .matches-list{display:flex;flex-direction:column;gap:20px;padding-left:0;padding-right:0}.new-match-button-desktop{display:none}.new-match-button-mobile{display:block;position:fixed;bottom:0;left:50%;transform:translate(-50%);width:calc(100% - 2rem);max-width:600px;z-index:40;height:3.5rem;font-size:1.125rem;margin-bottom:1rem}@media(max-width:640px){.session-page{padding-bottom:6rem}.session-page .page-header{margin-bottom:2rem}}.sessions-list-page{width:100%;max-width:600px;margin:0 auto;padding-top:7.5rem}.sessions-list-page .page-header{display:flex;flex-direction:column;gap:1rem;position:fixed;top:0;left:50%;transform:translate(-50%);width:100%;max-width:600px;z-index:40;background-color:hsl(var(--background));padding:1rem;margin:0}.sessions-list-page .page-header-top{display:flex;align-items:center;justify-content:flex-start;gap:1rem;width:100%}.sessions-list-page .page-header h1{margin:0;font-size:2rem;font-weight:700;text-align:left;width:100%}.sessions-list-page .loading,.sessions-list-page .error{text-align:center;padding:2rem}.sessions-list-page .error{color:hsl(var(--destructive))}.sessions-list-page .empty-state{text-align:center;padding:2rem;color:hsl(var(--muted-foreground))}.sessions-list-page .sessions-list{display:flex;flex-direction:column;gap:1rem}.sessions-list-page .session-card{background-color:hsl(var(--card));border:1px solid hsl(var(--border));border-radius:.5rem;padding:1.5rem;cursor:pointer;transition:background-color .2s,border-color .2s}.sessions-list-page .session-card:hover{background-color:hsl(var(--accent) / .5);border-color:hsl(var(--border))}.sessions-list-page .session-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.sessions-list-page .session-code{margin:0;font-size:1.5rem;font-weight:600}.sessions-list-page .session-time{font-size:.875rem;color:hsl(var(--muted-foreground))}.sessions-list-page .session-game{margin-bottom:.5rem;font-size:1rem;color:hsl(var(--foreground))}.sessions-list-page .session-participants{font-size:.875rem;color:hsl(var(--muted-foreground))}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:#666}#root{min-height:100vh}
