@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";*,: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: 0 0% 3.9%;--card: 0 0% 100%;--card-foreground: 0 0% 3.9%;--popover: 0 0% 100%;--popover-foreground: 0 0% 3.9%;--primary: 0 0% 9%;--primary-foreground: 0 0% 98%;--secondary: 0 0% 96.1%;--secondary-foreground: 0 0% 9%;--muted: 0 0% 96.1%;--muted-foreground: 0 0% 45.1%;--accent: 0 0% 96.1%;--accent-foreground: 0 0% 9%;--destructive: 0 84.2% 60.2%;--destructive-foreground: 0 0% 98%;--border: 0 0% 89.8%;--input: 0 0% 89.8%;--ring: 0 0% 3.9%;--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%;--radius: .5rem}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}}.absolute{position:absolute}.relative{position:relative}.left-3{left:.75rem}.right-2{right:.5rem}.right-3{right:.75rem}.top-1\/2{top:50%}.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}.mb-1{margin-bottom:.25rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mt-0{margin-top:0}.mt-12{margin-top:3rem}.mt-4{margin-top:1rem}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-10{height:2.5rem}.h-12{height:3rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-px{height:1px}.max-h-\[--radix-select-content-available-height\]{max-height:var(--radix-select-content-available-height)}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-9{width:2.25rem}.w-\[120px\]{width:120px}.w-\[180px\]{width:180px}.w-\[1px\]{width:1px}.w-\[60px\]{width:60px}.w-full{width:100%}.min-w-\[280px\]{min-width:280px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-\[1600px\]{max-width:1600px}.max-w-\[450px\]{max-width:450px}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.caption-bottom{caption-side:bottom}.origin-\[--radix-select-content-transform-origin\]{transform-origin:var(--radix-select-content-transform-origin)}.-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))}.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))}.animate-spin{animation:spin 1s linear infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-6{gap:1.5rem}.-space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(-.75rem * var(--tw-space-x-reverse));margin-left:calc(-.75rem * 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-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-auto{overflow:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.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-xl{border-radius:.75rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-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-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-destructive{background-color:hsl(var(--destructive))}.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-secondary{background-color:hsl(var(--secondary))}.bg-transparent{background-color:transparent}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.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-6{padding-left:1.5rem;padding-right:1.5rem}.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-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pl-2{padding-left:.5rem}.pl-9{padding-left:2.25rem}.pr-8{padding-right:2rem}.pr-9{padding-right:2.25rem}.pt-0{padding-top:0}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.text-base{font-size:1rem;line-height:1.5rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.text-card-foreground{color:hsl(var(--card-foreground))}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.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}.opacity-50{opacity:.5}.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-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-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)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-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}@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))}}.paused{animation-play-state:paused}html{scroll-behavior:smooth;overscroll-behavior:none}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;max-width:100vw;overscroll-behavior:none}.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))}.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\/50:hover{background-color:hsl(var(--muted) / .5)}.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\: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-80:hover{opacity:.8}.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-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-offset-2:focus-visible{--tw-ring-offset-width: 2px}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:z-50{z-index:50}.group:hover .group-hover\:scale-110{--tw-scale-x: 1.1;--tw-scale-y: 1.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))}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.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\=active\]\:bg-background[data-state=active]{background-color:hsl(var(--background))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:hsl(var(--muted))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:hsl(var(--muted-foreground))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:hsl(var(--foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.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\=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}@supports (backdrop-filter: var(--tw)){.supports-\[backdrop-filter\]\:bg-background\/60{background-color:hsl(var(--background) / .6)}}@media (min-width: 768px){.md\:text-sm{font-size:.875rem;line-height:1.25rem}}.\[\&\: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))}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0px}.\[\&_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-analytics-container{padding:0}.tab-navigation{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid var(--border-color);padding-bottom:0}.tab-button:hover{color:var(--text-dark)}.tab-button.active:hover{color:#646464}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--white);border-radius:var(--radius);padding:10px 4px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:6px;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-icon{width:28px;height:28px;background:#646464;border-radius:5px;display:flex;align-items:center;justify-content:center;color:var(--white);flex-shrink:0}.stat-icon svg{width:14px;height:14px}.stat-content{display:flex;flex-direction:column;justify-content:center;flex:1}.stat-content h3{font-size:12px;color:var(--text-gray);margin-bottom:2px;font-weight:500;line-height:1.2}.stat-value{font-size:14px;font-weight:700;color:#36393f;margin:0;line-height:1.2}.stat-label{font-size:9px;color:var(--text-gray);line-height:1.2;display:block;word-wrap:break-word}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(480px,1fr));gap:24px}.chart-card{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}.chart-card h2{font-size:18px;font-weight:600;color:var(--text-dark);margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.chart-card-wide{grid-column:span 2}.word-cloud{display:flex;flex-wrap:wrap;gap:12px 16px;padding:16px;align-items:center;justify-content:center;min-height:150px}.word-cloud-item{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;background:linear-gradient(135deg,#ffffff1a,#ffffff0d);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease;cursor:default;position:relative;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.1)}.word-cloud-item:hover{transform:scale(1.1);background:linear-gradient(135deg,#fff3,#ffffff1a);z-index:10}.word-count{font-size:12px;background:#0000001a;padding:2px 8px;border-radius:12px;margin-left:4px;font-weight:500;color:inherit;opacity:.7}.recharts-text,.recharts-cartesian-axis-tick-value{font-size:12px;fill:var(--text-gray)}.recharts-tooltip-wrapper{outline:none}.recharts-default-tooltip{background:var(--white)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;box-shadow:var(--shadow-sm)!important}.recharts-tooltip-label{color:var(--text-dark)!important;font-weight:600!important}.recharts-tooltip-item{color:var(--text-gray)!important}@media (max-width: 1200px){.chart-card-wide{grid-column:span 1}}@media (max-width: 768px){.charts-grid,.stats-grid{grid-template-columns:1fr}.stat-card{padding:16px}.stat-value{font-size:24px}.tab-navigation{flex-direction:row;overflow-x:auto}}:root{--primary-gradient: linear-gradient(135deg, #2361d9 0%, #5e24d9 100%);--primary-color: #2361d9;--secondary-color: #5e24d9;--text-dark: #36393f;--text-gray: #8c8c8c;--bg-light: #f8f8fa;--border-color: #eceff5;--white: #ffffff;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--radius: 16px;--radius-sm: 8px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:linear-gradient(180deg,#f8f9ff,#fff);color:var(--text-dark);min-height:100vh;overscroll-behavior-y:none}.data-table-container{max-width:1600px;margin:0 auto;padding:0 20px 40px}.table-header-sticky{position:sticky;position:-webkit-sticky;top:0;z-index:100;background:var(--white);border-radius:var(--radius) var(--radius) 0 0;padding:24px 32px;margin-bottom:0;box-shadow:0 2px 12px #00000014}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-buttons{display:flex;gap:12px}.logo-section{display:flex;align-items:center}.logo-section a{display:flex;align-items:center;transition:transform .3s ease}.logo-section a:hover{transform:scale(1.05)}.logo{height:28px;width:auto;-o-object-fit:contain;object-fit:contain}.header-content{margin-bottom:20px}.header-title h1{font-size:22px;font-weight:700;color:#36393f;margin-bottom:4px}.subtitle{color:var(--text-gray);font-size:14px;font-weight:500}.tabs-container{max-width:1600px;margin:0 auto 24px;padding:0 20px}.tabs{display:flex;gap:8px;border-bottom:2px solid var(--border-color);padding-bottom:0}.tab{display:flex;align-items:center;gap:8px;padding:12px 20px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--text-gray);font-size:15px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;bottom:-2px}.tab:hover{color:var(--text-dark);background:#6366f10d}.tab-active{color:#646464!important;border-bottom-color:#646464!important;font-weight:600}.tab svg{flex-shrink:0}.controls{max-width:1600px;margin:0 auto;padding:0 20px 20px;display:flex;gap:12px;align-items:stretch;flex-wrap:wrap}.search-bar{position:relative;display:flex;align-items:center;flex:1;min-width:280px;max-width:450px}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#6b7280;pointer-events:none;z-index:1;display:flex;align-items:center;justify-content:center}.search-input{width:100%;height:42px;padding:0 44px;border:1px solid var(--border-color);border-radius:8px;background:var(--white);color:var(--text-dark);font-size:14px;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-weight:400;transition:all .2s ease;line-height:42px}.search-input:hover{border-color:#d1d5db}.search-input:focus{outline:none;border-color:#646464;box-shadow:0 0 0 3px #6464641a}.search-input::-moz-placeholder{color:#9ca3af;font-weight:400}.search-input::placeholder{color:#9ca3af;font-weight:400}.clear-search{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:24px;height:24px;padding:0;background:transparent;border:none;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.clear-search:hover{background:#f3f4f6;color:#6b7280}.results-info{max-width:1600px;margin:0 auto;padding:0 20px 16px;color:var(--text-gray);font-size:14px}.filter-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;flex:1}.filter-select{height:42px;padding:0 16px;border:1px solid var(--border-color);border-radius:8px;background:var(--white);color:var(--text-dark);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:150px;display:flex;align-items:center}.filter-select:hover{border-color:#646464}.filter-select:focus{outline:none;border-color:#646464;box-shadow:0 0 0 3px #6464641a}.filter-button{display:flex;align-items:center;gap:8px;height:42px;padding:0 16px;background:var(--white);border:1px solid var(--border-color);border-radius:8px;color:var(--text-dark);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.filter-button:hover{border-color:#646464;background:var(--bg-light)}.export-button{display:flex;align-items:center;gap:8px;height:42px;padding:0 20px;background:#646464;color:var(--white);border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.export-button:hover{background:#36393f;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.export-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#646464;color:var(--white);border:none;border-radius:8px;font-weight:600;font-size:13px;cursor:pointer;transition:all .3s ease}.analytics-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;background:var(--white);color:var(--primary-color);border:2px solid var(--primary-color);border-radius:12px;font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.analytics-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#2563eb;transition:left .3s ease;z-index:0}.analytics-btn:hover:before{left:0}.analytics-btn:hover{color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px #5e24d94d;border-color:transparent}.analytics-btn svg,.analytics-btn span{position:relative;z-index:1}.export-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003;background:#36393f}.header-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:20px}.tab-navigation{display:flex;gap:8px;border-bottom:1px solid var(--border-color);padding-bottom:0;flex:1}.tab-button{display:flex;align-items:center;gap:6px;padding:10px 16px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-gray);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;position:relative;bottom:-1px}.tab-button:hover{color:var(--text-dark);background:var(--bg-light)}.tab-button.active{color:#646464;border-bottom-color:#646464;font-weight:600}.view-toggle{display:flex;gap:4px;background:var(--bg-light);padding:4px;border-radius:8px;border:1px solid var(--border-color)}.view-toggle-btn{display:flex;align-items:center;justify-content:center;padding:8px 12px;background:transparent;border:none;border-radius:6px;color:var(--text-gray);cursor:pointer;transition:all .2s ease}.view-toggle-btn:hover{color:var(--text-dark);background:#0000000d}.view-toggle-btn.active{background:var(--white);color:#646464;box-shadow:0 1px 3px #0000001a}.filters-container{display:flex;gap:16px;align-items:center;flex-wrap:wrap}.search-box{min-width:300px;max-width:400px;flex:1;display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--bg-light);border-radius:10px;border:1px solid var(--border-color);transition:all .3s ease}.search-box:focus-within{background:var(--white);border-color:var(--primary-color);box-shadow:0 0 0 3px #5e24d91a}.search-box svg{color:var(--text-gray);flex-shrink:0}.search-box input{flex:1;border:none;background:none;outline:none;font-size:14px;color:var(--text-dark);min-width:0}.search-box input::-moz-placeholder{color:var(--text-gray)}.search-box input::placeholder{color:var(--text-gray)}.filter-group{display:flex;gap:12px;align-items:center}.filter-item{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-light);border-radius:12px;border:1px solid transparent;transition:all .3s ease}.filter-item:hover{background:var(--white);border-color:var(--border-color)}.filter-item svg{color:var(--text-gray)}.filter-item select{border:none;background:none;outline:none;font-size:14px;color:var(--text-dark);cursor:pointer;font-weight:500}.category-filter,.language-filter{position:relative}.category-dropdown-trigger,.language-dropdown-trigger{border:none;background:none;outline:none;font-size:14px;color:var(--text-dark);cursor:pointer;font-weight:500;padding:0;min-width:120px;text-align:left}.category-dropdown,.language-dropdown{position:absolute;top:100%;left:0;margin-top:8px;background:var(--white);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 16px #0000001f;z-index:200;min-width:250px;max-width:300px}.category-dropdown-header,.language-dropdown-header{padding:12px;border-bottom:1px solid var(--border-color)}.select-all-btn{width:100%;padding:8px 12px;background:#2563eb;color:var(--white);border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease}.select-all-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #5e24d94d}.category-list,.language-list{max-height:300px;overflow-y:auto;padding:8px}.category-option,.language-option{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer;transition:background .2s ease}.category-option:hover,.language-option:hover{background:var(--bg-light)}.category-option input[type=checkbox],.language-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary-color)}.category-option span,.language-option>span{font-size:14px;color:var(--text-dark);flex:1}.language-label{display:flex;align-items:center;gap:8px;flex:1}.language-flag{font-size:18px}.th-language{width:100px}.th-release-date{width:120px}.td-release-date{font-size:13px;color:var(--text-gray)}.th-description{width:200px;min-width:150px}.td-description{padding:20px 16px;max-width:250px}.description-text{font-size:13px;color:var(--text-gray);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;cursor:help}.th-summary{width:250px;min-width:200px}.td-summary{padding:20px 16px;max-width:300px;position:relative}.summary-text{font-size:13px;color:var(--text-gray);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;cursor:pointer;position:relative;transition:all .3s ease}.summary-text:hover{color:var(--primary-blue)}.summary-text.expanded{-webkit-line-clamp:unset;display:block;background:#2d86ff0d;padding:8px;border-radius:6px;border-left:3px solid var(--primary-blue)}.summary-text:not(.expanded):hover:after{content:attr(data-tooltip);position:absolute;left:0;top:100%;margin-top:8px;padding:8px 12px;background:#000000e6;color:#fff;border-radius:6px;font-size:12px;line-height:1.4;max-width:300px;width:-moz-max-content;width:max-content;z-index:1000;white-space:normal;box-shadow:0 4px 12px #0003;animation:fadeIn .15s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.expand-all-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:inherit;font:inherit;cursor:pointer;transition:color .3s ease;padding:0}.expand-all-btn:hover{color:var(--primary-color)}.td-language{padding:20px 16px}.language-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-light);border-radius:20px;font-size:13px;font-weight:500;color:var(--text-dark)}.language-badge .language-flag{font-size:16px}.clear-filters{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--white);border:1px solid var(--border-color);border-radius:12px;color:var(--text-gray);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.clear-filters:hover{background:#fee;border-color:#fcc;color:#d00}.toggle-screenshots-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--white);border:2px solid var(--border-color);border-radius:12px;color:var(--text-gray);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.toggle-screenshots-btn:hover{background:var(--bg-light);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px);box-shadow:0 2px 8px #5e24d926}.table-wrapper{background:var(--white);border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-sm);overflow-x:auto;max-width:100%}.data-table{width:100%;min-width:1200px;border-collapse:collapse}.data-table thead{background:var(--bg-light);border-bottom:2px solid var(--border-color)}.data-table th{padding:16px;text-align:left;font-weight:600;font-size:12px;letter-spacing:.5px;color:var(--text-gray);background:var(--bg-light)}.data-table th button{display:flex;align-items:center;gap:6px;background:none;border:none;color:inherit;font:inherit;cursor:pointer;transition:color .3s ease}.data-table th button:hover{color:var(--primary-color)}.data-table tbody tr{border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.data-table tbody tr:hover{background:#fafbff}.data-table td{padding:20px 16px;font-size:14px;color:var(--text-dark)}.td-rank{font-weight:600;color:var(--text-gray);width:60px}.app-name-container{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:6px;width:100%;position:relative;min-height:60px}.app-name-container:hover .view-app-btn-inline{opacity:1;visibility:visible}.app-name{display:flex;align-items:center;gap:12px;width:100%}.app-icon{width:40px;height:40px;border-radius:10px;background:#2563eb;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:600;font-size:14px;flex-shrink:0}.app-icon-img{width:40px;height:40px;border-radius:10px;-o-object-fit:cover;object-fit:cover}.app-name-text{display:flex;flex-direction:column;gap:2px;flex:1}.app-name-title{font-weight:600;color:var(--text-dark);line-height:1.3}.app-subtitle{font-size:12px;color:var(--text-gray);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.view-app-btn-inline{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;background:#2563eb;color:var(--white);border-radius:6px;font-size:11px;font-weight:600;text-decoration:none;white-space:nowrap;transition:opacity .2s ease,visibility .2s ease,transform .2s ease,background .2s ease;box-shadow:0 2px 8px #2563eb33;opacity:0;visibility:hidden;margin-left:52px;position:absolute;bottom:8px;left:0}.view-app-btn-inline:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d;background:#1d4ed8}.category-badge{display:inline-block;padding:6px 12px;background:var(--bg-light);border-radius:20px;font-size:12px;font-weight:500;color:var(--text-gray)}.revenue-amount{font-weight:700;font-size:16px;color:#2563eb}.rating{display:inline-flex;align-items:center;gap:4px;font-weight:600}.td-developer{color:var(--text-gray);font-size:13px;max-width:150px;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4}.th-screenshots,.td-screenshots{width:100px}.screenshots-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--bg-light);border:1px solid var(--border-color);border-radius:6px;color:var(--text-gray);font-size:11px;font-weight:500;cursor:pointer;transition:all .3s ease}.screenshots-btn svg{width:14px;height:14px}.screenshots-btn:hover,.screenshots-btn.expanded{background:#646464;color:var(--white);border-color:transparent}.screenshots-btn svg:last-child{margin-left:2px;transition:transform .3s ease}.screenshots-row td{padding:0;background:var(--bg-light)}.screenshots-gallery{display:flex;gap:12px;padding:20px;overflow-x:auto;-webkit-overflow-scrolling:touch}.screenshot-img{max-height:200px;max-width:350px;width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:8px;box-shadow:0 2px 8px #0000001a;flex-shrink:0}.view-app-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;background:#2563eb;color:var(--white);border-radius:8px;font-size:13px;font-weight:600;text-decoration:none;transition:all .3s ease;white-space:nowrap}.view-app-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5e24d94d}.no-results{padding:60px 20px;text-align:center;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.no-results p{color:var(--text-gray);margin-bottom:16px;font-size:16px}.no-results button{padding:10px 24px;background:#2563eb;color:var(--white);border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease}.no-results button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #5e24d94d}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:24px;padding:32px;background:linear-gradient(135deg,#f8f9ff,#fff);border-radius:var(--radius);box-shadow:0 4px 20px #0000000d;margin-top:32px;margin-bottom:40px}.pagination-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--white);border:1px solid var(--border-color);border-radius:10px;color:var(--text-dark);font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.pagination-btn:hover:not(:disabled){background:#2563eb;color:var(--white);border-color:transparent;transform:translateY(-2px);box-shadow:0 4px 12px #2563eb33}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:16px;font-weight:700;color:#2563eb}.grid-wrapper{background:var(--bg-light);padding:24px;border-radius:var(--radius)}.apps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.app-card{background:var(--white);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm);transition:all .3s ease;display:flex;flex-direction:column;gap:16px;position:relative}.app-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.app-card-hover-link{position:absolute;top:16px;right:16px;display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#2563ebe6;border-radius:50%;color:var(--white);opacity:0;visibility:hidden;transition:all .2s ease;box-shadow:0 2px 8px #0003;z-index:10}.app-card:hover .app-card-hover-link{opacity:1;visibility:visible}.app-card-hover-link:hover{background:#1d4ed8;transform:scale(1.1);box-shadow:0 4px 12px #2563eb66}.app-card-header{display:flex;gap:12px;align-items:flex-start}.app-card-icon{width:60px;height:60px;border-radius:14px;flex-shrink:0;-o-object-fit:cover;object-fit:cover;background:#2563eb;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:24px}.app-card-title{flex:1;min-width:0}.app-card-title h3{font-size:18px;font-weight:700;color:var(--text-dark);margin-bottom:4px;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.app-card-subtitle{font-size:13px;color:var(--text-gray);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.app-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:11px;color:var(--text-gray);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:16px;font-weight:700;color:var(--text-dark)}.stat-value.revenue{color:#2563eb}.app-card-summary{padding:12px;background:var(--bg-light);border-radius:8px}.app-card-summary p{font-size:13px;color:var(--text-gray);line-height:1.5;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.app-card-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.app-card-category,.app-card-language{padding:6px 12px;background:var(--bg-light);border-radius:20px;font-size:12px;font-weight:500;color:var(--text-gray)}.app-card-screenshots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;position:relative}.app-card-screenshot{width:100%;aspect-ratio:9/16;-o-object-fit:cover;object-fit:cover;border-radius:8px;cursor:pointer;transition:all .2s ease}.app-card-screenshot:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003}.more-screenshots{position:absolute;top:0;right:0;width:calc(33.33% - 5.33px);height:100%;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:700;font-size:18px;pointer-events:none}.app-card-link{display:block;text-align:center;padding:12px;background:#2563eb;color:var(--white);border-radius:8px;font-weight:600;font-size:14px;text-decoration:none;transition:all .2s ease}.app-card-link:hover{background:#1d4ed8;transform:translateY(-2px)}.floating-cta-button{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:16px 28px;background:#646464;color:#fff;border:none;border-radius:50px;font-size:16px;font-weight:700;cursor:pointer;box-shadow:0 4px 12px #00000026;z-index:1000;transition:all .3s ease}.floating-cta-button:hover{transform:translate(-50%) translateY(-4px);box-shadow:0 8px 20px #0003;background:#36393f}.promo-modal-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;animation:fadeIn .3s ease}.promo-modal-content{background:#fff;border-radius:16px;max-width:560px;width:100%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 24px 48px #0000004d;animation:slideUpModal .4s ease}@keyframes slideUpModal{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close-btn{position:absolute;top:16px;right:16px;background:#0000000d;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:10;color:#6b7280}.modal-close-btn:hover{background:#0000001a;color:#111827;transform:rotate(90deg)}.modal-header{text-align:center;padding:32px 28px 24px;background:#f9fafb!important;border-radius:16px 16px 0 0;display:flex;flex-direction:column;gap:12px}.modal-header h2{font-size:24px;font-weight:700;color:#111827;margin:0;line-height:1.3}.modal-header p{font-size:15px;color:#374151;margin:0;font-weight:500;line-height:1.5}.modal-header-subtitle{font-size:14px;color:#6b7280;font-weight:400;margin:0!important;line-height:1.5}.modal-video{width:100%;aspect-ratio:16/9;background:#000}.modal-video iframe{display:block}.modal-promo{padding:32px 28px;text-align:center;background:#fff;border-radius:0 0 16px 16px}.modal-promo-text{font-size:18px;color:#1f2937;margin-bottom:12px;font-weight:600;line-height:1.4}.modal-promo-subtext{font-size:14px;color:#6b7280;margin-bottom:14px;font-weight:500}.promo-code-large{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:20px;padding:18px;background:#f3f4f6;border-radius:12px;border:2px dashed #d1d5db}.code-text{font-size:22px;font-weight:700;color:#374151;letter-spacing:2px;font-family:SF Mono,Monaco,Courier New,monospace}.copy-btn-large{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#1f2937;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #0000001a}.copy-btn-large:hover{background:#111827;transform:translateY(-2px);box-shadow:0 4px 10px #00000026}.modal-cta-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 36px;background:linear-gradient(135deg,#1f2937,#111827);color:#fff;text-decoration:none;border-radius:10px;font-size:16px;font-weight:600;transition:all .2s ease;box-shadow:0 3px 12px #0003}.modal-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000040}.screenshot-lightbox{position:fixed;inset:0;background:#000000f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px;animation:fadeIn .2s ease;cursor:zoom-out}.lightbox-close-btn{position:absolute;top:20px;right:20px;background:#ffffff1a;border:none;width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:10;color:#fff}.lightbox-close-btn:hover{background:#fff3;transform:rotate(90deg)}.lightbox-image{max-width:95%;max-height:95vh;width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px #00000080;cursor:default;animation:scaleIn .3s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width: 768px){.data-table-container{padding:0 12px 20px}.table-header-sticky{padding:16px;border-radius:0}.header-top{flex-direction:column;align-items:flex-start;gap:12px}.logo{height:24px}.header-title h1{font-size:22px}.export-btn{width:100%;justify-content:center}.header-controls{flex-direction:column;align-items:stretch;gap:12px}.tab-navigation{overflow-x:auto}.view-toggle{width:-moz-fit-content;width:fit-content}.apps-grid{grid-template-columns:1fr}.filters-container{flex-direction:column;align-items:stretch}.search-box{min-width:100%;max-width:100%}.filter-group{flex-direction:column;width:100%}.filter-item{width:100%}.table-wrapper{max-height:calc(100vh - 350px)}.data-table{min-width:1000px}.th-developer,.td-developer,.th-screenshots,.td-screenshots{display:none}.pagination-controls{flex-direction:column;gap:12px}.pagination-btn{width:100%;justify-content:center}.floating-cta-button{bottom:16px;padding:12px 20px;font-size:14px}.promo-modal-content{max-height:95vh}.modal-header{padding:32px 24px 24px}.modal-header h2{font-size:24px}.modal-header p{font-size:14px}.modal-promo{padding:24px}.promo-code-large{flex-direction:column}.code-text{font-size:24px}.modal-cta-btn{width:100%;justify-content:center}.lightbox-image{max-width:98%;max-height:90vh}.lightbox-close-btn{top:10px;right:10px;width:40px;height:40px}}@media (max-width: 480px){.header-title h1{font-size:20px}.data-table{min-width:800px}.th-installs,.td-installs,.th-rating,.td-rating{display:none}}.screensdesign-link{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:#2563eb;text-decoration:none;margin-top:4px;padding:2px 6px;border-radius:4px;background:#eff6ff;transition:all .2s ease}.screensdesign-link:hover{background:#dbeafe;color:#1d4ed8}.onboarding-badge{display:inline-block;padding:4px 8px;background:#f0fdf4;color:#166534;border-radius:6px;font-size:12px;font-weight:500}.paywall-badge{display:inline-block;padding:4px 8px;background:#fef3c7;color:#92400e;border-radius:6px;font-size:12px;font-weight:500}.na-badge{color:#9ca3af;font-size:14px}.filter-active{background:#2563eb!important;color:#fff!important}.chart-description{font-size:14px;color:var(--text-gray);margin-top:-10px;margin-bottom:20px}.chart-insights{margin-top:20px;padding:16px;background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:8px}.chart-insights p{font-size:14px;color:var(--text-dark);margin:0}.insight-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.insight-card h2{color:#fff;margin-bottom:20px}.insights-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.insight-item{background:#ffffff1a;padding:20px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.insight-item h3{color:#fff;font-size:16px;margin-bottom:8px;font-weight:600}.insight-item p{color:#ffffffe6;font-size:14px;line-height:1.6;margin:0}.insight-item strong{color:#fff;font-weight:700}:root{--primary-gradient: linear-gradient(135deg, #2361d9 0%, #5e24d9 100%);--primary-color: #2361d9;--secondary-color: #5e24d9;--text-dark: #36393f;--text-gray: #8c8c8c;--bg-light: #f8f8fa;--border-color: #eceff5;--white: #ffffff;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .08);--shadow-md: 0 4px 16px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16)}*{margin:0;padding:0;box-sizing:border-box}.cluster-canvas-container{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-light);min-height:100vh;padding:20px}.cluster-header{text-align:center;margin-bottom:30px;padding:40px 20px;background:var(--primary-gradient);border-radius:16px;color:#fff;box-shadow:var(--shadow-md)}.cluster-header h1{font-size:2.5em;font-weight:700;margin-bottom:10px}.cluster-header p{font-size:1.2em;opacity:.9}.cluster-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--white);padding:24px;border-radius:16px;text-align:center;box-shadow:var(--shadow-sm);transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-value{font-size:2.5em;font-weight:700;color:var(--primary-color);margin-bottom:8px}.stat-label{font-size:.9em;color:var(--text-gray);text-transform:uppercase;letter-spacing:.5px}.cluster-controls{background:var(--white);padding:20px;border-radius:16px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.search-input{width:100%;padding:14px 20px;font-size:1em;border:2px solid var(--border-color);border-radius:12px;background:var(--bg-light);transition:all .3s ease;margin-bottom:15px}.search-input:focus{outline:none;border-color:var(--primary-color);background:var(--white);box-shadow:0 0 0 3px #2361d91a}.control-row{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}.control-row label{display:flex;align-items:center;gap:12px;font-size:.95em;color:var(--text-dark)}.control-row input[type=range]{width:200px;height:6px;border-radius:3px;background:var(--border-color);outline:none;cursor:pointer}.control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary-gradient);cursor:pointer;box-shadow:var(--shadow-sm)}.control-row input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary-gradient);cursor:pointer;border:none;box-shadow:var(--shadow-sm)}.control-row span{font-weight:600;color:var(--primary-color);min-width:60px}.toggle-btn{padding:12px 24px;font-size:1em;font-weight:600;background:var(--primary-gradient);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm)}.toggle-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.toggle-btn:active{transform:translateY(0)}.canvas-container{background:var(--white);border-radius:16px;box-shadow:var(--shadow-sm);height:800px;overflow:hidden;position:relative}.canvas-container svg{cursor:grab;display:block}.canvas-container svg:active{cursor:grabbing}.bubble{cursor:pointer;transition:all .3s ease}.bubble circle{filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.bubble text{text-shadow:0 2px 4px rgba(0,0,0,.3)}.loading{text-align:center;padding:60px;font-size:1.2em;color:var(--text-gray)}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--white);border-radius:20px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:30px;border-bottom:2px solid var(--border-color);background:var(--primary-gradient);color:#fff;border-radius:20px 20px 0 0}.modal-header h2{font-size:2em;font-weight:700}.close-btn{background:#fff3;border:none;color:#fff;font-size:2em;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1}.close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.modal-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px;padding:30px;background:var(--bg-light)}.modal-stat{text-align:center;padding:16px;background:var(--white);border-radius:12px;box-shadow:var(--shadow-sm)}.modal-stat-label{font-size:.85em;color:var(--text-gray);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.modal-stat-value{font-size:1.5em;font-weight:700;color:var(--primary-color)}.modal-section{padding:30px;border-bottom:1px solid var(--border-color)}.modal-section:last-child{border-bottom:none}.modal-section h3{font-size:1.4em;font-weight:600;color:var(--text-dark);margin-bottom:20px}.app-list{display:flex;flex-direction:column;gap:12px}.app-list.scrollable{max-height:400px;overflow-y:auto;padding-right:8px}.app-item{background:var(--bg-light);padding:16px;border-radius:12px;border:1px solid var(--border-color);display:flex;align-items:flex-start;gap:16px;transition:all .2s ease}.app-item:hover{background:var(--white);border-color:var(--primary-color);transform:translate(4px)}.app-icon{width:80px;height:80px;border-radius:16px;-o-object-fit:cover;object-fit:cover;flex-shrink:0;box-shadow:var(--shadow-sm)}.app-info{flex:1;min-width:0}.app-name-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}.app-name{font-weight:600;color:var(--text-dark);font-size:1.2em;flex:1}.app-store-link{padding:6px 14px;font-size:.85em;font-weight:600;background:var(--primary-gradient);color:#fff;text-decoration:none;border-radius:8px;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.app-store-link:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.app-meta{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.app-category{font-size:.9em;color:var(--primary-color);font-weight:600}.app-developer,.app-release-date{font-size:.85em;color:var(--text-gray)}.meta-separator{color:var(--border-color);font-size:.8em}.app-short-description{font-size:.95em;color:var(--text-dark);line-height:1.5;margin-bottom:8px;font-weight:500}.app-full-description{font-size:.9em;color:var(--text-gray);line-height:1.6;margin-bottom:12px;white-space:pre-line}.app-actions{margin-top:10px}.view-screenshots-btn{padding:8px 16px;font-size:.9em;background:var(--primary-gradient);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-top:8px}.view-screenshots-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}.app-metrics{display:flex;gap:20px}.metric{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.metric-label{font-size:.75em;color:var(--text-gray);text-transform:uppercase}.metric-value{font-size:.95em;font-weight:600;color:var(--primary-color)}.app-item-small{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-light);border-radius:8px;transition:all .2s ease;gap:12px}.app-item-small:hover{background:var(--white);transform:translate(4px)}.app-icon-small{width:40px;height:40px;border-radius:8px;-o-object-fit:cover;object-fit:cover;flex-shrink:0;box-shadow:var(--shadow-sm)}.app-item-small a{color:var(--text-dark);text-decoration:none;font-weight:500;flex:1}.app-item-small a:hover{color:var(--primary-color)}.app-revenue-small{font-size:.85em;font-weight:600;color:var(--text-gray);margin-left:12px}.app-list.scrollable::-webkit-scrollbar{width:8px}.app-list.scrollable::-webkit-scrollbar-track{background:var(--bg-light);border-radius:4px}.app-list.scrollable::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.app-list.scrollable::-webkit-scrollbar-thumb:hover{background:var(--text-gray)}.screenshot-modal{background:var(--white);border-radius:20px;max-width:1200px;width:100%;max-height:95vh;overflow:hidden;box-shadow:var(--shadow-lg);animation:slideUp .3s ease;display:flex;flex-direction:column}.screenshot-header{display:flex;justify-content:space-between;align-items:center;padding:24px 30px;border-bottom:2px solid var(--border-color);background:var(--primary-gradient);color:#fff}.screenshot-header h2{font-size:1.5em;font-weight:700;margin-bottom:4px}.screenshot-header p{font-size:.9em;opacity:.9}.screenshot-container{position:relative;flex:1;display:flex;align-items:center;justify-content:center;background:#000;min-height:500px;overflow:hidden}.screenshot-image{max-width:100%;max-height:70vh;-o-object-fit:contain;object-fit:contain;display:block}.screenshot-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffffe6;border:none;color:var(--text-dark);font-size:3em;width:60px;height:60px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10;box-shadow:var(--shadow-md)}.screenshot-nav:hover{background:#fff;transform:translateY(-50%) scale(1.1)}.screenshot-nav.prev{left:20px}.screenshot-nav.next{right:20px}.screenshot-thumbnails{display:flex;gap:12px;padding:20px;overflow-x:auto;background:var(--bg-light);border-top:1px solid var(--border-color)}.thumbnail{width:80px;height:80px;-o-object-fit:cover;object-fit:cover;border-radius:8px;cursor:pointer;border:3px solid transparent;transition:all .2s ease;flex-shrink:0}.thumbnail:hover{border-color:var(--primary-color);transform:scale(1.05)}.thumbnail.active{border-color:var(--primary-color);box-shadow:var(--shadow-md)}@media (max-width: 768px){.cluster-header h1{font-size:1.8em}.cluster-header p{font-size:1em}.stat-value{font-size:2em}.control-row{flex-direction:column;align-items:flex-start}.control-row label,.control-row input[type=range]{width:100%}.canvas-container{height:500px}.modal-content{max-height:95vh}.modal-header h2{font-size:1.5em}.modal-stats{grid-template-columns:repeat(2,1fr)}.app-item{flex-direction:column;align-items:flex-start}.app-metrics{width:100%;justify-content:space-between}.app-icon{width:60px;height:60px}.screenshot-nav{width:50px;height:50px;font-size:2em}.screenshot-nav.prev{left:10px}.screenshot-nav.next{right:10px}.screenshot-container{min-height:400px}.thumbnail{width:60px;height:60px}}.cluster-grid-container{padding:2rem;max-width:1800px;margin:0 auto}.cluster-grid-header{margin-bottom:2rem}.cluster-grid-header h1{font-size:2.5rem;margin-bottom:.5rem}.cluster-grid-stats{display:flex;gap:2rem;color:#666;font-size:.95rem}.cluster-grid-controls{display:flex;gap:2rem;margin-bottom:2rem;padding:1rem;background:#f5f5f5;border-radius:8px}.control-group{display:flex;align-items:center;gap:.5rem}.control-group label{font-weight:500;color:#333}.control-group select{padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:.95rem}.cluster-grid{display:flex;gap:2rem}.cluster-grid.with-sidebar .cluster-cards{flex:1}.cluster-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;width:100%}.cluster-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .2s ease}.cluster-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a;border-color:#3b82f6}.cluster-card-icon{position:relative;height:70px;margin-bottom:1rem;display:flex;align-items:center}.cluster-card-icon .icon-overlay{width:56px;height:56px;border-radius:12px;border:3px solid white;box-shadow:0 2px 8px #0000001a;position:absolute;-o-object-fit:cover;object-fit:cover}.cluster-card-icon .icon-0{left:0;z-index:3}.cluster-card-icon .icon-1{left:35px;z-index:2}.cluster-card-icon .icon-2{left:70px;z-index:1}.cluster-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.cluster-card-header h3{font-size:1.2rem;margin:0;color:#1a1a1a}.cluster-size{font-size:.85rem;color:#666;background:#f0f0f0;padding:.25rem .75rem;border-radius:12px}.cluster-tags{color:#666;font-size:.9rem;margin-bottom:1rem;line-height:1.4;min-height:40px}.cluster-stats{display:flex;gap:1rem;padding-top:1rem;border-top:1px solid #eee}.cluster-stats .stat{flex:1;display:flex;flex-direction:column;gap:.25rem}.cluster-stats .stat-label{font-size:.75rem;color:#999;text-transform:uppercase;letter-spacing:.5px}.cluster-stats .stat-value{font-size:.95rem;font-weight:600;color:#333}.cluster-sidebar{position:sticky;top:2rem;width:450px;background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:2rem;max-height:calc(100vh - 4rem);overflow-y:auto;flex-shrink:0}.sidebar-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;cursor:pointer;color:#999;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.sidebar-close:hover{background:#f5f5f5;color:#333}.sidebar-content h2{margin:0 0 .5rem;font-size:1.8rem}.sidebar-tags{color:#666;font-size:.9rem;margin-bottom:1.5rem;line-height:1.5}.sidebar-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:2rem;padding:1rem;background:#f9f9f9;border-radius:8px}.sidebar-stat{display:flex;flex-direction:column;gap:.25rem}.sidebar-stat .label{font-size:.75rem;color:#999;text-transform:uppercase;letter-spacing:.5px}.sidebar-stat .value{font-size:1.1rem;font-weight:600;color:#333}.sidebar-content h3{margin:2rem 0 1rem;font-size:1.2rem;color:#333}.sidebar-apps{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto}.sidebar-app{display:flex;gap:.75rem;padding:.75rem;background:#f9f9f9;border-radius:8px;transition:background .2s}.sidebar-app:hover{background:#f0f0f0}.sidebar-app img{width:48px;height:48px;border-radius:10px;flex-shrink:0;-o-object-fit:cover;object-fit:cover}.sidebar-app-info{flex:1;min-width:0}.sidebar-app-info h4{margin:0 0 .25rem;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-app-info p{margin:0;font-size:.85rem;color:#666}.sidebar-related{display:flex;flex-direction:column;gap:.5rem}.sidebar-related-item{display:flex;gap:.75rem;padding:.75rem;background:#f9f9f9;border-radius:8px;cursor:pointer;transition:all .2s}.sidebar-related-item:hover{background:#e8f0fe;transform:translate(4px)}.related-icon{width:40px;height:40px;flex-shrink:0}.related-icon img{width:100%;height:100%;border-radius:8px;-o-object-fit:cover;object-fit:cover}.related-info{flex:1;min-width:0}.related-info h4{margin:0 0 .25rem;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.related-info p{margin:0;font-size:.8rem;color:#666}.cluster-grid-loading,.cluster-grid-error{text-align:center;padding:4rem;font-size:1.2rem;color:#666}.app{min-height:100vh;display:flex;flex-direction:column;position:relative}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.loader{width:48px;height:48px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container p{color:var(--text-gray);font-size:14px}.error-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:20px}.error-message{color:#d00;font-size:16px;font-weight:500}.upload-label,.upload-label-inline{position:relative;display:inline-block;padding:12px 24px;background:var(--primary-gradient);color:var(--white);border-radius:12px;font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease}.upload-label:hover,.upload-label-inline:hover{transform:translateY(-2px);box-shadow:0 8px 24px #5e24d94d}.upload-label input[type=file],.upload-label-inline input[type=file]{position:absolute;opacity:0;width:0;height:0}.upload-section{max-width:1400px;margin:40px auto 0;padding:0 20px;text-align:center}.upload-label-inline{background:var(--white);color:var(--primary-color);border:2px solid var(--primary-color)}.upload-label-inline:hover{background:var(--primary-gradient);color:var(--white);border-color:transparent}.footer{margin-top:20px;padding:20px;text-align:center;background:var(--white);border-top:1px solid var(--border-color)}.footer p{color:var(--text-gray);font-size:14px}.brand{font-weight:600;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media (max-width: 768px){.upload-section{margin:20px auto 0;padding:0 12px}.footer{padding:20px}}
