*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.relative{position:relative}.left-0{left:0}.right-0{right:0}.top-0{top:0}.top-1\/2{top:50%}.z-10{z-index:10}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.h-2{height:.5rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-9{height:2.25rem}.h-full{height:100%}.max-h-0{max-height:0}.max-h-\[500px\]{max-height:500px}.w-2{width:.5rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-9{width:2.25rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-2xl{max-width:42rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.flex-1{flex:1 1}.flex-shrink-0{flex-shrink:0}.-translate-x-4{--tw-translate-x:-1rem}.-translate-x-4,.-translate-y-1\/2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y:-50%}.translate-x-4{--tw-translate-x:1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-not-allowed{cursor:not-allowed}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.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}.justify-around{justify-content:space-around}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.overflow-hidden,.truncate{overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-gray-100{--tw-border-opacity:1;border-color:#f3f4f6;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:#d1d5db;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-primary-500{--tw-border-opacity:1;border-color:#1976d2;border-color:rgb(25 118 210/var(--tw-border-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-300{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-green-200{--tw-bg-opacity:1;background-color:#bbf7d0;background-color:rgb(187 247 208/var(--tw-bg-opacity,1))}.bg-primary-50{--tw-bg-opacity:1;background-color:#e3f2fd;background-color:rgb(227 242 253/var(--tw-bg-opacity,1))}.bg-primary-500{--tw-bg-opacity:1;background-color:#1976d2;background-color:rgb(25 118 210/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/20{background-color:#fff3}.p-2{padding:.5rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.text-center{text-align:center}.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-\[15px\]{font-size:15px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-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}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.text-blue-600{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:#374151;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:#111827;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:#16a34a;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-primary-500{--tw-text-opacity:1;color:#1976d2;color:rgb(25 118 210/var(--tw-text-opacity,1))}.text-primary-600{--tw-text-opacity:1;color:#1565c0;color:rgb(21 101 192/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-50{opacity:.5}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-md{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-1,.ring-2{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-2{--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)}.ring-primary-200{--tw-ring-opacity:1;--tw-ring-color:rgb(144 202 249/var(--tw-ring-opacity,1))}.ring-primary-300{--tw-ring-opacity:1;--tw-ring-color:rgb(100 181 246/var(--tw-ring-opacity,1))}.ring-primary-500{--tw-ring-opacity:1;--tw-ring-color:rgb(25 118 210/var(--tw-ring-opacity,1))}.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-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-300{transition-duration:.3s}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.hover\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:#e5e7eb;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-400:hover{--tw-bg-opacity:1;background-color:#9ca3af;background-color:rgb(156 163 175/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-primary-100:hover{--tw-bg-opacity:1;background-color:#bbdefb;background-color:rgb(187 222 251/var(--tw-bg-opacity,1))}.hover\:bg-primary-50:hover{--tw-bg-opacity:1;background-color:#e3f2fd;background-color:rgb(227 242 253/var(--tw-bg-opacity,1))}.hover\:bg-primary-600:hover{--tw-bg-opacity:1;background-color:#1565c0;background-color:rgb(21 101 192/var(--tw-bg-opacity,1))}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.focus\:border-primary-500:focus{--tw-border-opacity:1;border-color:#1976d2;border-color:rgb(25 118 210/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline:2px solid #0000;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),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-primary-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(25 118 210/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.active\:scale-95:active{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:768px){.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}}.user-status{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:15px}.username{color:#1976d2;font-weight:500}.login-btn,.logout-btn{border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .3s ease}.login-btn{background:#1976d2;color:#fff}.login-btn:hover{background:#1565c0}.logout-btn{background:#f44336;color:#fff}.logout-btn:hover{background:#d32f2f}.sidebar{background:#fff;border-right:1px solid #eee;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:250px;z-index:1000}.sidebar-header{border-bottom:1px solid #eee;padding:20px;text-align:center}.sidebar-header h2{color:#1976d2;font-size:24px;margin:0}.sidebar-nav{padding:20px 0}.sidebar-nav a{align-items:center;color:#666;display:flex;padding:12px 24px;text-decoration:none;transition:all .3s ease}.sidebar-nav a:hover{background:#1976d20d;color:#1976d2}.sidebar-nav a.active{background:#1976d21a;color:#1976d2;font-weight:500}.icon{font-size:20px;margin-right:12px}.sidebar-guest{padding:20px}.guest-info{margin-bottom:30px;text-align:center}.guest-info h3{color:#1976d2;margin-bottom:8px}.guest-info p{color:#666;font-size:14px}.feature-list{margin-top:30px}.feature-item{align-items:center;border-bottom:1px solid #eee;display:flex;padding:12px 0}.feature-item:last-child{border-bottom:none}.feature-item .icon{font-size:20px;margin-right:12px}.feature-item p{color:#666;margin:0}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .3s ease}.sidebar.open{transform:translateX(0)}}.home{animation:fadeIn .5s ease;padding:20px}.welcome-section{margin-bottom:30px;text-align:center}.welcome-section h1{color:#1976d2;font-size:28px;margin-bottom:8px}.welcome-section p{color:#666;font-size:16px}.stats-overview{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{animation:slideUp .5s ease;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px;text-align:center;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-5px)}.stat-icon{font-size:32px;margin-bottom:10px}.stat-number{color:#1976d2;font-size:28px;font-weight:700;margin-bottom:5px}.charts-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:30px}.chart-box{animation:slideUp .5s ease;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px}.home-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}.loading-spinner{margin-bottom:10px}.home-error{color:#f44336;padding:20px;text-align:center}.retry-button{background:#1976d2;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:16px;padding:8px 16px;transition:background .3s ease}.retry-button:hover{background:#1565c0}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.charts-container,.stats-overview{grid-template-columns:1fr}.stat-number,.welcome-section h1{font-size:24px}}.login-container{align-items:center;background:linear-gradient(#2196f31a,#2196f333);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-container:before{background-image:url(/static/media/words-pattern.379dd319869125bf5e5a.svg);content:"";height:100%;opacity:.1;position:absolute;width:100%;z-index:0}.login-box{animation:fadeIn .6s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-radius:16px;box-shadow:0 8px 32px #0000001a;max-width:420px;padding:40px;position:relative;width:100%;z-index:1}.login-header{margin-bottom:36px;text-align:center}.login-header h2{color:#1976d2;font-size:28px;margin-bottom:12px}.login-header p{color:#666;font-size:16px}.demo-account{background:#2196f31a;border-radius:6px;margin-top:15px;padding:10px}.demo-account p{color:#1976d2;font-family:monospace;font-size:14px;margin:5px 0}.form-group,.login-form{width:100%}.form-group input{box-sizing:border-box}.login-button{background:linear-gradient(45deg,#2196f3,#1976d2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:12px;padding:14px;transition:all .3s ease;width:100%}.login-button:hover{background:linear-gradient(45deg,#1976d2,#1565c0);box-shadow:0 4px 12px #2196f34d;transform:translateY(-1px)}.auth-links{display:flex;justify-content:space-between;padding:0 10px}@media (max-width:480px){.login-box{margin:20px;padding:30px}.login-header h2{font-size:24px}.auth-links{flex-direction:column;gap:10px}}.register-container{align-items:center;background:linear-gradient(#2196f31a,#2196f333);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.register-container:before{background-image:url(/static/media/words-pattern.379dd319869125bf5e5a.svg);content:"";height:100%;opacity:.1;position:absolute;width:100%;z-index:0}.register-box{animation:fadeIn .6s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-radius:16px;box-shadow:0 8px 32px #0000001a;max-width:420px;padding:40px;position:relative;width:100%;z-index:1}.register-header{margin-bottom:36px;text-align:center}.register-header h2{color:#1976d2;font-size:28px;margin-bottom:12px}.register-header p{color:#666;font-size:16px}.register-button{background:linear-gradient(45deg,#2196f3,#1976d2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:12px;padding:14px;transition:all .3s ease;width:100%}.register-button:hover{background:linear-gradient(45deg,#1976d2,#1565c0);box-shadow:0 4px 12px #2196f34d;transform:translateY(-1px)}.error-message{align-items:center;background-color:#ffebee;border-radius:8px;color:#d32f2f;display:flex;font-size:14px;justify-content:center;margin-bottom:24px;padding:12px}@media (max-width:480px){.register-box{margin:20px;padding:30px}.register-header h2{font-size:24px}}.forgot-password-container{align-items:center;background:linear-gradient(#2196f31a,#2196f333);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.forgot-password-container:before{background-image:url(/static/media/words-pattern.379dd319869125bf5e5a.svg);content:"";height:100%;opacity:.1;position:absolute;width:100%;z-index:0}.forgot-password-box{animation:fadeIn .6s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-radius:16px;box-shadow:0 8px 32px #0000001a;max-width:420px;padding:40px;position:relative;width:100%;z-index:1}.forgot-password-header{margin-bottom:36px;text-align:center}.forgot-password-header h2{color:#1976d2;font-size:28px;margin-bottom:12px}.forgot-password-header p{color:#666;font-size:16px}.form-group{margin-bottom:24px;position:relative}.form-group label{color:#555;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px 16px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f333;outline:none}.submit-button{background:linear-gradient(45deg,#2196f3,#1976d2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:12px;padding:14px;transition:all .3s ease;width:100%}.submit-button:hover{background:linear-gradient(45deg,#1976d2,#1565c0);box-shadow:0 4px 12px #2196f34d;transform:translateY(-1px)}.status-message{align-items:center;border-radius:8px;display:flex;font-size:14px;justify-content:center;margin-bottom:24px;padding:12px}.status-message.success{background-color:#e8f5e9;color:#2e7d32}.status-message.error{background-color:#ffebee;color:#d32f2f}.auth-links{margin-top:20px;text-align:center}.auth-links a{color:#2196f3;font-size:14px;text-decoration:none}.auth-links a:hover{text-decoration:underline}@media (max-width:480px){.forgot-password-box{margin:20px;padding:30px}.forgot-password-header h2{font-size:24px}}.settings{padding:20px}.settings-title{color:#333;margin-bottom:30px}.settings-section{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.settings-section h2{color:#333;font-size:18px;margin-bottom:20px}.settings-item{align-items:center;display:flex;margin-bottom:15px}.settings-item label{color:#666;flex:0 0 120px}.settings-item input{border:1px solid #ddd;border-radius:4px;padding:8px;width:200px}.review-container{margin:0 auto;max-width:800px;padding:20px}.review-stats{display:flex;gap:30px;justify-content:center;margin-bottom:30px}.stat-item{text-align:center}.stat-label{color:#666;display:block;font-size:14px;margin-bottom:5px}.stat-value{font-size:24px;font-weight:700}.stat-value.correct{color:#4caf50}.stat-value.wrong{color:#f44336}.review-card{background:#fff;border:1px solid #eee;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:32px;text-align:center}.word-header{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:20px}.word-header h2{color:#1976d2;font-size:32px;margin:0}.audio-btn{align-items:center;background:#e3f2fd;border:none;border-radius:50%;color:#1976d2;cursor:pointer;display:flex;height:40px;justify-content:center;margin-left:12px;padding:0;transition:all .2s ease;width:40px}.audio-btn:hover{background:#bbdefb;transform:scale(1.1)}.audio-btn:active{transform:scale(.95)}.audio-icon{font-size:20px}.word-details{animation:fadeIn .3s ease}.meaning{color:#333;font-size:18px;margin-bottom:15px}.example{color:#666;font-style:italic;margin-bottom:20px}.answer-buttons{gap:15px}.answer-btn,.answer-buttons{display:flex;justify-content:center}.answer-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;font-size:16px;gap:8px;min-width:120px;padding:12px 24px;transition:all .3s ease}.answer-btn.correct{background:#4caf50;color:#fff}.answer-btn.wrong{background:#f44336;color:#fff}.answer-btn:hover{box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.show-answer-btn{background:#1976d2;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:all .3s ease}.show-answer-btn:hover{background:#1565c0}.review-complete{margin-top:30px;text-align:center}.reset-btn{align-items:center;background:#2196f3;border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:16px;gap:8px;margin:20px auto;padding:10px 20px;transition:all .3s ease}.reset-btn:hover{background:#1976d2}.loading-container{align-items:center;display:flex;justify-content:center;min-height:300px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#1976d2;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:480px){.review-stats{flex-direction:column;gap:15px}.word-header h2{font-size:28px}.answer-buttons{flex-direction:column}.answer-btn{width:100%}.review-card{border-radius:12px;padding:20px}.audio-btn{height:36px;width:36px}.audio-icon{font-size:18px}}.test-container{margin:0 auto;max-width:800px;padding:20px}.test-progress{margin-bottom:30px;text-align:center}.progress-bar{background:#e3f2fd;border-radius:4px;height:8px;margin-top:10px;overflow:hidden;width:100%}.progress-fill{background:#1976d2;height:100%;transition:width .3s ease}.test-card{background:#fff;border:1px solid #eee;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:32px}.word-meaning{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:30px}.word-meaning h3{color:#333;font-size:24px;margin:0}.input-group{margin-bottom:20px;position:relative}.input-icon{color:#666;left:12px;position:absolute;top:50%;transform:translateY(-50%)}.input-group input{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:14px 14px 14px 44px;transition:all .3s ease;width:100%}.input-group input:focus{background:#fff;border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.submit-btn{align-items:center;background:#1976d2;border:none;border-radius:5px;color:#fff;cursor:pointer;display:flex;font-size:16px;gap:8px;justify-content:center;padding:12px;transition:all .3s ease;width:100%}.submit-btn:hover{background:#1565c0}.result{animation:slideDown .3s ease;border-radius:5px;margin-top:20px;padding:20px;transform-origin:top}.result.correct{background:#e8f5e9;border:1px solid #4caf50}.result.wrong{background:#ffebee;border:1px solid #f44336}.result h4{color:#333;margin:0 0 10px}.next-btn{background:#2196f3;border:none;border-radius:5px;color:#fff;cursor:pointer;margin-top:20px;padding:10px 20px;transition:all .3s ease}.next-btn:hover{background:#1976d2}.test-complete{margin-top:30px;text-align:center}.review-empty,.test-empty{color:#666;padding:40px;text-align:center}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:scaleY(0)}to{opacity:1;transform:scaleY(1)}}.keyboard-hint{color:#666;font-size:12px;margin-top:10px;text-align:center}@media (max-width:480px){.test-card{border-radius:12px;padding:20px}.word-meaning h3{font-size:20px}.audio-btn{height:36px;width:36px}.audio-icon{font-size:18px}.input-group input{font-size:15px;padding:12px 12px 12px 40px}}.app{background-color:#f8fafc;display:flex;min-height:100vh}.main-content{flex:1 1;padding:20px;transition:margin-left .3s ease}.main-content.with-sidebar{margin-left:250px}@media (max-width:768px){.main-content.with-sidebar{margin-left:0;padding:16px}}.nav-link{border-radius:.5rem;padding:.5rem 1rem;transition:all .2s ease}.nav-link:hover{background-color:#e3f2fd;color:#1976d2}.nav-link.active{background-color:#1976d2;color:#fff}.fade-enter{opacity:0;transform:translateY(10px)}.fade-enter-active{transition:opacity .3s,transform .3s}.fade-enter-active,.fade-exit{opacity:1;transform:translateY(0)}.fade-exit-active{opacity:0;transform:translateY(-10px);transition:opacity .3s,transform .3s}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#999}
/*# sourceMappingURL=main.69851c67.css.map*/