*,: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: 221.2 83.2% 53.3%;--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: 221.2 83.2% 53.3%;--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%}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground));font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.invisible{visibility:hidden}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.left-2{left:.5rem}.left-3{left:.75rem}.top-1\/2{top:50%}.top-2\.5{top:.625rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mt-0\.5{margin-top:.125rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-video{aspect-ratio:16 / 9}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-24{height:6rem}.h-3{height:.75rem}.h-32{height:8rem}.h-4{height:1rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[300px\]{height:300px}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-12{width:3rem}.w-3{width:.75rem}.w-32{width:8rem}.w-4{width:1rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.min-w-\[150px\]{min-width:150px}.min-w-\[200px\]{min-width:200px}.max-w-6xl{max-width:72rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-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))}.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-pointer{cursor:pointer}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-row{flex-direction:row}.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-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(0px * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-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-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-destructive{border-color:hsl(var(--destructive))}.border-destructive\/30{border-color:hsl(var(--destructive) / .3)}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.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-card{background-color:hsl(var(--card))}.bg-destructive{background-color:hsl(var(--destructive))}.bg-destructive\/10{background-color:hsl(var(--destructive) / .1)}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted\/50{background-color:hsl(var(--muted) / .5)}.bg-primary{background-color:hsl(var(--primary))}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-primary\/20{background-color:hsl(var(--primary) / .2)}.bg-secondary{background-color:hsl(var(--secondary))}.bg-transparent{background-color:transparent}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-background{--tw-gradient-from: hsl(var(--background)) var(--tw-gradient-from-position);--tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-background{--tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), hsl(var(--background)) var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-muted\/20{--tw-gradient-to: hsl(var(--muted) / .2) var(--tw-gradient-to-position)}.fill-yellow-400{fill:#facc15}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pb-2{padding-bottom:.5rem}.pb-6{padding-bottom:1.5rem}.pl-10{padding-left:2.5rem}.pr-3{padding-right:.75rem}.pt-0{padding-top:0}.pt-2{padding-top:.5rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[0\.70rem\]{font-size:.7rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.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-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.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-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{outline-style:solid}.blur-3xl{--tw-blur: blur(64px);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)}.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}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:border-primary\/50:hover{border-color:hsl(var(--primary) / .5)}.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\:shadow-lg:hover{--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)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-1:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.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\:bg-primary\/20{background-color:hsl(var(--primary) / .2)}.group:hover .group-hover\:text-primary{color:hsl(var(--primary))}.dark\:border-green-800:is(.dark *){--tw-border-opacity: 1;border-color:rgb(22 101 52 / var(--tw-border-opacity, 1))}.dark\:bg-green-950:is(.dark *){--tw-bg-opacity: 1;background-color:rgb(5 46 22 / var(--tw-bg-opacity, 1))}.dark\:text-green-200:is(.dark *){--tw-text-opacity: 1;color:rgb(187 247 208 / var(--tw-text-opacity, 1))}.dark\:text-green-400:is(.dark *){--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}@media (min-width: 768px){.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{width:1rem;height:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:16px;border-radius:12px;box-shadow:0 8px 24px #00000026;animation:slideInRight .3s ease,fadeOut .3s ease 4.7s;min-width:300px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.toast-success{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border:2px solid #22c55e;color:#166534}.toast-error{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444;color:#991b1b}.toast-warning{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;color:#92400e}.toast-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6;color:#1e40af}.toast-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0}.toast-success .toast-icon{background:#22c55e;color:#fff}.toast-error .toast-icon{background:#ef4444;color:#fff}.toast-warning .toast-icon{background:#f59e0b;color:#fff}.toast-info .toast-icon{background:#3b82f6;color:#fff}.toast-message{flex:1;font-size:14px;font-weight:600;line-height:1.5}.toast-close{background:none;border:none;font-size:18px;cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;flex-shrink:0;opacity:.7}.toast-close:hover{opacity:1;background:#0000001a}@media (max-width: 768px){.toast-container{left:16px;right:16px;top:16px;max-width:none}.toast{min-width:auto;width:100%}}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:#fff;border-radius:16px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:24px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.modal-header h3{margin:0;font-size:20px;font-weight:700;color:#1e293b}.modal-header-danger{background:linear-gradient(135deg,#fee2e2,#fecaca)}.modal-header-danger h3{color:#991b1b}.modal-header-warning{background:linear-gradient(135deg,#fef3c7,#fde68a)}.modal-header-warning h3{color:#92400e}.modal-header-info{background:linear-gradient(135deg,#dbeafe,#bfdbfe)}.modal-header-info h3{color:#1e40af}.modal-close{background:none;border:none;font-size:24px;color:#64748b;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.modal-close:hover{background:#0000001a;color:#1e293b}.modal-body{padding:24px}.modal-body p{margin:0;font-size:16px;color:#475569;line-height:1.6}.modal-footer{padding:24px;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end}.modal-btn{padding:12px 24px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s;border:none}.modal-btn-cancel{background:#fff;color:#64748b;border:2px solid #e2e8f0}.modal-btn-cancel:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.modal-btn-confirm{color:#fff}.modal-btn-danger{background:linear-gradient(135deg,#dc2626,#b91c1c)}.modal-btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #dc262666}.modal-btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.modal-btn-warning:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b66}.modal-btn-info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.modal-btn-info:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f666}@media (max-width: 768px){.modal-container{width:95%;margin:16px}.modal-header,.modal-body,.modal-footer{padding:16px}.modal-footer{flex-direction:column-reverse}.modal-btn{width:100%}}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#f0fdf4,#dcfce7)}.dashboard-nav{background:#fff;border-bottom:1px solid #e2e8f0;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0000000d}.nav-brand{display:flex;align-items:center;gap:16px}.nav-logo{width:48px;height:auto}.nav-brand h1{font-size:20px;font-weight:700;color:#1e293b;margin:0;line-height:1.2}.nav-subtitle{font-size:12px;color:#64748b;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.nav-actions{display:flex;align-items:center;gap:20px}.user-badge{display:flex;align-items:center;gap:12px;padding:8px 16px;background:#f8fafc;border-radius:12px}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#059669,#0891b2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px}.user-email{color:#1e293b;font-size:14px;font-weight:500}.logout-button{padding:10px 20px;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.logout-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.dashboard-main{max-width:1400px;margin:0 auto;padding:40px 32px}.welcome-section{margin-bottom:32px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.welcome-text h2{font-size:36px;font-weight:700;color:#1e293b;margin:0 0 8px;letter-spacing:-.5px}.welcome-text p{color:#64748b;font-size:18px;margin:0}.refresh-section{display:flex;align-items:center;gap:12px}.last-updated{font-size:14px;color:#64748b;font-weight:500}.refresh-button{padding:10px 20px;background:#fff;color:#059669;border:2px solid #059669;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px}.refresh-button:hover:not(:disabled){background:#059669;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0596694d}.refresh-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 12px #0000000f;transition:all .3s;border:1px solid #f1f5f9}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 20px #0000001a}.stat-header h3{font-size:14px;font-weight:600;color:#64748b;margin:0 0 16px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:42px;font-weight:700;color:#1e293b;margin-bottom:8px;line-height:1}.stat-value.status-operational{font-size:28px;color:#059669}.stat-footer{font-size:13px;color:#94a3b8;font-weight:500;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.stat-change{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:700;letter-spacing:.3px}.stat-change.positive{background:#dcfce7;color:#166534}.stat-change.negative{background:#fee2e2;color:#991b1b}.stat-comparison{font-size:12px;color:#94a3b8;font-weight:400}.chart-card{margin-bottom:32px}.chart-title{font-size:20px;font-weight:700;color:#1e293b;margin:0 0 24px}.donut-chart-container{display:grid;grid-template-columns:300px 1fr;gap:48px;align-items:center}.donut-chart{width:100%;max-width:300px;height:auto;filter:drop-shadow(0 4px 12px rgba(0,0,0,.1))}.donut-segment{transition:all .3s ease;cursor:pointer}.donut-segment:hover{opacity:.8;filter:brightness(1.1);transform:scale(1.02);transform-origin:center}.donut-total-label{font-size:12px;font-weight:600;fill:#64748b;text-transform:uppercase;letter-spacing:.5px}.donut-total-value{font-size:28px;font-weight:700;fill:#1e293b}.donut-legend{display:flex;flex-direction:column;gap:12px}.legend-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;transition:all .2s}.legend-item:hover{background:#f8fafc}.legend-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0;box-shadow:0 2px 4px #0000001a}.legend-label{font-size:14px;font-weight:600;color:#1e293b;flex:1}.legend-count{font-size:18px;font-weight:700;color:#1e293b;min-width:50px;text-align:right}.legend-percentage{font-size:13px;font-weight:500;color:#64748b;min-width:60px;text-align:right}.loading-section{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px}.loading-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#059669;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-section p{color:#64748b;font-size:16px}.error-section{padding:40px;text-align:center}.error-message{color:#dc2626;font-size:16px;background:#fee2e2;padding:16px 24px;border-radius:12px;display:inline-block}.content-section{margin-top:32px}.content-card{background:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 12px #0000000f;border:1px solid #f1f5f9}.table-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px;flex-wrap:wrap}.table-header h3{font-size:20px;font-weight:700;color:#1e293b;margin:0}.table-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.search-input{padding:10px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;min-width:250px;transition:all .3s;background:#fff;color:#1e293b}.search-input::-moz-placeholder{color:#94a3b8}.search-input::placeholder{color:#94a3b8}.search-input:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.filter-select{padding:10px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;background:#fff;color:#1e293b;cursor:pointer;transition:all .3s}.filter-select option{background:#fff;color:#1e293b}.filter-select:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.clear-filters-button{padding:10px 20px;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.clear-filters-button:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.copy-emails-button{padding:10px 20px;background:#2196f3;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:6px}.copy-emails-button:hover{background:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #2196f34d}.export-buttons{display:flex;gap:8px}.export-button{padding:10px 16px;background:linear-gradient(135deg,#059669,#0891b2);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s;text-transform:uppercase;letter-spacing:.5px}.export-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0596694d}.results-info{font-size:14px;color:#64748b;margin-bottom:16px;font-weight:500}.quick-filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:16px;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.quick-filters-label{font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-right:8px}.filter-chip{padding:8px 16px;background:#fff;border:2px solid #e2e8f0;border-radius:20px;font-size:13px;font-weight:600;color:#64748b;cursor:pointer;transition:all .3s;white-space:nowrap}.filter-chip:hover{border-color:#059669;color:#059669;transform:translateY(-2px);box-shadow:0 4px 8px #05966926}.filter-chip.active{background:linear-gradient(135deg,#059669,#0891b2);border-color:#059669;color:#fff;box-shadow:0 4px 12px #05966940}.filter-chip.active:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0596694d}.bulk-actions-bar{display:flex;flex-direction:column;gap:12px;padding:16px;background:linear-gradient(135deg,#e0f2fe,#e0e7ff);border-radius:12px;border:2px solid #3b82f6;margin-bottom:16px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.bulk-actions-label{font-size:14px;font-weight:700;color:#1e40af;letter-spacing:.3px}.bulk-actions-buttons{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.bulk-actions-title{font-size:13px;font-weight:600;color:#475569;margin-right:8px}.bulk-action-btn{padding:8px 16px;background:#fff;border:2px solid;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s}.bulk-action-btn:hover:not(:disabled){background:currentColor;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.bulk-action-btn:disabled{opacity:.5;cursor:not-allowed}.bulk-action-cancel{padding:8px 16px;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s;margin-left:auto}.bulk-action-cancel:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.bulk-action-cancel:disabled{opacity:.5;cursor:not-allowed}.checkbox-column{width:50px;text-align:center}.bulk-checkbox{width:18px;height:18px;cursor:pointer;accent-color:#059669}.submissions-table tbody tr.selected{background:#f0fdf4!important;border-left:3px solid #059669}.notes-cell{max-width:300px;min-width:200px}.notes-display{cursor:pointer;padding:8px;border-radius:6px;transition:all .2s;min-height:40px;display:flex;align-items:center}.notes-display:hover{background:#f8fafc;border:1px solid #e2e8f0}.notes-text{font-size:13px;color:#1e293b;line-height:1.4;white-space:pre-wrap;word-break:break-word}.notes-placeholder{font-size:13px;color:#94a3b8;font-style:italic}.notes-editor{display:flex;flex-direction:column;gap:8px;padding:4px}.notes-textarea{width:100%;padding:8px;border:2px solid #e2e8f0;border-radius:6px;font-size:13px;font-family:inherit;resize:vertical;transition:all .3s}.notes-textarea:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.notes-textarea:disabled{opacity:.6;cursor:not-allowed}.notes-actions{display:flex;gap:6px}.notes-save{padding:6px 12px;background:linear-gradient(135deg,#059669,#0891b2);color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s;flex:1}.notes-save:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #0596694d}.notes-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.notes-cancel{padding:6px 12px;background:#fff;color:#64748b;border:2px solid #e2e8f0;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s}.notes-cancel:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.notes-cancel:disabled{opacity:.6;cursor:not-allowed}.empty-state{text-align:center;padding:60px 20px;color:#94a3b8;font-size:16px;display:flex;flex-direction:column;gap:12px;align-items:center}.clear-filters-link{background:none;border:none;color:#059669;font-size:14px;font-weight:600;cursor:pointer;text-decoration:underline;transition:color .3s}.clear-filters-link:hover{color:#047857}.table-container{overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0;min-height:400px}.submissions-table{width:100%;border-collapse:collapse;table-layout:auto}.submissions-table thead{background:#f8fafc}.submissions-table th{padding:16px;text-align:left;font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid #e2e8f0}.submissions-table th.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:all .3s}.submissions-table th.sortable:hover{color:#059669;background:#f0fdf4}.submissions-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background .2s}.submissions-table tbody tr:hover{background:#f8fafc}.submissions-table tbody tr:last-child{border-bottom:none}.submissions-table td{padding:16px;font-size:14px;color:#1e293b}.status-dropdown-container{position:relative}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:capitalize;letter-spacing:.3px;border:2px solid transparent;cursor:pointer;transition:all .3s;background:transparent}.status-badge:hover{transform:scale(1.05);border-color:currentColor;opacity:.9}.dropdown-arrow{font-size:10px;margin-left:4px}.status-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 20px #00000026;min-width:160px;z-index:100;overflow:hidden}.status-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;background:#fff;border:none;text-align:left;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.status-dropdown-item:hover{background:#f8fafc}.status-dropdown-item.active{background:#f0fdf4}.status-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.status-active{background:#dcfce7;color:#166534}.status-unsubscribed{background:#fee2e2;color:#991b1b}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0}.pagination-button{padding:10px 20px;background:#fff;color:#1e293b;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.pagination-button:hover:not(:disabled){background:#f0fdf4;border-color:#059669;color:#059669}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:14px;color:#64748b;font-weight:500}.page-size-select{padding:10px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;background:#fff;cursor:pointer;transition:all .3s}.page-size-select:focus{outline:none;border-color:#059669;box-shadow:0 0 0 3px #0596691a}.action-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.action-button{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:24px;cursor:not-allowed;transition:all .3s;text-align:left;display:flex;flex-direction:column;gap:6px}.action-button:not(:disabled){cursor:pointer;background:#fff}.action-button:not(:disabled):hover{border-color:#059669;background:#f0fdf4;transform:translateY(-2px);box-shadow:0 4px 12px #05966926}.action-title{font-size:16px;font-weight:600;color:#1e293b;display:block}.action-subtitle{font-size:13px;color:#94a3b8;font-weight:500}.action-button:disabled .action-title,.action-button:disabled .action-subtitle{opacity:.5}@media (max-width: 768px){.dashboard-nav{padding:16px 20px;flex-direction:column;gap:16px;align-items:stretch}.nav-brand{justify-content:center}.nav-actions{flex-direction:column;gap:12px}.tabs-container{padding:0 20px;overflow-x:auto}.tab-button{padding:.75rem 1.5rem;font-size:.875rem}.user-badge{justify-content:center}.logout-button{width:100%}.dashboard-main{padding:24px 20px}.welcome-section{flex-direction:column;align-items:flex-start}.refresh-section{width:100%;justify-content:space-between}.welcome-text h2{font-size:28px}.welcome-text p{font-size:16px}.dashboard-grid,.action-grid{grid-template-columns:1fr}.donut-chart-container{grid-template-columns:1fr;gap:24px}.donut-chart{max-width:250px;margin:0 auto}.submissions-table{font-size:13px}.submissions-table th,.submissions-table td{padding:12px 8px}.table-header{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 480px){.nav-logo{width:40px}.nav-brand h1{font-size:18px}.welcome-text h2{font-size:24px}.stat-value{font-size:36px}}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;padding:2rem;max-width:1400px;margin:0 auto}.tool-card{background:#fff;border-radius:12px;padding:2rem;display:flex;align-items:center;gap:1.5rem;text-decoration:none;color:inherit;border:2px solid #e0e0e0;transition:all .2s ease;cursor:pointer}.tool-card:hover{border-color:#2196f3;box-shadow:0 4px 12px #2196f31a;transform:translateY(-2px)}.tool-icon{width:60px;height:60px;background:linear-gradient(135deg,#059669,#0891b2);border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;color:#fff;letter-spacing:-.5px}.tool-content{flex:1;min-width:0}.tool-content h3{margin:0 0 .5rem;font-size:1.25rem;color:#333}.tool-content p{margin:0 0 .75rem;font-size:.875rem;color:#666;line-height:1.4}.tool-url{font-size:.75rem;color:#2196f3;font-family:Monaco,Courier New,monospace}.tool-arrow{font-size:1.5rem;color:#999;transition:transform .2s ease}.tool-card:hover .tool-arrow{transform:translate(4px);color:#2196f3}.nav-center{display:flex;gap:.5rem;position:absolute;left:50%;transform:translate(-50%)}.nav-tab{padding:.75rem 1.5rem;background:transparent;border:none;color:#ffffffb3;font-size:1rem;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease}.nav-tab:hover{background:#ffffff1a;color:#fff}.nav-tab.active{background:#ffffff26;color:#fff}.env-badge{padding:.5rem 1rem;border-radius:6px;font-size:.75rem;font-weight:700;letter-spacing:.5px}.env-badge[data-env=dev]{background:orange;color:#fff}.env-badge[data-env=prod]{background:#4caf50;color:#fff}.tabs-container{background:#fff;border-bottom:2px solid #e2e8f0;display:flex;gap:0;padding:0 32px}.tab-button{padding:1rem 2rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#64748b;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;position:relative;display:flex;align-items:center;gap:.5rem}.tab-button:hover{color:#059669;background:#f0fdf4}.tab-button.active{color:#059669;border-bottom-color:#059669;background:#f0fdf4}@media (max-width: 768px){.tools-grid{grid-template-columns:1fr;padding:1rem}.tabs-container{padding:0 20px;overflow-x:auto}.tab-button{padding:.75rem 1.5rem;font-size:.875rem}.dashboard-nav{flex-wrap:wrap}}#root{width:100%;min-height:100vh}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
