@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,: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;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,[type=button],[type=reset],[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]{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: 142.1 76.2% 36.3%;--primary-foreground: 355.7 100% 97.3%;--secondary: 142.1 76.2% 36.3%;--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: 142.1 76.2% 36.3%;--radius: .75rem}*{border-color:hsl(var(--border))}html{scroll-behavior:smooth}body{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity));color:hsl(var(--foreground));font-family:Inter,sans-serif;background-color:#f8fafc;background-image:radial-gradient(at 0% 0%,hsla(142,40%,96%,1) 0,transparent 50%),radial-gradient(at 50% 0%,hsla(210,40%,96%,1) 0,transparent 50%),radial-gradient(at 100% 0%,hsla(142,40%,96%,1) 0,transparent 50%);background-attachment:fixed;background-size:cover}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{border-radius:9999px;--tw-bg-opacity: 1;background-color:rgb(203 213 225 / var(--tw-bg-opacity));-webkit-transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}::-webkit-scrollbar-thumb:hover{--tw-bg-opacity: 1;background-color:rgb(148 163 184 / var(--tw-bg-opacity))}::-moz-selection{--tw-bg-opacity: 1;background-color:rgb(187 247 208 / var(--tw-bg-opacity));--tw-text-opacity: 1;color:rgb(20 83 45 / var(--tw-text-opacity))}::selection{--tw-bg-opacity: 1;background-color:rgb(187 247 208 / var(--tw-bg-opacity));--tw-text-opacity: 1;color:rgb(20 83 45 / var(--tw-text-opacity))}*,: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: }::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: }.\!container{width:100%!important;margin-right:auto!important;margin-left:auto!important;padding-right:2rem!important;padding-left:2rem!important}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:2rem;padding-left:2rem}@media (min-width: 1400px){.\!container{max-width:1400px!important}.container{max-width:1400px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{top:0;right:0;bottom:0;left:0}.inset-x-0{left:0;right:0}.inset-y-0{top:0;bottom:0}.-bottom-2{bottom:-.5rem}.-right-1{right:-.25rem}.-right-2{right:-.5rem}.-top-1{top:-.25rem}.bottom-0{bottom:0}.bottom-20{bottom:5rem}.bottom-24{bottom:6rem}.bottom-4{bottom:1rem}.bottom-6{bottom:1.5rem}.bottom-8{bottom:2rem}.left-0{left:0}.left-3{left:.75rem}.left-4{left:1rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-14{right:3.5rem}.right-16{right:4rem}.right-2{right:.5rem}.right-3{right:.75rem}.right-4{right:1rem}.right-5{right:1.25rem}.right-6{right:1.5rem}.right-8{right:2rem}.right-\[calc\(50\%-60px\)\]{right:calc(50% - 60px)}.top-0{top:0}.top-1\/2{top:50%}.top-2{top:.5rem}.top-20{top:5rem}.top-24{top:6rem}.top-3{top:.75rem}.top-4{top:1rem}.top-5{top:1.25rem}.top-6{top:1.5rem}.top-\[100\%\]{top:100%}.top-\[50\%\]{top:50%}.top-\[60px\]{top:60px}.top-\[80px\]{top:80px}.top-full{top:100%}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[1000\]{z-index:1000}.z-\[60\]{z-index:60}.z-\[99999\]{z-index:99999}.order-1{order:1}.order-2{order:2}.col-span-2{grid-column:span 2 / span 2}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.-mx-4{margin-left:-1rem;margin-right:-1rem}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-6{margin-left:1.5rem;margin-right:1.5rem}.mx-auto{margin-left:auto;margin-right:auto}.my-0{margin-top:0;margin-bottom:0}.my-0\.5{margin-top:.125rem;margin-bottom:.125rem}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-3{margin-top:.75rem;margin-bottom:.75rem}.-mb-20{margin-bottom:-5rem}.-ml-2{margin-left:-.5rem}.-ml-20{margin-left:-5rem}.-mr-2{margin-right:-.5rem}.-mr-20{margin-right:-5rem}.-mt-10{margin-top:-2.5rem}.-mt-20{margin-top:-5rem}.-mt-3{margin-top:-.75rem}.-mt-6{margin-top:-1.5rem}.mb-0{margin-bottom:0}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-6{margin-left:1.5rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-1\.5{margin-right:.375rem}.mr-2{margin-right:.5rem}.mr-2\.5{margin-right:.625rem}.mr-3{margin-right:.75rem}.mt-0{margin-top:0}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-10{margin-top:2.5rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.line-clamp-1{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-\[16\/10\]{aspect-ratio:16/10}.aspect-\[3\/4\]{aspect-ratio:3/4}.aspect-square{aspect-ratio:1 / 1}.aspect-video{aspect-ratio:16 / 9}.h-0{height:0px}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-1\/2{height:50%}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-20{height:5rem}.h-24{height:6rem}.h-3{height:.75rem}.h-32{height:8rem}.h-4{height:1rem}.h-40{height:10rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-80{height:20rem}.h-9{height:2.25rem}.h-96{height:24rem}.h-\[50vh\]{height:50vh}.h-\[75vh\]{height:75vh}.h-\[80vh\]{height:80vh}.h-\[90vh\]{height:90vh}.h-\[calc\(100vh-64px\)\]{height:calc(100vh - 64px)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-32{max-height:8rem}.max-h-60{max-height:15rem}.max-h-80{max-height:20rem}.max-h-96{max-height:24rem}.max-h-\[800px\]{max-height:800px}.max-h-\[80vh\]{max-height:80vh}.max-h-\[85vh\]{max-height:85vh}.max-h-\[90vh\]{max-height:90vh}.max-h-\[92vh\]{max-height:92vh}.max-h-\[95vh\]{max-height:95vh}.max-h-full{max-height:100%}.min-h-0{min-height:0px}.min-h-\[100px\]{min-height:100px}.min-h-\[120px\]{min-height:120px}.min-h-\[400px\]{min-height:400px}.min-h-\[500px\]{min-height:500px}.min-h-\[600px\]{min-height:600px}.min-h-\[60px\]{min-height:60px}.min-h-\[70px\]{min-height:70px}.min-h-\[80px\]{min-height:80px}.min-h-\[90px\]{min-height:90px}.min-h-full{min-height:100%}.min-h-screen{min-height:100vh}.w-0{width:0px}.w-1{width:.25rem}.w-1\.5{width:.375rem}.w-1\/2{width:50%}.w-1\/3{width:33.333333%}.w-1\/4{width:25%}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-2\/3{width:66.666667%}.w-20{width:5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-3\/4{width:75%}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-80{width:20rem}.w-96{width:24rem}.w-\[95vw\]{width:95vw}.w-auto{width:auto}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[1\.25rem\]{min-width:1.25rem}.min-w-\[120px\]{min-width:120px}.min-w-\[140px\]{min-width:140px}.min-w-\[150px\]{min-width:150px}.min-w-\[200px\]{min-width:200px}.min-w-\[300px\]{min-width:300px}.min-w-\[70px\]{min-width:70px}.min-w-\[80px\]{min-width:80px}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[120px\]{max-width:120px}.max-w-\[200px\]{max-width:200px}.max-w-\[240px\]{max-width:240px}.max-w-\[260px\]{max-width:260px}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.origin-top-right{transform-origin:top right}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-x-full{--tw-translate-x: -100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-1\/2{--tw-translate-x: 50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-\[-50\%\]{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-0{--tw-translate-y: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-1\/2{--tw-translate-y: 50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-10{--tw-translate-y: 2.5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-16{--tw-translate-y: 4rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-full{--tw-translate-y: 100%;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))}.skew-x-12{--tw-skew-x: 12deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-100{--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-105{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}@keyframes ping{75%,to{transform:scale(2);opacity:0}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-all{-webkit-user-select:all;-moz-user-select:all;user-select:all}.resize-none{resize:none}.resize{resize:both}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0px}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-10{gap:2.5rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-x-3{-moz-column-gap:.75rem;column-gap:.75rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-y-1{row-gap:.25rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.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-2\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.625rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.625rem * 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-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * 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))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.divide-x>:not([hidden])~:not([hidden]){--tw-divide-x-reverse: 0;border-right-width:calc(1px * var(--tw-divide-x-reverse));border-left-width:calc(1px * calc(1 - var(--tw-divide-x-reverse)))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-slate-100>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(241 245 249 / var(--tw-divide-opacity))}.divide-slate-50>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(248 250 252 / var(--tw-divide-opacity))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-nowrap{text-wrap:nowrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-none{border-radius:0}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-b-\[2rem\]{border-bottom-right-radius:2rem;border-bottom-left-radius:2rem}.rounded-b-none{border-bottom-right-radius:0;border-bottom-left-radius:0}.rounded-t-3xl{border-top-left-radius:1.5rem;border-top-right-radius:1.5rem}.rounded-t-lg{border-top-left-radius:var(--radius);border-top-right-radius:var(--radius)}.rounded-t-none{border-top-left-radius:0;border-top-right-radius:0}.rounded-tr-\[100px\]{border-top-right-radius:100px}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-4{border-width:4px}.border-\[3px\]{border-width:3px}.border-y{border-top-width:1px;border-bottom-width:1px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l-2{border-left-width:2px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-none{border-style:none}.border-amber-100{--tw-border-opacity: 1;border-color:rgb(254 243 199 / var(--tw-border-opacity))}.border-amber-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity))}.border-amber-300{--tw-border-opacity: 1;border-color:rgb(252 211 77 / var(--tw-border-opacity))}.border-amber-500{--tw-border-opacity: 1;border-color:rgb(245 158 11 / var(--tw-border-opacity))}.border-amber-600{--tw-border-opacity: 1;border-color:rgb(217 119 6 / var(--tw-border-opacity))}.border-blue-100{--tw-border-opacity: 1;border-color:rgb(219 234 254 / var(--tw-border-opacity))}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity))}.border-blue-400{--tw-border-opacity: 1;border-color:rgb(96 165 250 / var(--tw-border-opacity))}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity))}.border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity))}.border-emerald-200{--tw-border-opacity: 1;border-color:rgb(167 243 208 / var(--tw-border-opacity))}.border-emerald-500{--tw-border-opacity: 1;border-color:rgb(16 185 129 / var(--tw-border-opacity))}.border-emerald-600{--tw-border-opacity: 1;border-color:rgb(5 150 105 / var(--tw-border-opacity))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity))}.border-green-100{--tw-border-opacity: 1;border-color:rgb(220 252 231 / var(--tw-border-opacity))}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity))}.border-green-300{--tw-border-opacity: 1;border-color:rgb(134 239 172 / var(--tw-border-opacity))}.border-green-500{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity))}.border-green-600{--tw-border-opacity: 1;border-color:rgb(22 163 74 / var(--tw-border-opacity))}.border-input{border-color:hsl(var(--input))}.border-orange-100{--tw-border-opacity: 1;border-color:rgb(255 237 213 / var(--tw-border-opacity))}.border-orange-200{--tw-border-opacity: 1;border-color:rgb(254 215 170 / var(--tw-border-opacity))}.border-orange-500{--tw-border-opacity: 1;border-color:rgb(249 115 22 / var(--tw-border-opacity))}.border-purple-100{--tw-border-opacity: 1;border-color:rgb(243 232 255 / var(--tw-border-opacity))}.border-purple-200{--tw-border-opacity: 1;border-color:rgb(233 213 255 / var(--tw-border-opacity))}.border-purple-500{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity))}.border-purple-600{--tw-border-opacity: 1;border-color:rgb(147 51 234 / var(--tw-border-opacity))}.border-red-100{--tw-border-opacity: 1;border-color:rgb(254 226 226 / var(--tw-border-opacity))}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity))}.border-red-300{--tw-border-opacity: 1;border-color:rgb(252 165 165 / var(--tw-border-opacity))}.border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity))}.border-red-600{--tw-border-opacity: 1;border-color:rgb(220 38 38 / var(--tw-border-opacity))}.border-rose-200{--tw-border-opacity: 1;border-color:rgb(254 205 211 / var(--tw-border-opacity))}.border-slate-100{--tw-border-opacity: 1;border-color:rgb(241 245 249 / var(--tw-border-opacity))}.border-slate-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity))}.border-slate-200\/60{border-color:#e2e8f099}.border-slate-300{--tw-border-opacity: 1;border-color:rgb(203 213 225 / var(--tw-border-opacity))}.border-slate-50{--tw-border-opacity: 1;border-color:rgb(248 250 252 / var(--tw-border-opacity))}.border-slate-500\/30{border-color:#64748b4d}.border-slate-700{--tw-border-opacity: 1;border-color:rgb(51 65 85 / var(--tw-border-opacity))}.border-slate-800{--tw-border-opacity: 1;border-color:rgb(30 41 59 / var(--tw-border-opacity))}.border-teal-600{--tw-border-opacity: 1;border-color:rgb(13 148 136 / var(--tw-border-opacity))}.border-transparent{border-color:transparent}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity))}.border-white\/20{border-color:#fff3}.border-white\/30{border-color:#ffffff4d}.border-yellow-200{--tw-border-opacity: 1;border-color:rgb(254 240 138 / var(--tw-border-opacity))}.border-l-green-500{--tw-border-opacity: 1;border-left-color:rgb(34 197 94 / var(--tw-border-opacity))}.border-l-orange-500{--tw-border-opacity: 1;border-left-color:rgb(249 115 22 / var(--tw-border-opacity))}.border-t-amber-600{--tw-border-opacity: 1;border-top-color:rgb(217 119 6 / var(--tw-border-opacity))}.border-t-purple-600{--tw-border-opacity: 1;border-top-color:rgb(147 51 234 / var(--tw-border-opacity))}.border-t-transparent{border-top-color:transparent}.border-t-white{--tw-border-opacity: 1;border-top-color:rgb(255 255 255 / var(--tw-border-opacity))}.bg-\[\#fafafa\]{--tw-bg-opacity: 1;background-color:rgb(250 250 250 / var(--tw-bg-opacity))}.bg-amber-100{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity))}.bg-amber-400{--tw-bg-opacity: 1;background-color:rgb(251 191 36 / var(--tw-bg-opacity))}.bg-amber-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity))}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity))}.bg-background{background-color:hsl(var(--background))}.bg-background\/95{background-color:hsl(var(--background) / .95)}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity))}.bg-black\/0{background-color:#0000}.bg-black\/10{background-color:#0000001a}.bg-black\/50{background-color:#00000080}.bg-black\/60{background-color:#0009}.bg-black\/90{background-color:#000000e6}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity))}.bg-blue-200{--tw-bg-opacity: 1;background-color:rgb(191 219 254 / var(--tw-bg-opacity))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity))}.bg-blue-50\/30{background-color:#eff6ff4d}.bg-blue-50\/50{background-color:#eff6ff80}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity))}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity))}.bg-blue-700{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.bg-card{background-color:hsl(var(--card))}.bg-destructive{background-color:hsl(var(--destructive))}.bg-emerald-100{--tw-bg-opacity: 1;background-color:rgb(209 250 229 / var(--tw-bg-opacity))}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity))}.bg-emerald-600{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity))}.bg-green-100\/30{background-color:#dcfce74d}.bg-green-200{--tw-bg-opacity: 1;background-color:rgb(187 247 208 / var(--tw-bg-opacity))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity))}.bg-green-50\/30{background-color:#f0fdf44d}.bg-green-50\/50{background-color:#f0fdf480}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity))}.bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity))}.bg-green-900\/20{background-color:#14532d33}.bg-indigo-100{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity))}.bg-indigo-50{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity))}.bg-indigo-500{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity))}.bg-orange-100{--tw-bg-opacity: 1;background-color:rgb(255 237 213 / var(--tw-bg-opacity))}.bg-orange-50{--tw-bg-opacity: 1;background-color:rgb(255 247 237 / var(--tw-bg-opacity))}.bg-orange-50\/30{background-color:#fff7ed4d}.bg-orange-500{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity))}.bg-primary{background-color:hsl(var(--primary))}.bg-purple-100{--tw-bg-opacity: 1;background-color:rgb(243 232 255 / var(--tw-bg-opacity))}.bg-purple-200{--tw-bg-opacity: 1;background-color:rgb(233 213 255 / var(--tw-bg-opacity))}.bg-purple-50{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity))}.bg-purple-50\/30{background-color:#faf5ff4d}.bg-purple-50\/50{background-color:#faf5ff80}.bg-purple-500{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity))}.bg-purple-600{--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity))}.bg-red-50\/30{background-color:#fef2f24d}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity))}.bg-red-500\/30{background-color:#ef44444d}.bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity))}.bg-rose-100{--tw-bg-opacity: 1;background-color:rgb(255 228 230 / var(--tw-bg-opacity))}.bg-secondary{background-color:hsl(var(--secondary))}.bg-sky-500{--tw-bg-opacity: 1;background-color:rgb(14 165 233 / var(--tw-bg-opacity))}.bg-slate-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity))}.bg-slate-200{--tw-bg-opacity: 1;background-color:rgb(226 232 240 / var(--tw-bg-opacity))}.bg-slate-300{--tw-bg-opacity: 1;background-color:rgb(203 213 225 / var(--tw-bg-opacity))}.bg-slate-400{--tw-bg-opacity: 1;background-color:rgb(148 163 184 / var(--tw-bg-opacity))}.bg-slate-50{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity))}.bg-slate-50\/30{background-color:#f8fafc4d}.bg-slate-50\/50{background-color:#f8fafc80}.bg-slate-500{--tw-bg-opacity: 1;background-color:rgb(100 116 139 / var(--tw-bg-opacity))}.bg-slate-500\/20{background-color:#64748b33}.bg-slate-800{--tw-bg-opacity: 1;background-color:rgb(30 41 59 / var(--tw-bg-opacity))}.bg-slate-900{--tw-bg-opacity: 1;background-color:rgb(15 23 42 / var(--tw-bg-opacity))}.bg-teal-100{--tw-bg-opacity: 1;background-color:rgb(204 251 241 / var(--tw-bg-opacity))}.bg-teal-600{--tw-bg-opacity: 1;background-color:rgb(13 148 136 / var(--tw-bg-opacity))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.bg-white\/10{background-color:#ffffff1a}.bg-white\/20{background-color:#fff3}.bg-white\/30{background-color:#ffffff4d}.bg-white\/50{background-color:#ffffff80}.bg-white\/80{background-color:#fffc}.bg-white\/90{background-color:#ffffffe6}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity))}.bg-yellow-50{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity))}.bg-opacity-50{--tw-bg-opacity: .5}.bg-\[radial-gradient\(ellipse_at_top\,_var\(--tw-gradient-stops\)\)\]{background-image:radial-gradient(ellipse at top,var(--tw-gradient-stops))}.bg-\[url\(\'\/background\.jpg\'\)\]{background-image:url(/background.jpg)}.bg-\[url\(\'data\:image\/svg\+xml\;charset\=US-ASCII\,\%3Csvg\%20xmlns\%3D\%22http\%3A\%2F\%2Fwww\.w3\.org\%2F2000\%2Fsvg\%22\%20width\%3D\%2224\%22\%20height\%3D\%2224\%22\%20viewBox\%3D\%220\%200\%2024\%2024\%22\%20fill\%3D\%22none\%22\%20stroke\%3D\%22\%2364748b\%22\%20stroke-width\%3D\%222\%22\%20stroke-linecap\%3D\%22round\%22\%20stroke-linejoin\%3D\%22round\%22\%3E\%3Cpath\%20d\%3D\%22m6\%209\%206\%206\%206-6\%22\%2F\%3E\%3C\%2Fsvg\%3E\'\)\]{background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%2364748b%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%3E%3Cpath%20d%3D%22m6%209%206%206%206-6%22%2F%3E%3C%2Fsvg%3E)}.bg-\[url\(\'https\:\/\/images\.unsplash\.com\/photo-1546410531-bb4caa6b424d\?q\=80\'\)\]{background-image:url(https://images.unsplash.com/photo-1546410531-bb4caa6b424d?q=80)}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.bg-gradient-to-tr{background-image:linear-gradient(to top right,var(--tw-gradient-stops))}.from-amber-50{--tw-gradient-from: #fffbeb var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 251 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-amber-500{--tw-gradient-from: #f59e0b var(--tw-gradient-from-position);--tw-gradient-to: rgb(245 158 11 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-amber-600{--tw-gradient-from: #d97706 var(--tw-gradient-from-position);--tw-gradient-to: rgb(217 119 6 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-black\/60{--tw-gradient-from: rgb(0 0 0 / .6) var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-100{--tw-gradient-from: #dbeafe var(--tw-gradient-from-position);--tw-gradient-to: rgb(219 234 254 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-400{--tw-gradient-from: #60a5fa var(--tw-gradient-from-position);--tw-gradient-to: rgb(96 165 250 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from: #eff6ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(239 246 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from: #2563eb var(--tw-gradient-from-position);--tw-gradient-to: rgb(37 99 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-500{--tw-gradient-from: #10b981 var(--tw-gradient-from-position);--tw-gradient-to: rgb(16 185 129 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-600{--tw-gradient-from: #059669 var(--tw-gradient-from-position);--tw-gradient-to: rgb(5 150 105 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-50{--tw-gradient-from: #f0fdf4 var(--tw-gradient-from-position);--tw-gradient-to: rgb(240 253 244 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-500{--tw-gradient-from: #22c55e var(--tw-gradient-from-position);--tw-gradient-to: rgb(34 197 94 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-600{--tw-gradient-from: #16a34a var(--tw-gradient-from-position);--tw-gradient-to: rgb(22 163 74 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-900\/40{--tw-gradient-from: rgb(20 83 45 / .4) var(--tw-gradient-from-position);--tw-gradient-to: rgb(20 83 45 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-600{--tw-gradient-from: #4f46e5 var(--tw-gradient-from-position);--tw-gradient-to: rgb(79 70 229 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-orange-100{--tw-gradient-from: #ffedd5 var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 237 213 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-100{--tw-gradient-from: #f3e8ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(243 232 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-50{--tw-gradient-from: #faf5ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(250 245 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-500{--tw-gradient-from: #a855f7 var(--tw-gradient-from-position);--tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-600{--tw-gradient-from: #9333ea var(--tw-gradient-from-position);--tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-rose-600{--tw-gradient-from: #e11d48 var(--tw-gradient-from-position);--tw-gradient-to: rgb(225 29 72 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-200{--tw-gradient-from: #e2e8f0 var(--tw-gradient-from-position);--tw-gradient-to: rgb(226 232 240 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-400{--tw-gradient-from: #94a3b8 var(--tw-gradient-from-position);--tw-gradient-to: rgb(148 163 184 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from: #f8fafc var(--tw-gradient-from-position);--tw-gradient-to: rgb(248 250 252 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-700{--tw-gradient-from: #334155 var(--tw-gradient-from-position);--tw-gradient-to: rgb(51 65 85 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-900{--tw-gradient-from: #0f172a var(--tw-gradient-from-position);--tw-gradient-to: rgb(15 23 42 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-teal-600{--tw-gradient-from: #0d9488 var(--tw-gradient-from-position);--tw-gradient-to: rgb(13 148 136 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-transparent{--tw-gradient-from: transparent var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-violet-500{--tw-gradient-from: #8b5cf6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(139 92 246 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-white{--tw-gradient-from: #fff var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-fuchsia-500{--tw-gradient-to: rgb(217 70 239 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #d946ef var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-green-500{--tw-gradient-to: rgb(34 197 94 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #22c55e var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-purple-500{--tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #a855f7 var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-slate-100{--tw-gradient-to: rgb(241 245 249 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #f1f5f9 var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-slate-900{--tw-gradient-to: rgb(15 23 42 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #0f172a var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-white{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-blue-100{--tw-gradient-to: #dbeafe var(--tw-gradient-to-position)}.to-blue-200{--tw-gradient-to: #bfdbfe var(--tw-gradient-to-position)}.to-blue-50{--tw-gradient-to: #eff6ff var(--tw-gradient-to-position)}.to-blue-600{--tw-gradient-to: #2563eb var(--tw-gradient-to-position)}.to-blue-700{--tw-gradient-to: #1d4ed8 var(--tw-gradient-to-position)}.to-cyan-600{--tw-gradient-to: #0891b2 var(--tw-gradient-to-position)}.to-emerald-600{--tw-gradient-to: #059669 var(--tw-gradient-to-position)}.to-emerald-700{--tw-gradient-to: #047857 var(--tw-gradient-to-position)}.to-green-50{--tw-gradient-to: #f0fdf4 var(--tw-gradient-to-position)}.to-green-500{--tw-gradient-to: #22c55e var(--tw-gradient-to-position)}.to-green-600{--tw-gradient-to: #16a34a var(--tw-gradient-to-position)}.to-green-700{--tw-gradient-to: #15803d var(--tw-gradient-to-position)}.to-green-800{--tw-gradient-to: #166534 var(--tw-gradient-to-position)}.to-indigo-500{--tw-gradient-to: #6366f1 var(--tw-gradient-to-position)}.to-indigo-600{--tw-gradient-to: #4f46e5 var(--tw-gradient-to-position)}.to-orange-200{--tw-gradient-to: #fed7aa var(--tw-gradient-to-position)}.to-orange-500{--tw-gradient-to: #f97316 var(--tw-gradient-to-position)}.to-orange-600{--tw-gradient-to: #ea580c var(--tw-gradient-to-position)}.to-pink-100{--tw-gradient-to: #fce7f3 var(--tw-gradient-to-position)}.to-pink-500{--tw-gradient-to: #ec4899 var(--tw-gradient-to-position)}.to-pink-600{--tw-gradient-to: #db2777 var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to: #9333ea var(--tw-gradient-to-position)}.to-purple-700{--tw-gradient-to: #7e22ce var(--tw-gradient-to-position)}.to-rose-800{--tw-gradient-to: #9f1239 var(--tw-gradient-to-position)}.to-slate-200{--tw-gradient-to: #e2e8f0 var(--tw-gradient-to-position)}.to-slate-500{--tw-gradient-to: #64748b var(--tw-gradient-to-position)}.to-slate-600{--tw-gradient-to: #475569 var(--tw-gradient-to-position)}.to-slate-900{--tw-gradient-to: #0f172a var(--tw-gradient-to-position)}.to-slate-900\/90{--tw-gradient-to: rgb(15 23 42 / .9) var(--tw-gradient-to-position)}.to-teal-500{--tw-gradient-to: #14b8a6 var(--tw-gradient-to-position)}.to-teal-600{--tw-gradient-to: #0d9488 var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.to-yellow-50{--tw-gradient-to: #fefce8 var(--tw-gradient-to-position)}.to-yellow-600{--tw-gradient-to: #ca8a04 var(--tw-gradient-to-position)}.bg-\[length\:1\.25rem_1\.25rem\]{background-size:1.25rem 1.25rem}.bg-\[length\:200\%_100\%\]{background-size:200% 100%}.bg-cover{background-size:cover}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.bg-\[right_0\.5rem_center\]{background-position:right .5rem center}.bg-center{background-position:center}.bg-no-repeat{background-repeat:no-repeat}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.px-12{padding-left:3rem;padding-right:3rem}.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-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0{padding-top:0;padding-bottom:0}.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-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-3\.5{padding-top:.875rem;padding-bottom:.875rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-1{padding-bottom:.25rem}.pb-1\.5{padding-bottom:.375rem}.pb-10{padding-bottom:2.5rem}.pb-2{padding-bottom:.5rem}.pb-20{padding-bottom:5rem}.pb-24{padding-bottom:6rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}.pb-6{padding-bottom:1.5rem}.pb-8{padding-bottom:2rem}.pl-0{padding-left:0}.pl-10{padding-left:2.5rem}.pl-11{padding-left:2.75rem}.pl-9{padding-left:2.25rem}.pr-10{padding-right:2.5rem}.pr-12{padding-right:3rem}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-16{padding-top:4rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.font-serif{font-family:ui-serif,Georgia,Cambria,Times New Roman,Times,serif}.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-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.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-black{font-weight:900}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-light{font-weight:300}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-500{--tw-text-opacity: 1;color:rgb(245 158 11 / var(--tw-text-opacity))}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity))}.text-amber-700{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity))}.text-amber-800{--tw-text-opacity: 1;color:rgb(146 64 14 / var(--tw-text-opacity))}.text-blue-100{--tw-text-opacity: 1;color:rgb(219 234 254 / var(--tw-text-opacity))}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity))}.text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity))}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity))}.text-blue-900{--tw-text-opacity: 1;color:rgb(30 58 138 / var(--tw-text-opacity))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-emerald-500{--tw-text-opacity: 1;color:rgb(16 185 129 / var(--tw-text-opacity))}.text-emerald-600{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity))}.text-emerald-700{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity))}.text-foreground{color:hsl(var(--foreground))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity))}.text-green-100{--tw-text-opacity: 1;color:rgb(220 252 231 / var(--tw-text-opacity))}.text-green-200{--tw-text-opacity: 1;color:rgb(187 247 208 / var(--tw-text-opacity))}.text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity))}.text-green-50{--tw-text-opacity: 1;color:rgb(240 253 244 / var(--tw-text-opacity))}.text-green-500{--tw-text-opacity: 1;color:rgb(34 197 94 / var(--tw-text-opacity))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity))}.text-indigo-500{--tw-text-opacity: 1;color:rgb(99 102 241 / var(--tw-text-opacity))}.text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity))}.text-indigo-700{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity))}.text-orange-500{--tw-text-opacity: 1;color:rgb(249 115 22 / var(--tw-text-opacity))}.text-orange-600{--tw-text-opacity: 1;color:rgb(234 88 12 / var(--tw-text-opacity))}.text-orange-700{--tw-text-opacity: 1;color:rgb(194 65 12 / var(--tw-text-opacity))}.text-orange-800{--tw-text-opacity: 1;color:rgb(154 52 18 / var(--tw-text-opacity))}.text-pink-500{--tw-text-opacity: 1;color:rgb(236 72 153 / var(--tw-text-opacity))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-purple-100{--tw-text-opacity: 1;color:rgb(243 232 255 / var(--tw-text-opacity))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity))}.text-purple-500{--tw-text-opacity: 1;color:rgb(168 85 247 / var(--tw-text-opacity))}.text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity))}.text-purple-700{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity))}.text-rose-100{--tw-text-opacity: 1;color:rgb(255 228 230 / var(--tw-text-opacity))}.text-rose-700{--tw-text-opacity: 1;color:rgb(190 18 60 / var(--tw-text-opacity))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-slate-200{--tw-text-opacity: 1;color:rgb(226 232 240 / var(--tw-text-opacity))}.text-slate-300{--tw-text-opacity: 1;color:rgb(203 213 225 / var(--tw-text-opacity))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity))}.text-slate-700{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity))}.text-slate-800{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity))}.text-slate-950{--tw-text-opacity: 1;color:rgb(2 6 23 / var(--tw-text-opacity))}.text-teal-500{--tw-text-opacity: 1;color:rgb(20 184 166 / var(--tw-text-opacity))}.text-teal-600{--tw-text-opacity: 1;color:rgb(13 148 136 / var(--tw-text-opacity))}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.text-white\/40{color:#fff6}.text-white\/50{color:#ffffff80}.text-white\/60{color:#fff9}.text-white\/70{color:#ffffffb3}.text-white\/80{color:#fffc}.text-white\/90{color:#ffffffe6}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity))}.text-yellow-500{--tw-text-opacity: 1;color:rgb(234 179 8 / var(--tw-text-opacity))}.text-yellow-600{--tw-text-opacity: 1;color:rgb(202 138 4 / var(--tw-text-opacity))}.text-yellow-700{--tw-text-opacity: 1;color:rgb(161 98 7 / var(--tw-text-opacity))}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.placeholder-white\/60::-moz-placeholder{color:#fff9}.placeholder-white\/60::placeholder{color:#fff9}.placeholder-white\/70::-moz-placeholder{color:#ffffffb3}.placeholder-white\/70::placeholder{color:#ffffffb3}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-100{opacity:1}.opacity-20{opacity:.2}.opacity-30{opacity:.3}.opacity-5{opacity:.05}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.mix-blend-multiply{mix-blend-mode:multiply}.mix-blend-overlay{mix-blend-mode:overlay}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-blue-200{--tw-shadow-color: #bfdbfe;--tw-shadow: var(--tw-shadow-colored)}.shadow-blue-300{--tw-shadow-color: #93c5fd;--tw-shadow: var(--tw-shadow-colored)}.shadow-blue-600\/30{--tw-shadow-color: rgb(37 99 235 / .3);--tw-shadow: var(--tw-shadow-colored)}.shadow-emerald-300{--tw-shadow-color: #6ee7b7;--tw-shadow: var(--tw-shadow-colored)}.shadow-green-100{--tw-shadow-color: #dcfce7;--tw-shadow: var(--tw-shadow-colored)}.shadow-green-200{--tw-shadow-color: #bbf7d0;--tw-shadow: var(--tw-shadow-colored)}.shadow-green-900\/20{--tw-shadow-color: rgb(20 83 45 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-indigo-200{--tw-shadow-color: #c7d2fe;--tw-shadow: var(--tw-shadow-colored)}.shadow-indigo-300{--tw-shadow-color: #a5b4fc;--tw-shadow: var(--tw-shadow-colored)}.shadow-purple-200{--tw-shadow-color: #e9d5ff;--tw-shadow: var(--tw-shadow-colored)}.shadow-purple-300{--tw-shadow-color: #d8b4fe;--tw-shadow: var(--tw-shadow-colored)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-1{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-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);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-blue-100{--tw-ring-opacity: 1;--tw-ring-color: rgb(219 234 254 / var(--tw-ring-opacity))}.ring-blue-200{--tw-ring-opacity: 1;--tw-ring-color: rgb(191 219 254 / var(--tw-ring-opacity))}.ring-green-500{--tw-ring-opacity: 1;--tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity))}.ring-red-500{--tw-ring-opacity: 1;--tw-ring-color: rgb(239 68 68 / var(--tw-ring-opacity))}.ring-slate-100{--tw-ring-opacity: 1;--tw-ring-color: rgb(241 245 249 / var(--tw-ring-opacity))}.ring-slate-200{--tw-ring-opacity: 1;--tw-ring-color: rgb(226 232 240 / var(--tw-ring-opacity))}.ring-white{--tw-ring-opacity: 1;--tw-ring-color: rgb(255 255 255 / var(--tw-ring-opacity))}.ring-offset-1{--tw-ring-offset-width: 1px}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.ring-offset-white{--tw-ring-offset-color: #fff}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-0{--tw-blur: blur(0);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)}.blur-2xl{--tw-blur: blur(40px);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)}.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)}.blur-sm{--tw-blur: blur(4px);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)}.drop-shadow-lg{--tw-drop-shadow: drop-shadow(0 10px 8px rgb(0 0 0 / .04)) drop-shadow(0 4px 3px rgb(0 0 0 / .1));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)}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur: blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-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-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-xl{--tw-backdrop-blur: blur(24px);-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-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.duration-700{transition-duration:.7s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.animate-fade-in{animation:fadeIn .5s ease-out forwards}.animate-blob{animation:blob 7s infinite}.animation-delay-2000{animation-delay:2s}.animation-delay-4000{animation-delay:4s}.glass{background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3)}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:9999;display:flex!important;align-items:center!important;justify-content:center!important;padding:20px;transition:all .3s ease}@media (min-width: 768px){.admin-modal-overlay{padding-left:256px!important}}.admin-modal-content{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-height:90vh;display:flex!important;flex-direction:column;overflow:hidden;margin:auto!important;position:relative;width:100%;max-width:600px;animation:modalSlideUp .3s cubic-bezier(.16,1,.3,1)}.admin-modal-content.large{max-width:900px}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.file\:mr-4::file-selector-button{margin-right:1rem}.file\:rounded-lg::file-selector-button{border-radius:var(--radius)}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-purple-50::file-selector-button{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity))}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:px-4::file-selector-button{padding-left:1rem;padding-right:1rem}.file\:py-2::file-selector-button{padding-top:.5rem;padding-bottom:.5rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-purple-700::file-selector-button{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity))}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:-translate-y-0:hover{--tw-translate-y: -0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;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))}.hover\:-translate-y-1:hover{--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))}.hover\:-translate-y-2:hover{--tw-translate-y: -.5rem;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))}.hover\:translate-y-1:hover{--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))}.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)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-110:hover{--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))}.hover\:scale-\[1\.01\]:hover{--tw-scale-x: 1.01;--tw-scale-y: 1.01;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))}.hover\:gap-2:hover{gap:.5rem}.hover\:border-blue-100:hover{--tw-border-opacity: 1;border-color:rgb(219 234 254 / var(--tw-border-opacity))}.hover\:border-blue-400:hover{--tw-border-opacity: 1;border-color:rgb(96 165 250 / var(--tw-border-opacity))}.hover\:border-blue-500\/50:hover{border-color:#3b82f680}.hover\:border-green-200:hover{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity))}.hover\:border-green-500:hover{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity))}.hover\:border-green-500\/50:hover{border-color:#22c55e80}.hover\:border-purple-300:hover{--tw-border-opacity: 1;border-color:rgb(216 180 254 / var(--tw-border-opacity))}.hover\:border-purple-500\/50:hover{border-color:#a855f780}.hover\:border-slate-200:hover{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity))}.hover\:border-white:hover{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity))}.hover\:border-white\/50:hover{border-color:#ffffff80}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-amber-100:hover{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity))}.hover\:bg-black\/5:hover{background-color:#0000000d}.hover\:bg-blue-100:hover{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity))}.hover\:bg-blue-200:hover{--tw-bg-opacity: 1;background-color:rgb(191 219 254 / var(--tw-bg-opacity))}.hover\:bg-blue-50:hover{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity))}.hover\:bg-blue-600:hover{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.hover\:bg-blue-800:hover{--tw-bg-opacity: 1;background-color:rgb(30 64 175 / var(--tw-bg-opacity))}.hover\:bg-destructive\/80:hover{background-color:hsl(var(--destructive) / .8)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-emerald-100:hover{--tw-bg-opacity: 1;background-color:rgb(209 250 229 / var(--tw-bg-opacity))}.hover\:bg-emerald-600:hover{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity))}.hover\:bg-emerald-700:hover{--tw-bg-opacity: 1;background-color:rgb(4 120 87 / var(--tw-bg-opacity))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity))}.hover\:bg-green-100:hover{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity))}.hover\:bg-green-100\/50:hover{background-color:#dcfce780}.hover\:bg-green-200:hover{--tw-bg-opacity: 1;background-color:rgb(187 247 208 / var(--tw-bg-opacity))}.hover\:bg-green-50:hover{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity))}.hover\:bg-green-500:hover{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity))}.hover\:bg-green-700:hover{--tw-bg-opacity: 1;background-color:rgb(21 128 61 / var(--tw-bg-opacity))}.hover\:bg-orange-100:hover{--tw-bg-opacity: 1;background-color:rgb(255 237 213 / var(--tw-bg-opacity))}.hover\:bg-orange-50:hover{--tw-bg-opacity: 1;background-color:rgb(255 247 237 / var(--tw-bg-opacity))}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary) / .8)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-purple-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 232 255 / var(--tw-bg-opacity))}.hover\:bg-purple-200:hover{--tw-bg-opacity: 1;background-color:rgb(233 213 255 / var(--tw-bg-opacity))}.hover\:bg-purple-700:hover{--tw-bg-opacity: 1;background-color:rgb(126 34 206 / var(--tw-bg-opacity))}.hover\:bg-red-200:hover{--tw-bg-opacity: 1;background-color:rgb(254 202 202 / var(--tw-bg-opacity))}.hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity))}.hover\:bg-red-600:hover{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity))}.hover\:bg-red-700:hover{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity))}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:bg-sky-600:hover{--tw-bg-opacity: 1;background-color:rgb(2 132 199 / var(--tw-bg-opacity))}.hover\:bg-slate-100:hover{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity))}.hover\:bg-slate-200:hover{--tw-bg-opacity: 1;background-color:rgb(226 232 240 / var(--tw-bg-opacity))}.hover\:bg-slate-300:hover{--tw-bg-opacity: 1;background-color:rgb(203 213 225 / var(--tw-bg-opacity))}.hover\:bg-slate-400:hover{--tw-bg-opacity: 1;background-color:rgb(148 163 184 / var(--tw-bg-opacity))}.hover\:bg-slate-50:hover{--tw-bg-opacity: 1;background-color:rgb(248 250 252 / var(--tw-bg-opacity))}.hover\:bg-slate-500:hover{--tw-bg-opacity: 1;background-color:rgb(100 116 139 / var(--tw-bg-opacity))}.hover\:bg-teal-700:hover{--tw-bg-opacity: 1;background-color:rgb(15 118 110 / var(--tw-bg-opacity))}.hover\:bg-transparent:hover{background-color:transparent}.hover\:bg-white:hover{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/20:hover{background-color:#fff3}.hover\:bg-white\/50:hover{background-color:#ffffff80}.hover\:bg-yellow-200:hover{--tw-bg-opacity: 1;background-color:rgb(254 240 138 / var(--tw-bg-opacity))}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:text-blue-600:hover{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity))}.hover\:text-blue-700:hover{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity))}.hover\:text-blue-800:hover{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity))}.hover\:text-gray-300:hover{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity))}.hover\:text-green-100:hover{--tw-text-opacity: 1;color:rgb(220 252 231 / var(--tw-text-opacity))}.hover\:text-green-600:hover{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity))}.hover\:text-green-700:hover{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity))}.hover\:text-orange-600:hover{--tw-text-opacity: 1;color:rgb(234 88 12 / var(--tw-text-opacity))}.hover\:text-purple-600:hover{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity))}.hover\:text-purple-700:hover{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity))}.hover\:text-red-500:hover{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity))}.hover\:text-red-600:hover{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity))}.hover\:text-red-700:hover{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity))}.hover\:text-slate-600:hover{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity))}.hover\:text-slate-700:hover{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity))}.hover\:text-slate-800:hover{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity))}.hover\:text-slate-900:hover{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow:hover{--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)}.hover\:shadow-2xl:hover{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\: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)}.hover\:shadow-md:hover{--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)}.hover\:shadow-sm:hover{--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)}.hover\:shadow-xl:hover{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-green-200:hover{--tw-shadow-color: #bbf7d0;--tw-shadow: var(--tw-shadow-colored)}.hover\:ring-purple-200:hover{--tw-ring-opacity: 1;--tw-ring-color: rgb(233 213 255 / var(--tw-ring-opacity))}.hover\:file\:bg-purple-100::file-selector-button:hover{--tw-bg-opacity: 1;background-color:rgb(243 232 255 / var(--tw-bg-opacity))}.focus\:border-blue-500:focus{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity))}.focus\:border-green-500:focus{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity))}.focus\:border-transparent:focus{border-color:transparent}.focus\:bg-white:focus{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.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-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity))}.focus\:ring-blue-600:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(37 99 235 / var(--tw-ring-opacity))}.focus\:ring-emerald-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(16 185 129 / var(--tw-ring-opacity))}.focus\:ring-green-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity))}.focus\:ring-indigo-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(99 102 241 / var(--tw-ring-opacity))}.focus\:ring-purple-100:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(243 232 255 / var(--tw-ring-opacity))}.focus\:ring-purple-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity))}.focus\:ring-red-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(239 68 68 / var(--tw-ring-opacity))}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus\:ring-white\/40:focus{--tw-ring-color: rgb(255 255 255 / .4)}.focus\:ring-white\/50:focus{--tw-ring-color: rgb(255 255 255 / .5)}.focus\:ring-white\/60:focus{--tw-ring-color: rgb(255 255 255 / .6)}.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-0: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(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.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-blue-500:focus-visible{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity))}.focus-visible\:ring-green-500:focus-visible{--tw-ring-opacity: 1;--tw-ring-color: rgb(34 197 94 / var(--tw-ring-opacity))}.focus-visible\:ring-purple-500:focus-visible{--tw-ring-opacity: 1;--tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity))}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-slate-950:focus-visible{--tw-ring-opacity: 1;--tw-ring-color: rgb(2 6 23 / var(--tw-ring-opacity))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.active\:scale-90:active{--tw-scale-x: .9;--tw-scale-y: .9;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))}.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)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.active\:scale-\[0\.98\]:active{--tw-scale-x: .98;--tw-scale-y: .98;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))}.active\:scale-\[0\.99\]:active{--tw-scale-x: .99;--tw-scale-y: .99;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))}.active\:bg-blue-100:active{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity))}.active\:bg-green-100:active{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity))}.active\:bg-green-700:active{--tw-bg-opacity: 1;background-color:rgb(21 128 61 / var(--tw-bg-opacity))}.active\:bg-red-100:active{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity))}.active\:bg-red-200:active{--tw-bg-opacity: 1;background-color:rgb(254 202 202 / var(--tw-bg-opacity))}.active\:bg-red-700:active{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity))}.active\:bg-slate-100:active{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity))}.active\:bg-slate-200:active{--tw-bg-opacity: 1;background-color:rgb(226 232 240 / var(--tw-bg-opacity))}.active\:bg-white\/30:active{background-color:#ffffff4d}.active\:text-blue-700:active{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity))}.active\:text-green-600:active{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity))}.active\:opacity-80:active{opacity:.8}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:scale-100:disabled{--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-slate-100:disabled{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity))}.disabled\:text-slate-500:disabled{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity))}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-70:disabled{opacity:.7}.group:hover .group-hover\:-translate-y-1{--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))}.group:hover .group-hover\:-translate-y-2{--tw-translate-y: -.5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:translate-x-1{--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))}.group:hover .group-hover\:scale-105{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group: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))}.group:hover .group-hover\:border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity))}.group:hover .group-hover\:bg-slate-100{--tw-bg-opacity: 1;background-color:rgb(241 245 249 / var(--tw-bg-opacity))}.group:hover .group-hover\:bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.group:hover .group-hover\:text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity))}.group:hover .group-hover\:text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity))}.group:hover .group-hover\:text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity))}.group:hover .group-hover\:text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity))}.group:hover .group-hover\:text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity))}.group:hover .group-hover\:text-purple-700{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity))}.group:hover .group-hover\:text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity))}.group:hover .group-hover\:underline{text-decoration-line:underline}.group:hover .group-hover\:opacity-100{opacity:1}.group:hover .group-hover\: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)}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[state\=active\]\:bg-amber-50[data-state=active]{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity))}.data-\[state\=active\]\:bg-purple-50[data-state=active]{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity))}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:hsl(var(--accent))}.data-\[state\=active\]\:text-amber-700[data-state=active]{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity))}.data-\[state\=active\]\:text-purple-700[data-state=active]{--tw-text-opacity: 1;color:rgb(126 34 206 / var(--tw-text-opacity))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:hsl(var(--muted-foreground))}@supports (backdrop-filter: var(--tw)){.supports-\[backdrop-filter\]\:bg-background\/60{background-color:hsl(var(--background) / .6)}}@media (min-width: 640px){.sm\:order-1{order:1}.sm\:order-2{order:2}.sm\:col-span-4{grid-column:span 4 / span 4}.sm\:col-span-6{grid-column:span 6 / span 6}.sm\:col-span-8{grid-column:span 8 / span 8}.sm\:flex{display:flex}.sm\:h-auto{height:auto}.sm\:max-h-\[85vh\]{max-height:85vh}.sm\:w-40{width:10rem}.sm\:w-auto{width:auto}.sm\:max-w-\[1000px\]{max-width:1000px}.sm\:max-w-\[600px\]{max-width:600px}.sm\:max-w-\[900px\]{max-width:900px}.sm\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:rounded-2xl{border-radius:1rem}.sm\:rounded-b-2xl{border-bottom-right-radius:1rem;border-bottom-left-radius:1rem}.sm\:rounded-t-2xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.sm\:p-4{padding:1rem}.sm\:p-5{padding:1.25rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-5xl{font-size:3rem;line-height:1}}@media (min-width: 768px){.md\:static{position:static}.md\:col-span-2{grid-column:span 2 / span 2}.md\:col-span-3{grid-column:span 3 / span 3}.md\:mb-4{margin-bottom:1rem}.md\:mb-6{margin-bottom:1.5rem}.md\:mr-2{margin-right:.5rem}.md\:mt-1{margin-top:.25rem}.md\:mt-4{margin-top:1rem}.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:h-12{height:3rem}.md\:h-2{height:.5rem}.md\:h-6{height:1.5rem}.md\:h-8{height:2rem}.md\:h-96{height:24rem}.md\:h-full{height:100%}.md\:h-screen{height:100vh}.md\:w-1\/2{width:50%}.md\:w-2{width:.5rem}.md\:w-48{width:12rem}.md\:w-6{width:1.5rem}.md\:w-8{width:2rem}.md\:w-96{width:24rem}.md\:w-auto{width:auto}.md\:flex-none{flex:none}.md\:translate-x-0{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:gap-3{gap:.75rem}.md\:gap-4{gap:1rem}.md\: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))}.md\: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))}.md\: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))}.md\:space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.md\:overflow-hidden{overflow:hidden}.md\:rounded-2xl{border-radius:1rem}.md\:rounded-xl{border-radius:.75rem}.md\:border-b-0{border-bottom-width:0px}.md\:border-r{border-right-width:1px}.md\:p-12{padding:3rem}.md\:p-16{padding:4rem}.md\:p-3{padding:.75rem}.md\:p-4{padding:1rem}.md\:p-6{padding:1.5rem}.md\:p-8{padding:2rem}.md\:px-8{padding-left:2rem;padding-right:2rem}.md\:py-24{padding-top:6rem;padding-bottom:6rem}.md\:pl-64{padding-left:16rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-7xl{font-size:4.5rem;line-height:1}.md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:shadow-none{--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}}@media (min-width: 1024px){.lg\:col-span-1{grid-column:span 1 / span 1}.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-4{grid-column:span 4 / span 4}.lg\:col-span-8{grid-column:span 8 / span 8}.lg\:flex{display:flex}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.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\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.lg\:gap-6{gap:1.5rem}.lg\:text-5xl{font-size:3rem;line-height:1}.lg\:text-7xl{font-size:4.5rem;line-height:1}}@media (min-width: 1280px){.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.cccd-uploader{width:100%}.upload-container{position:relative;width:100%;min-height:200px;border-radius:12px;overflow:hidden;transition:all .3s ease}.upload-container.status-idle{border:2px dashed #d4a574;background:#fef7f0}.upload-container.status-uploading{border:2px solid #f97316;background:#fff7ed}.upload-container.status-success{border:2px solid #16a34a;background:#f0fdf4}.upload-container.status-error{border:2px solid #dc2626;background:#fef2f2}.upload-container.status-processing{border:2px solid #3b82f6;background:#eff6ff}.upload-container.status-ready_to_upload{border:2px solid #10b981;background:#f0fdf4}.upload-container.drag-active{border:2px solid #f97316;background:#fff7ed;transform:scale(1.02);box-shadow:0 8px 24px #f9731633}.upload-trigger{display:block;width:100%;height:100%;cursor:pointer;transition:all .2s}.upload-trigger:hover .upload-placeholder{transform:scale(1.02)}.upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;min-height:200px;transition:transform .2s}.icon-large{color:#d4a574;margin-bottom:16px}.upload-text{font-size:16px;font-weight:600;color:#374151;margin:0 0 8px}.upload-hint{font-size:13px;color:#9ca3af;margin:0}.upload-hint-small{font-size:12px;margin-top:4px}.upload-hint-tip{margin-top:12px;padding:8px 16px;background:#fef3c7;border-radius:8px;color:#92400e;font-size:12px;font-weight:500}.progress-bar{width:200px;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden;margin-top:16px}.progress-fill{height:100%;background:linear-gradient(90deg,#f97316,#ea580c);transition:width .3s ease;border-radius:3px}.preview-container{position:relative;width:100%;height:100%;min-height:200px}.preview-container img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;max-height:300px;border-radius:8px;background-color:#f9fafb}.btn-view-image{background:#fff3;border:1px solid rgba(255,255,255,.4);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:all .2s;margin-top:8px}.btn-view-image:hover{background:#ffffff4d;transform:scale(1.05)}.preview-overlay{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.status-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 4px 12px #00000026}.status-badge.success{background:#10b981f2;color:#fff}.status-badge.error{background:#dc2626f2;color:#fff}.status-badge.uploading{background:#f97316f2;color:#fff}.btn-change{position:absolute;bottom:12px;left:50%;transform:translate(-50%);padding:10px 24px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000001a}.btn-change:hover{background:#f9fafb;transform:translate(-50%) translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-upload-file{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:12px;padding:12px 20px;background:#f97316;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #f9731633}.btn-upload-file:hover:not(:disabled){background:#ea580c;transform:translateY(-1px);box-shadow:0 4px 12px #f973164d}.btn-upload-file:active:not(:disabled){transform:translateY(0)}.btn-upload-file:disabled{background:#d1d5db;cursor:not-allowed;opacity:.6}.btn-upload-file svg{width:18px;height:18px}.error-message{display:flex;align-items:center;gap:8px;margin-top:12px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px;font-weight:500}.error-message.warning{background:#fef3c7;border:1px solid #fde68a;color:#92400e}.quality-info{position:absolute;bottom:12px;left:12px;display:flex;gap:8px;flex-wrap:wrap}.quality-badge{padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;background:#fffffff2;color:#374151;box-shadow:0 2px 8px #0000001a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.quality-badge.good{background:#10b981f2;color:#fff}.quality-badge.warning{background:#fbbf24f2;color:#78350f}.preview-actions{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:8px}.btn-crop,.btn-upload-confirm{display:flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000001a}.btn-crop{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-crop:hover{background:#f9fafb;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn-upload-confirm{background:#f97316;color:#fff}.btn-upload-confirm:hover{background:#ea580c;transform:translateY(-2px);box-shadow:0 4px 12px #f973164d}.template-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;max-width:100vw;max-height:100vh;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:999999;padding:20px;animation:fadeIn .3s ease;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y;isolation:isolate}.template-overlay-content{background:#fff!important;border-radius:16px;max-width:600px;width:100%!important;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:slideUp .3s ease;position:relative!important;margin:auto;-webkit-overflow-scrolling:touch}.template-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e7eb}.template-overlay-header h3{margin:0;font-size:20px;font-weight:700;color:#1f2937}.template-close-btn{background:transparent;border:none;cursor:pointer;padding:8px;border-radius:8px;color:#6b7280;transition:all .2s;display:flex;align-items:center;justify-content:center}.template-close-btn:hover{background:#f3f4f6;color:#1f2937}.template-overlay-body{padding:24px}.template-image-wrapper{position:relative;width:100%;margin-bottom:24px;border-radius:12px;overflow:hidden;background:#f9fafb;border:2px dashed #d1d5db}.template-image{width:100%;height:auto;display:block;opacity:.3;filter:blur(2px);transition:opacity .3s}.template-overlay-blur{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#ffffff1a;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.template-instruction{text-align:center;font-size:18px;font-weight:600;color:#1f2937;padding:16px 20px;background:#fffffff2;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin:0 0 8px}.template-instruction-sub{text-align:center;font-size:14px;font-weight:400;color:#4b5563;padding:0 20px;margin:0}.template-tips{background:#fef3c7;border:1px solid #fde68a;border-radius:12px;padding:20px}.tips-title{font-size:16px;font-weight:700;color:#92400e;margin:0 0 12px}.tips-list{margin:0;padding-left:20px;color:#78350f}.tips-list li{margin-bottom:8px;font-size:14px;line-height:1.6}.tips-list li:last-child{margin-bottom:0}.template-overlay-footer{display:flex;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;justify-content:flex-end}.template-cancel-btn,.template-confirm-btn{padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;gap:8px}.template-cancel-btn{background:#f3f4f6;color:#374151}.template-cancel-btn:hover{background:#e5e7eb}.template-confirm-btn{background:#f97316;color:#fff}.template-confirm-btn:hover{background:#ea580c;transform:translateY(-1px);box-shadow:0 4px 12px #f973164d}@media (max-width: 768px){.upload-placeholder{padding:30px 15px;min-height:180px}.icon-large{width:32px;height:32px}.upload-text{font-size:14px}.preview-container img{max-height:250px}.status-badge{padding:6px 12px;font-size:12px}.btn-change{padding:8px 20px;font-size:13px}.btn-upload-file{padding:14px 20px;font-size:15px;min-height:48px}.btn-upload-file svg{width:20px;height:20px}.template-overlay{padding:10px}.template-overlay-content{max-width:100%!important;max-height:95vh;border-radius:12px}.template-overlay-header{padding:16px 20px}.template-overlay-header h3{font-size:18px}.template-overlay-body{padding:20px}.template-instruction{font-size:16px;padding:16px}.template-overlay-footer{padding:16px 20px;flex-direction:column}.template-cancel-btn,.template-confirm-btn{width:100%;justify-content:center}}:root{--primary-red: #dc2626;--primary-orange: #f97316;--text-dark: #1a1a1a;--text-muted: #64748b;--border-color: #e2e8f0;--bg-light: #f8fafc;--upload-tan: #d4a574}.a4-registration-page{min-height:100vh;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);padding:40px 20px;display:flex;justify-content:center;align-items:flex-start}.a4-form-wrapper{width:100%;max-width:800px;background:#fff;box-shadow:0 10px 40px #0000001a,0 0 0 1px #0000000d;padding:50px 60px;font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;font-size:14px;line-height:1.6;color:var(--text-dark);position:relative}.a4-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px;padding-bottom:16px;border-bottom:2px solid var(--border-color)}.header-left{text-align:left}.org-label{font-size:11px;color:var(--text-muted);margin:0 0 2px;text-transform:uppercase;font-family:Inter,sans-serif}.org-name{font-size:14px;font-weight:700;color:var(--primary-red);margin:0;text-transform:uppercase;font-family:Inter,sans-serif}.header-right{text-align:right}.brand-name{font-size:14px;font-weight:700;color:var(--text-dark);margin:0;text-transform:uppercase;font-family:Inter,sans-serif}.brand-subtitle{font-size:11px;color:var(--text-muted);font-style:italic;margin:2px 0 0;font-family:Inter,sans-serif}.a4-title{text-align:center;margin-bottom:32px}.a4-title h1{font-size:26px;font-weight:700;color:var(--primary-red);margin:0 0 8px;font-style:italic;letter-spacing:1px}.a4-subtitle{font-size:14px;color:var(--text-muted);font-style:italic;margin:0}.a4-section{margin-bottom:24px}.section-header-row{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;background:var(--bg-light);border-radius:8px;border-left:4px solid var(--primary-red)}.section-icon{color:var(--primary-red)}.section-header-row h2{font-size:15px;font-weight:700;color:var(--text-dark);margin:0;font-family:Inter,sans-serif;text-transform:uppercase}.form-field{margin-bottom:20px}.form-field.full-width{width:100%}.form-field label{display:block;font-size:14px;font-weight:600;color:var(--text-dark);margin-bottom:8px;font-family:Inter,sans-serif}.form-field label .required{color:var(--primary-red)}.form-input{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-family:Inter,sans-serif;background:#fff;transition:all .2s;box-sizing:border-box}.form-input:focus{outline:none;border-color:var(--primary-red);box-shadow:0 0 0 3px #dc26261a}.form-input.error{border-color:var(--primary-red)}.form-input::-moz-placeholder{color:#9ca3af}.form-input::placeholder{color:#9ca3af}.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:20px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px}.date-selects{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.date-select{min-width:0;padding:12px 8px!important;text-align:center}.radio-group{display:flex;gap:32px;padding:12px 0}.radio-group-inline{display:flex;gap:24px;margin-bottom:12px}.radio-option{display:flex;align-items:center;gap:8px;cursor:pointer;font-family:Inter,sans-serif;font-size:14px}.radio-option input[type=radio]{width:18px;height:18px;accent-color:var(--primary-red)}.text-red{color:var(--primary-red)}.form-hint{font-size:12px;color:var(--primary-red);font-style:italic;margin-top:6px}.error-text{font-size:12px;color:var(--primary-red);margin-top:4px;font-family:Inter,sans-serif}.ml-6{margin-left:24px}.upload-section{margin-top:32px;padding-top:24px;border-top:1px solid var(--border-color)}.upload-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px}.upload-card{text-align:center}.upload-label{font-size:13px;color:#1e40af;text-decoration:underline;margin:0 0 16px;font-family:Inter,sans-serif}.upload-area{width:100%;height:180px;border:2px dashed var(--upload-tan);background:#fef7f0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;border-radius:8px;margin-bottom:12px}.upload-area:hover{border-color:var(--primary-orange);background:#fff7ed}.upload-area.has-image{border-style:solid;padding:8px}.upload-area.has-image img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;border-radius:4px}.upload-placeholder{display:flex;flex-direction:column;align-items:center;color:var(--upload-tan)}.upload-placeholder span{font-size:32px;margin-top:4px}.view-rules-btn{background:none;border:none;color:#1e40af;font-size:12px;cursor:pointer;text-decoration:underline;padding:4px 8px;font-family:Inter,sans-serif}.view-rules-btn:hover{color:#1d4ed8}.upload-area.has-error{border-color:var(--primary-red);background:#fef2f2;animation:shake .5s ease-in-out}.upload-area.has-error:hover{border-color:var(--primary-red);background:#fee2e2}.upload-error-text{font-size:12px;color:var(--primary-red);margin:4px 0 8px;font-family:Inter,sans-serif;font-weight:500}.upload-label .required{color:var(--primary-red);font-weight:700}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.commitments-section{margin-top:24px;padding:20px;background:var(--bg-light);border-radius:8px}.checkbox-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;cursor:pointer}.checkbox-row input[type=checkbox]{margin-top:3px;width:18px;height:18px;accent-color:#16a34a}.checkbox-row span{font-size:13px;line-height:1.5;font-family:Inter,sans-serif}.signature-section{text-align:right;margin-top:32px;padding-right:80px}.signature-date{font-size:14px;font-style:italic;color:var(--primary-red);margin:0 0 4px}.signature-title{font-weight:700;font-size:14px;margin:0}.signature-hint{font-size:13px;font-style:italic;color:var(--text-muted);margin:2px 0 0}.notes-section{margin-top:40px;padding-top:20px;border-top:1px solid var(--border-color)}.notes-title{font-weight:700;font-style:italic;margin:0 0 12px}.note-item{font-size:12px;margin:0 0 6px;line-height:1.6;color:var(--text-dark)}.a4-footer{display:flex;justify-content:space-between;margin-top:32px;padding-top:20px;border-top:1px solid #ccc}.contact-info p{font-size:12px;margin:0 0 4px;font-family:Inter,sans-serif}.footer-right{text-align:right}.footer-right p{font-size:13px;margin:0 0 4px}.center-name{font-weight:700}.message-box{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:8px;margin-top:24px;font-family:Inter,sans-serif;font-size:14px}.error-box{background:#fef2f2;color:var(--primary-red);border:1px solid #fecaca}.success-box{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.submit-container{display:flex;justify-content:center;gap:16px;margin-top:32px;padding-top:24px}.btn-secondary{display:flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;color:var(--text-dark);border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif}.btn-secondary:hover{background:var(--bg-light)}.btn-primary{display:flex;align-items:center;gap:8px;padding:12px 32px;background:linear-gradient(135deg,var(--primary-orange) 0%,#ea580c 100%);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif;box-shadow:0 4px 12px #f973164d}.btn-primary:hover{background:linear-gradient(135deg,#ea580c,#c2410c);transform:translateY(-2px);box-shadow:0 6px 16px #f9731666}.back-link{text-align:center;margin-top:24px}.back-link a{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);text-decoration:none;font-size:13px;font-family:Inter,sans-serif;transition:color .2s}.back-link a:hover{color:var(--primary-red)}.instruction-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.instruction-modal-content{background:#fff;border-radius:12px;max-width:420px;width:100%;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.instruction-modal-header{background:#fff7ed;padding:16px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid #fed7aa}.instruction-modal-header h3{font-size:15px;font-weight:600;color:#ea580c;margin:0;font-family:Inter,sans-serif}.instruction-modal-body{padding:20px}.instruction-image{background:var(--bg-light);padding:16px;border-radius:8px;margin-bottom:16px}.instruction-image img{width:100%;height:auto;border-radius:6px}.instruction-rules p{font-size:13px;margin:0 0 6px;color:#374151;font-family:Inter,sans-serif}.instruction-close-btn{display:block;width:calc(100% - 40px);margin:0 20px 20px;background:linear-gradient(135deg,var(--primary-orange) 0%,#ea580c 100%);color:#fff;border:none;padding:12px 24px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;font-family:Inter,sans-serif}.instruction-close-btn:hover{background:linear-gradient(135deg,#ea580c,#c2410c)}@media print{.a4-registration-page{background:#fff;padding:0}.a4-form-wrapper{box-shadow:none;max-width:none;padding:20mm 25mm}.submit-container,.back-link{display:none}}@media (max-width: 768px){.a4-registration-page{padding:10px;align-items:flex-start;min-height:auto;overflow-x:hidden}.a4-form-wrapper{transform:scale(.55);transform-origin:top center;margin-bottom:-45%;padding:40px 50px;min-width:800px}.a4-header{flex-direction:row;gap:0;text-align:left}.header-left{text-align:left}.header-right{text-align:right}.a4-title h1{font-size:26px}.form-row-2{grid-template-columns:1fr 1fr;gap:24px}.form-row-3,.upload-grid{grid-template-columns:1fr 1fr 1fr;gap:16px}.a4-footer{flex-direction:row;gap:0}.footer-right{text-align:right}.signature-section{text-align:right;padding-right:80px}.submit-container{flex-direction:row}}@media (max-width: 480px){.a4-form-wrapper{transform:scale(.42);margin-bottom:-58%}}@media (max-width: 380px){.a4-form-wrapper{transform:scale(.38);margin-bottom:-62%}}.lookup-container{min-height:calc(100vh - 200px);padding:40px 20px;background:linear-gradient(135deg,#f5f7fa,#fff);display:flex;justify-content:center;align-items:flex-start}.lookup-card{background:#fff;border-radius:16px;padding:40px;box-shadow:0 4px 20px #0000001a;max-width:800px;width:100%;animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lookup-card h1{color:#333;font-size:28px;margin-bottom:10px;text-align:center}.lookup-subtitle{text-align:center;color:#666;font-size:16px;margin-bottom:30px}.lookup-form{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}.form-group label{font-size:14px;font-weight:600;color:#333}.form-group input{padding:14px 18px;border:2px solid #e0e0e0;border-radius:10px;font-size:15px;transition:all .3s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.btn-large{padding:16px 32px;font-size:16px;font-weight:700}.error-message{padding:12px 16px;background:#f8d7da;color:#721c24;border-radius:8px;border:1px solid #f5c6cb;font-size:14px}.certificates-results{margin-top:40px;padding-top:30px;border-top:2px solid #e0e0e0}.certificates-results h2{color:#333;font-size:22px;margin-bottom:20px}.certificate-result-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e0e0e0;border-radius:12px;padding:24px;margin-bottom:20px;transition:all .3s}.certificate-result-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:#667eea}.certificate-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e0e0e0}.certificate-header h3{color:#333;font-size:20px;margin:0}.certificate-number{font-size:14px;font-weight:700;color:#667eea;background:#f0f4ff;padding:6px 12px;border-radius:8px}.certificate-details{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.detail-row{display:flex;padding:10px;background:#f8f9fa;border-radius:8px}.detail-row strong{min-width:120px;color:#667eea;font-size:14px}.detail-row span{flex:1;color:#333;font-size:14px}.status-active{color:#28a745;font-weight:700}.status-revoked{color:#dc3545;font-weight:700}.certificate-actions{display:flex;justify-content:center;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}@media (max-width: 768px){.lookup-card{padding:24px}.certificate-header{flex-direction:column;align-items:flex-start;gap:10px}.detail-row{flex-direction:column;gap:5px}.detail-row strong{min-width:auto}}@media (max-width: 768px){.dashboard-sidebar,aside.dashboard-sidebar,aside.dashboard-sidebar.w-64{width:80vw!important;max-width:320px!important;min-width:0!important}.dashboard-sidebar{box-shadow:4px 0 24px #00000026!important}.dashboard-sidebar>div>div:first-child{height:3.75rem!important;padding-left:1rem!important;padding-right:.75rem!important;min-height:60px!important}.dashboard-sidebar>div>div:first-child .text-xl{font-size:1.125rem!important;font-weight:700!important}.dashboard-sidebar>div>div:first-child .w-10,.dashboard-sidebar>div>div:first-child .h-10{width:2.25rem!important;height:2.25rem!important;min-width:36px!important;min-height:36px!important}.dashboard-sidebar>div>div[class*=mx-4]{margin-left:.875rem!important;margin-right:.875rem!important;margin-top:1rem!important;padding:.875rem!important}.dashboard-sidebar>div>div[class*=mx-4] .w-10,.dashboard-sidebar>div>div[class*=mx-4] .h-10{width:2.5rem!important;height:2.5rem!important}.dashboard-sidebar>div>div[class*=mx-4] p{font-size:.875rem!important;line-height:1.4!important}.dashboard-sidebar nav{padding:.75rem .875rem!important}.dashboard-sidebar nav li{margin-bottom:.25rem!important}.dashboard-sidebar nav li a{padding:.75rem .875rem!important;min-height:44px!important;font-size:.9375rem!important;line-height:1.5!important;gap:.75rem!important;display:flex!important;align-items:center!important}.dashboard-sidebar nav li a svg{width:20px!important;height:20px!important;flex-shrink:0!important}.dashboard-sidebar>div>div:last-child{padding:1rem .875rem!important;border-top:1px solid rgba(0,0,0,.08)!important}.dashboard-sidebar button[class*=h-12]{height:44px!important;min-height:44px!important;font-size:.9375rem!important;padding-left:.875rem!important;padding-right:.875rem!important}.dashboard-sidebar button[class*=h-12] svg{width:20px!important;height:20px!important}}@media (max-width: 480px){.dashboard-sidebar,aside.dashboard-sidebar,aside.dashboard-sidebar.w-64{width:85vw!important;max-width:300px!important;min-width:0!important}.dashboard-sidebar>div>div:first-child{height:3.5rem!important;padding-left:.875rem!important;padding-right:.625rem!important}.dashboard-sidebar nav li a{padding-top:.625rem!important;padding-bottom:.625rem!important;font-size:.875rem!important}}@media (max-width: 360px){.dashboard-sidebar,aside.dashboard-sidebar,aside.dashboard-sidebar.w-64{width:85vw!important;max-width:280px!important;min-width:0!important}}@media (max-width: 768px){.dashboard-sidebar{position:fixed!important;z-index:50!important}}@media (max-width: 768px){.flex.flex-col.md\\:pl-64{margin-left:0!important;padding-left:0!important;width:100%!important}header.sticky.top-0{height:3.5rem!important;padding-left:1rem!important;padding-right:1rem!important;gap:.75rem!important}header.sticky.top-0 button{min-width:44px!important;min-height:44px!important;padding:.5rem!important}header.sticky.top-0 span{font-size:1rem!important;font-weight:600!important}main.flex-1{padding:.75rem!important}main.flex-1,.flex.flex-col{overflow-x:hidden!important;max-width:100vw!important}}@media (max-width: 480px){header.sticky.top-0{height:3.25rem!important;padding-left:.75rem!important;padding-right:.75rem!important}main.flex-1{padding:.5rem!important}}.toast{position:fixed;top:20px;right:20px;min-width:300px;max-width:500px;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:10000;display:flex;align-items:center;justify-content:space-between;animation:slideIn .3s ease-out;font-size:14px;line-height:1.5}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;gap:12px;flex:1}.toast-icon{font-size:20px;flex-shrink:0}.toast-message{flex:1;word-wrap:break-word}.toast-close{background:none;border:none;font-size:24px;cursor:pointer;color:inherit;opacity:.7;padding:0;margin-left:12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s}.toast-close:hover{opacity:1}.toast-success{background-color:#10b981;color:#fff}.toast-error{background-color:#ef4444;color:#fff}.toast-warning{background-color:#f59e0b;color:#fff}.toast-info{background-color:#3b82f6;color:#fff}@media (max-width: 768px){.toast{top:10px;right:10px;left:10px;min-width:auto;max-width:none}}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-around;background:#fff;border-top:1px solid #e2e8f0;z-index:100;box-shadow:0 -2px 10px #0000000d;height:70px;padding:0 4px}.mobile-bottom-nav.ios{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.mobile-bottom-nav.android{background:#fff;box-shadow:0 -4px 6px -1px #0000001a}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:5px 1px;border:none;background:transparent;color:#64748b;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;min-height:44px;min-width:0;max-width:100%;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.mobile-nav-item:active{transform:scale(.95)}.mobile-nav-item.active{color:#16a34a}.mobile-nav-item svg{transition:all .2s ease;flex-shrink:0;width:22px;height:22px}.mobile-nav-item.active svg{transform:scale(1.05)}.mobile-nav-label{font-size:9px;font-weight:500;line-height:1.1;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.mobile-nav-indicator{position:absolute;top:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:#16a34a;border-radius:0 0 3px 3px}.mobile-bottom-nav.android .mobile-nav-item{color:#64748b}.mobile-bottom-nav.android .mobile-nav-item.active{color:#16a34a}.mobile-bottom-nav.android .mobile-nav-indicator{background:#16a34a}.teacher-schedule-page{padding:var(--spacing-2xl);box-sizing:border-box;width:100%;max-width:100%}.schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);flex-wrap:wrap;gap:var(--spacing-lg)}.schedule-header h1{margin:0;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--teacher-text-primary);line-height:var(--line-height-tight)}.schedule-controls{display:flex;gap:var(--spacing-md);align-items:center}.btn-nav,.btn-today{padding:var(--spacing-md) var(--spacing-xl);border:2px solid var(--teacher-primary);border-radius:var(--radius-sm);background:var(--teacher-bg);color:var(--teacher-primary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);cursor:pointer;transition:all var(--transition-base);touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:44px}.btn-nav:hover,.btn-today:hover,.btn-today{background:var(--teacher-primary);color:#fff}.schedule-info{margin-bottom:var(--spacing-2xl);padding:var(--spacing-md);background:var(--teacher-primary-lightest);border-radius:var(--radius-sm);text-align:center}.schedule-info p{margin:0;color:var(--teacher-primary-dark);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.schedule-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-xl)}.schedule-day{background:var(--teacher-bg);border-radius:var(--radius-md);padding:var(--spacing-lg);box-shadow:var(--shadow-md);border:2px solid transparent}.schedule-day.today{border-color:var(--teacher-primary);background:var(--teacher-primary-lightest)}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--teacher-border)}.day-header h3{margin:0;font-size:var(--font-size-lg);color:var(--teacher-text-primary);font-weight:var(--font-weight-semibold)}.day-date{font-size:var(--font-size-xs);color:var(--teacher-text-tertiary)}.day-classes{display:flex;flex-direction:column;gap:var(--spacing-md)}.no-class{text-align:center;color:var(--teacher-text-muted);font-size:var(--font-size-sm);padding:var(--spacing-xl)}.class-item{padding:var(--spacing-md);background:var(--teacher-bg-tertiary);border-radius:var(--radius-sm);border-left:4px solid var(--teacher-primary);transition:all var(--transition-base)}.class-item.clickable{cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.class-item.clickable:hover{transform:translate(4px);background:var(--teacher-primary-lightest);box-shadow:var(--shadow-sm)}.class-time{font-weight:var(--font-weight-semibold);color:var(--teacher-primary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-xs)}.class-name{font-weight:var(--font-weight-semibold);color:var(--teacher-text-primary);font-size:var(--font-size-base);margin-bottom:var(--spacing-xs)}.class-code{font-size:var(--font-size-xs);color:var(--teacher-text-tertiary);margin-bottom:var(--spacing-xs)}.class-room,.class-notes,.class-meeting{font-size:var(--font-size-xs);color:var(--teacher-text-tertiary);margin-top:var(--spacing-xs)}.class-meeting.has-link{color:var(--teacher-info);font-weight:var(--font-weight-semibold);background:var(--teacher-info-light);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);display:inline-block}.class-room.no-room{color:var(--teacher-error);font-style:italic}.schedule-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-xl);animation:fadeIn var(--transition-base)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.schedule-modal{background:var(--teacher-bg);border-radius:var(--radius-lg);max-width:480px;width:100%;box-shadow:var(--shadow-xl);animation:slideUp var(--transition-slow);overflow:hidden}.schedule-modal-header{background:linear-gradient(135deg,var(--teacher-primary) 0%,var(--teacher-primary-dark) 100%);padding:var(--spacing-2xl);display:flex;justify-content:space-between;align-items:flex-start}.header-content{display:flex;gap:var(--spacing-lg);align-items:flex-start}.class-icon{font-size:40px;background:#fff3;padding:var(--spacing-md);border-radius:var(--radius-md)}.class-info h2{margin:0 0 var(--spacing-sm) 0;color:#fff;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.class-code-badge{display:inline-block;background:#ffffff40;color:#fff;padding:var(--spacing-xs) var(--spacing-md);border-radius:20px;font-size:13px;font-weight:var(--font-weight-semibold)}.close-btn{background:#fff3;border:none;width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-base);color:#fff;flex-shrink:0;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.close-btn:hover{background:#ffffff59;transform:rotate(90deg)}.schedule-modal-body{padding:var(--spacing-2xl);display:flex;flex-direction:column;gap:var(--spacing-md)}.info-card{display:flex;gap:var(--spacing-lg);padding:var(--spacing-lg);background:var(--teacher-bg-tertiary);border-radius:var(--radius-md);align-items:flex-start;transition:all var(--transition-base)}.info-card:hover{transform:translate(4px);box-shadow:var(--shadow-sm)}.time-card{background:var(--teacher-primary-lightest);border-left:4px solid var(--teacher-primary)}.card-icon{font-size:28px;line-height:1}.card-content{display:flex;flex-direction:column;gap:var(--spacing-xs)}.card-label{font-size:var(--font-size-xs);color:var(--teacher-text-tertiary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px}.card-value{font-size:var(--font-size-base);color:var(--teacher-text-primary);font-weight:var(--font-weight-semibold)}.card-value.primary{color:var(--teacher-primary-dark);font-size:var(--font-size-lg)}.card-sub{font-size:var(--font-size-sm);color:var(--teacher-text-tertiary)}.meeting-link-card{display:flex;gap:var(--spacing-lg);padding:var(--spacing-lg) var(--spacing-xl);background:var(--teacher-info);border-radius:var(--radius-md);align-items:center;text-decoration:none;transition:all var(--transition-slow);box-shadow:var(--shadow-md)}.meeting-link-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.meeting-icon{font-size:32px;background:#fff3;padding:var(--spacing-md);border-radius:var(--radius-md)}.meeting-content{flex:1}.meeting-title{display:block;color:#fff;font-size:var(--font-size-base);font-weight:var(--font-weight-bold)}.meeting-sub{display:block;color:#fffc;font-size:13px;margin-top:2px}.meeting-arrow{font-size:var(--font-size-2xl);color:#fff;font-weight:var(--font-weight-bold)}.schedule-modal-footer{padding:var(--spacing-xl) var(--spacing-2xl);border-top:1px solid var(--teacher-border-light);display:flex;gap:var(--spacing-md)}.btn-view-class{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-2xl);background:var(--teacher-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-slow);box-shadow:var(--shadow-md);touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:44px}.btn-view-class:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--teacher-primary-dark)}.btn-close{padding:var(--spacing-md) var(--spacing-2xl);background:var(--teacher-bg-tertiary);color:var(--teacher-text-secondary);border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);touch-action:manipulation;-webkit-tap-highlight-color:transparent;min-height:44px}.btn-close:hover{background:var(--teacher-border);color:var(--teacher-text-primary)}@media (max-width: 768px){.teacher-schedule-page{padding:var(--spacing-lg)!important;padding-top:calc(var(--spacing-lg) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-lg) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-lg) + env(safe-area-inset-right,0px));margin:0;max-width:100%}.schedule-header{flex-direction:column;align-items:stretch;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.schedule-header h1{font-size:var(--font-size-2xl)}.schedule-controls{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-sm);width:100%}.btn-nav,.btn-today{padding:var(--spacing-md) var(--spacing-sm);font-size:var(--font-size-base)!important;min-height:44px!important;min-width:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}.btn-today{grid-column:1 / -1}.schedule-info{margin-bottom:var(--spacing-lg);padding:var(--spacing-md)}.schedule-grid{grid-template-columns:1fr;gap:var(--spacing-md)}.schedule-day{padding:var(--spacing-lg)}.day-header{margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm)}.day-header h3{font-size:var(--font-size-lg)}.schedule-modal-overlay{align-items:flex-end;padding:0}.schedule-modal{max-height:90vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:fixed;bottom:0;left:0;right:0;max-width:100%}.schedule-modal-header{padding:var(--spacing-xl);position:sticky;top:0;z-index:10}.schedule-modal-body{padding:var(--spacing-xl)}.schedule-modal-footer{padding:var(--spacing-lg) var(--spacing-xl);flex-direction:column;position:sticky;bottom:0;background:var(--teacher-bg)}.btn-view-class,.btn-close{width:100%}}@media (max-width: 480px){.teacher-schedule-page{padding:var(--spacing-md)}.schedule-header h1{font-size:var(--font-size-xl)}.schedule-day{padding:var(--spacing-md)}}.teacher-exams-page{padding:var(--spacing-2xl);box-sizing:border-box}.exams-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.exams-header h1{margin:0;font-size:28px;color:#2c3e50}.filter-buttons{display:flex;gap:8px}.filter-buttons button{padding:8px 16px;border:2px solid #4CAF50;border-radius:8px;background:#fff;color:#4caf50;font-weight:600;cursor:pointer;transition:all .2s}.filter-buttons button:hover{background:#f1f8f4}.filter-buttons button.active{background:#4caf50;color:#fff}.exams-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:20px}.exam-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;border-left:4px solid #ff9800;transition:transform .2s,box-shadow .2s}.exam-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.exam-card.past{opacity:.7;border-left-color:#95a5a6}.exam-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #e0e0e0}.exam-header h3{margin:0;font-size:20px;color:#2c3e50;flex:1}.badge-past{background:#95a5a6;color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600}.exam-details{display:flex;flex-direction:column;gap:12px}.exam-detail-item{display:flex;gap:12px}.exam-detail-item .label{font-weight:600;color:#7f8c8d;min-width:100px}.exam-detail-item .value{color:#2c3e50;flex:1}@media (max-width: 768px){.teacher-exams-page{padding:var(--spacing-lg)!important;padding-top:calc(var(--spacing-lg) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-lg) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-lg) + env(safe-area-inset-right,0px))}.exams-header{flex-direction:column!important;align-items:stretch!important;gap:var(--spacing-md)!important;margin-bottom:var(--spacing-lg)!important}.exams-header h1{font-size:var(--font-size-2xl)!important;line-height:var(--line-height-tight)!important}.filter-buttons{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:var(--spacing-sm)!important;width:100%!important}.filter-buttons button{padding:var(--spacing-md) var(--spacing-lg)!important;font-size:var(--font-size-base)!important;min-height:44px!important;min-width:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}.exams-list{grid-template-columns:1fr!important;gap:.75rem!important}.exam-card{padding:1rem!important}.exam-header{flex-direction:column!important;gap:.5rem!important;margin-bottom:1rem!important;padding-bottom:.75rem!important}.exam-header h3{font-size:1.125rem!important}.exam-details{gap:.75rem!important}.exam-detail-item{flex-direction:column!important;gap:var(--spacing-xs)!important;font-size:var(--font-size-base)!important}.exam-detail-item .label{min-width:auto!important;font-size:var(--font-size-sm)!important}.exam-detail-item .value{font-size:var(--font-size-base)!important}}.class-students-list{padding:20px}.students-header{margin-bottom:20px}.students-header h3{margin:0;color:#333;font-size:20px}.table-container{overflow-x:auto;border:1px solid #e0e0e0;border-radius:8px}.students-table{width:100%;border-collapse:collapse;background:#fff}.students-table thead{background:#f5f5f5}.students-table th{padding:12px 15px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap}.students-table td{padding:12px 15px;border-bottom:1px solid #f0f0f0;color:#666}.students-table tbody tr:hover{background-color:#f9f9f9}.students-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap}.badge-success{background-color:#d4edda;color:#155724}.badge-info{background-color:#d1ecf1;color:#0c5460}.badge-warning{background-color:#fff3cd;color:#856404}.badge-danger{background-color:#f8d7da;color:#721c24}.badge-secondary{background-color:#e2e3e5;color:#383d41}@media (max-width: 768px){.class-students-list{padding:10px}.students-table{font-size:14px}.students-table th,.students-table td{padding:8px 10px}}.teacher-class-detail-page{padding:var(--spacing-2xl);box-sizing:border-box}.class-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.class-header h1{margin:0;font-size:28px;color:var(--teacher-text-primary)}.class-code{margin:4px 0 0;color:var(--teacher-text-secondary);font-size:14px}.class-info-card{background:#fff;border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 2px 8px #0000001a}.info-row{display:flex;gap:16px;margin-bottom:12px}.info-row .label{font-weight:600;color:var(--teacher-text-secondary);min-width:120px}.info-row .value{color:var(--teacher-text-primary)}.detail-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid var(--teacher-border)}.detail-tabs button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:var(--teacher-text-secondary);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:-2px}.detail-tabs button:hover{color:var(--teacher-primary)}.detail-tabs button.active{color:var(--teacher-primary);border-bottom-color:var(--teacher-primary)}.detail-content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.table-container{overflow-x:auto}.schedules-list{display:flex;flex-direction:column;gap:16px}.schedule-item{padding:16px;background:var(--teacher-bg-secondary);border-radius:8px;border-left:4px solid var(--teacher-primary)}.schedule-day{font-weight:600;font-size:16px;color:var(--teacher-text-primary);margin-bottom:8px}.schedule-time{font-size:14px;color:var(--teacher-primary);font-weight:600;margin-bottom:4px}.schedule-room,.schedule-notes{font-size:14px;color:var(--teacher-text-secondary);margin-top:4px}.exams-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.exam-item{background:var(--teacher-bg-secondary);border-radius:8px;padding:16px;border-left:4px solid var(--teacher-warning)}.exam-header h3{margin:0 0 12px;font-size:18px;color:var(--teacher-text-primary)}.exam-details{display:flex;flex-direction:column;gap:8px}.exam-detail-item{display:flex;gap:12px;font-size:14px}.exam-detail-item .label{font-weight:600;color:var(--teacher-text-secondary);min-width:100px}.exam-detail-item .value{color:var(--teacher-text-primary)}@media (max-width: 768px){.teacher-class-detail-page{padding:var(--spacing-lg)!important;padding-top:calc(var(--spacing-lg) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-lg) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-lg) + env(safe-area-inset-right,0px))}.class-header{flex-direction:column!important;align-items:flex-start!important;gap:var(--spacing-md)!important;margin-bottom:var(--spacing-lg)!important}.class-header h1{font-size:var(--font-size-2xl)!important;line-height:var(--line-height-tight)!important}.class-code{font-size:var(--font-size-sm)!important}.class-info-card{padding:var(--spacing-lg)!important;margin-bottom:var(--spacing-lg)!important}.info-row{flex-direction:column!important;gap:var(--spacing-xs)!important;margin-bottom:var(--spacing-md)!important}.info-row .label{min-width:auto!important;font-size:var(--font-size-sm)!important}.info-row .value{font-size:var(--font-size-base)!important}.detail-tabs{flex-direction:row!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;gap:var(--spacing-sm)!important;padding-bottom:var(--spacing-sm)!important;scrollbar-width:thin}.detail-tabs button{padding:var(--spacing-md) var(--spacing-lg)!important;font-size:var(--font-size-base)!important;white-space:nowrap;min-height:44px!important;min-width:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}.detail-content{padding:var(--spacing-lg)!important}.exams-list{grid-template-columns:1fr!important;gap:var(--spacing-md)!important}.exam-item{padding:var(--spacing-lg)!important}.table-container{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;scrollbar-width:thin}.schedules-list{gap:var(--spacing-md)!important}.schedule-item{padding:var(--spacing-lg)!important}.schedule-day,.schedule-time,.schedule-room,.schedule-notes{font-size:var(--font-size-sm)!important}}.teacher-classes-page{width:100%}@media (max-width: 768px){.teacher-classes-page{padding:0!important}.classes-header{margin-bottom:var(--spacing-lg)!important}.classes-header h1{font-size:var(--font-size-2xl)!important;line-height:var(--line-height-tight)!important}.classes-table-container{border-radius:var(--radius-sm)!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;scrollbar-width:thin;margin:0 calc(-1 * var(--spacing-lg));padding:0 var(--spacing-lg);width:calc(100% + 2 * var(--spacing-lg))}.table-teacher{min-width:800px}.table-teacher th,.table-teacher td{padding:var(--spacing-sm) var(--spacing-md)!important;font-size:var(--font-size-sm)!important;white-space:nowrap;min-height:44px!important}.table-teacher th:nth-child(4),.table-teacher td:nth-child(4),.table-teacher th:nth-child(5),.table-teacher td:nth-child(5){display:none}.table-teacher tbody tr{min-height:44px!important}}@media (max-width: 480px){.table-teacher th,.table-teacher td{padding:var(--spacing-xs) var(--spacing-sm)!important;font-size:var(--font-size-xs)!important}.table-teacher th:nth-child(6),.table-teacher td:nth-child(6){display:none}}.classes-header{margin-bottom:24px}.classes-header h1{margin:0;font-size:28px;color:var(--teacher-text-primary)}.classes-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.teacher-profile-page{padding:var(--spacing-2xl);box-sizing:border-box}.profile-header{margin-bottom:24px}.profile-header h1{margin:0;font-size:28px;color:#2c3e50}.profile-tabs{display:flex;gap:12px;margin-bottom:24px;border-bottom:2px solid #e0e0e0}.profile-tabs button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:#7f8c8d;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;margin-bottom:-2px}.profile-tabs button:hover{color:#4caf50}.profile-tabs button.active{color:#4caf50;border-bottom-color:#4caf50}.profile-section{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.profile-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.form-group input{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .2s}.form-actions{display:flex;justify-content:flex-end;margin-top:8px}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:#4caf50;color:#fff}.btn-primary:hover:not(:disabled){background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.teacher-profile-page{padding:var(--spacing-lg)!important;padding-top:calc(var(--spacing-lg) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-lg) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-lg) + env(safe-area-inset-right,0px));margin:0;max-width:100%}.profile-header{margin-bottom:var(--spacing-lg)!important}.profile-header h1{font-size:var(--font-size-2xl)!important;line-height:var(--line-height-tight)!important}.profile-tabs{flex-direction:row!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;gap:var(--spacing-sm)!important;padding-bottom:var(--spacing-sm)!important;margin-bottom:var(--spacing-lg)!important;scrollbar-width:thin}.profile-tabs button{padding:var(--spacing-md) var(--spacing-lg)!important;font-size:var(--font-size-base)!important;white-space:nowrap;min-height:44px!important;min-width:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}.profile-section{padding:1rem!important}.form-row{grid-template-columns:1fr!important;gap:1rem!important}.form-group{gap:.5rem!important}.form-group label{font-size:var(--font-size-sm)!important}.form-group input{padding:var(--spacing-md)!important;font-size:var(--font-size-base)!important;min-height:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}.form-actions{margin-top:var(--spacing-lg)!important}.btn{padding:var(--spacing-md) var(--spacing-xl)!important;font-size:var(--font-size-base)!important;min-height:44px!important;min-width:44px!important;width:100%!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}}.attendance-page-modern{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto;background:var(--teacher-bg-secondary);min-height:100vh;min-height:calc(var(--vh, 1vh) * 100);box-sizing:border-box;padding-top:calc(var(--spacing-2xl) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-2xl) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-2xl) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-2xl) + env(safe-area-inset-right,0px))}.attendance-header-modern{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-2xl);padding:var(--spacing-xl);background:linear-gradient(135deg,var(--teacher-primary) 0%,var(--teacher-primary-dark) 100%);border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-lg)}.attendance-header-modern h1{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight)}.header-subtitle{margin:0;opacity:.9;font-size:var(--font-size-sm)}.class-info-badge{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:#fff3;border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.badge-label{font-size:13px;opacity:.9}.badge-value{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.attendance-card-modern{background:var(--teacher-bg);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-2xl)}.attendance-form-modern{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.selection-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-xl);padding-bottom:var(--spacing-2xl);border-bottom:2px solid var(--teacher-border-light)}.form-group-modern{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group-modern label{display:flex;align-items:center;gap:var(--spacing-sm);font-weight:var(--font-weight-semibold);color:var(--teacher-text-secondary);font-size:var(--font-size-sm)}.label-icon{color:var(--teacher-primary)}.select-modern,.input-modern{padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--teacher-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);transition:all var(--transition-base);background:var(--teacher-bg);min-height:44px;box-sizing:border-box}.select-modern:focus,.input-modern:focus{outline:none;border-color:var(--teacher-primary);box-shadow:0 0 0 3px var(--teacher-primary-lighter)}.select-modern:disabled,.input-modern:disabled{background:var(--teacher-bg-tertiary);cursor:not-allowed;opacity:.6}.summary-cards-modern{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.summary-card{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-xl);background:var(--teacher-bg-tertiary);border-radius:var(--radius-md);border:2px solid transparent;transition:all var(--transition-base)}.summary-card.total{border-color:var(--teacher-border)}.summary-card.present{border-color:var(--teacher-success);background:var(--teacher-success-light)}.summary-card.absent{border-color:var(--teacher-error);background:var(--teacher-error-light)}.summary-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--teacher-bg);color:var(--teacher-text-tertiary);font-size:var(--font-size-xl)}.summary-icon.present-icon{background:var(--teacher-success);color:#fff}.summary-icon.absent-icon{background:var(--teacher-error);color:#fff}.summary-label{font-size:13px;color:var(--teacher-text-tertiary);margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-medium)}.summary-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--teacher-text-primary)}.summary-value.present-value{color:var(--teacher-success)}.summary-value.absent-value{color:var(--teacher-error)}.quick-actions{display:flex;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.quick-action-btn{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border:2px solid var(--teacher-border);border-radius:var(--radius-sm);background:var(--teacher-bg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base);min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.quick-action-btn.present-btn{color:var(--teacher-success);border-color:var(--teacher-success)}.quick-action-btn.present-btn:hover:not(:disabled){background:var(--teacher-success-light)}.quick-action-btn.absent-btn{color:var(--teacher-error);border-color:var(--teacher-error)}.quick-action-btn.absent-btn:hover:not(:disabled){background:var(--teacher-error-light)}.quick-action-btn:disabled{opacity:.5;cursor:not-allowed}.table-wrapper-modern{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--teacher-border)}.attendance-table-modern{width:100%;border-collapse:collapse;background:var(--teacher-bg)}.attendance-table-modern thead{background:var(--teacher-primary);color:#fff}.attendance-table-modern th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px}.attendance-table-modern th.attendance-col{text-align:center}.attendance-table-modern td{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--teacher-border-light);color:var(--teacher-text-primary);font-size:var(--font-size-sm)}.attendance-table-modern tbody tr:hover{background:var(--teacher-bg-tertiary)}.attendance-table-modern tbody tr:last-child td{border-bottom:none}.text-center{text-align:center}.text-muted{color:var(--teacher-text-muted)}.cccd-code{background:var(--teacher-bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-family:Courier New,monospace;font-size:13px;font-weight:var(--font-weight-semibold);color:var(--teacher-text-primary)}.attendance-cell{text-align:center}.radio-label{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;position:relative}.radio-label input[type=radio]{position:absolute;opacity:0;width:0;height:0}.radio-custom{width:24px;height:24px;border:2px solid var(--teacher-border);border-radius:50%;display:inline-block;position:relative;transition:all var(--transition-base)}.radio-label.present-label input:checked+.radio-custom{border-color:var(--teacher-success);background:var(--teacher-success)}.radio-label.present-label input:checked+.radio-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#fff;border-radius:50%}.radio-label.absent-label input:checked+.radio-custom{border-color:var(--teacher-error);background:var(--teacher-error)}.radio-label.absent-label input:checked+.radio-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:#fff;border-radius:50%}.radio-label input:disabled+.radio-custom{opacity:.5;cursor:not-allowed}.form-actions-modern{display:flex;justify-content:flex-end;padding-top:var(--spacing-xl);border-top:2px solid var(--teacher-border-light)}.btn-submit-modern{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-2xl);background:var(--teacher-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-md);min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-submit-modern:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg);background:var(--teacher-primary-dark)}.btn-submit-modern:disabled{opacity:.6;cursor:not-allowed;transform:none}.history-section-modern{background:var(--teacher-bg);border-radius:var(--radius-lg);padding:var(--spacing-2xl);box-shadow:var(--shadow-md)}.history-header{margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--teacher-border-light)}.history-header h2{display:flex;align-items:center;gap:var(--spacing-md);margin:0;font-size:var(--font-size-2xl);color:var(--teacher-text-primary);font-weight:var(--font-weight-semibold)}.history-content{display:flex;flex-direction:column;gap:var(--spacing-2xl)}.history-block-modern{display:flex;flex-direction:column;gap:var(--spacing-lg)}.history-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--teacher-text-secondary);margin:0}.date-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-lg)}.date-card-modern{padding:var(--spacing-lg);background:var(--teacher-bg-tertiary);border:2px solid var(--teacher-border);border-radius:var(--radius-md);transition:all var(--transition-base)}.date-card-modern:hover{border-color:var(--teacher-primary);box-shadow:var(--shadow-sm)}.date-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.date-text{font-weight:var(--font-weight-semibold);color:var(--teacher-text-primary);font-size:var(--font-size-base)}.percent-badge{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.percent-badge.high{background:var(--teacher-success-light);color:#065f46}.percent-badge.medium{background:var(--teacher-warning-light);color:#92400e}.percent-badge.low{background:var(--teacher-error-light);color:#991b1b}.date-card-stats{display:flex;flex-direction:column;gap:var(--spacing-sm)}.stat-item{display:flex;justify-content:space-between;font-size:var(--font-size-sm)}.stat-label{color:var(--teacher-text-tertiary)}.stat-value{font-weight:var(--font-weight-semibold);color:var(--teacher-text-primary)}.present-stat .stat-value{color:var(--teacher-success)}.absent-stat .stat-value{color:var(--teacher-error)}.student-table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--teacher-border)}.student-table-modern{width:100%;border-collapse:collapse;background:var(--teacher-bg)}.student-table-modern thead{background:var(--teacher-bg-tertiary)}.student-table-modern th{padding:var(--spacing-md) var(--spacing-lg);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--teacher-text-primary);border-bottom:2px solid var(--teacher-border)}.student-table-modern td{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--teacher-border-light);color:var(--teacher-text-primary);font-size:var(--font-size-sm)}.student-table-modern tbody tr:hover{background:var(--teacher-bg-tertiary)}.percent-badge-table{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);display:inline-block}.percent-badge-table.high{background:var(--teacher-success-light);color:#065f46}.percent-badge-table.medium{background:var(--teacher-warning-light);color:#92400e}.percent-badge-table.low{background:var(--teacher-error-light);color:#991b1b}.loading-section{padding:var(--spacing-3xl);text-align:center}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}@media (max-width: 768px){.attendance-page-modern{padding:var(--spacing-lg)!important;background:var(--teacher-bg);padding-top:calc(var(--spacing-lg) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-lg) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-lg) + env(safe-area-inset-right,0px));margin:0;max-width:100%}.attendance-header-modern{flex-direction:column;gap:var(--spacing-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-radius:var(--radius-md)}.attendance-header-modern h1{font-size:var(--font-size-2xl)}.attendance-card-modern,.history-section-modern{padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);border-radius:var(--radius-md)}.attendance-form-modern{gap:var(--spacing-lg)}.selection-section{grid-template-columns:1fr;gap:var(--spacing-lg);padding-bottom:var(--spacing-lg)}.summary-cards-modern{grid-template-columns:1fr;gap:var(--spacing-md)}.summary-card{padding:var(--spacing-lg)}.summary-icon{width:40px;height:40px}.summary-value{font-size:var(--font-size-2xl)}.quick-actions{flex-direction:column;gap:var(--spacing-sm)}.table-wrapper-modern,.student-table-wrapper{margin:0 calc(-1 * var(--spacing-lg));padding:0 var(--spacing-lg);width:calc(100% + 2 * var(--spacing-lg))}.attendance-table-modern,.student-table-modern{font-size:var(--font-size-xs);min-width:600px}.attendance-table-modern th,.attendance-table-modern td,.student-table-modern th,.student-table-modern td{padding:var(--spacing-sm) var(--spacing-md);white-space:nowrap}.attendance-table-modern th:nth-child(4),.attendance-table-modern td:nth-child(4),.attendance-table-modern th:nth-child(5),.attendance-table-modern td:nth-child(5){display:none}.radio-custom{width:32px;height:32px}.btn-submit-modern{width:100%}.date-cards-grid{grid-template-columns:1fr}}@media (max-width: 480px){.attendance-page-modern{padding:var(--spacing-md)}.attendance-header-modern h1{font-size:var(--font-size-xl)}.attendance-card-modern,.history-section-modern{padding:var(--spacing-md)}}.teacher-messaging-page{padding:var(--spacing-xl);height:calc(var(--vh, 1vh) * 100 - 120px);display:flex;flex-direction:column;box-sizing:border-box;padding-top:calc(var(--spacing-xl) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-xl) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-xl) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-xl) + env(safe-area-inset-right,0px))}.messaging-header{margin-bottom:20px}.messaging-header h2{margin:0;color:#333;font-size:24px}.messaging-container{display:flex;gap:20px;flex:1;min-height:0;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden;background:#fff}.conversations-sidebar{width:350px;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;background:#f9f9f9;overflow-y:auto}.conversations-list{flex:1;overflow-y:auto}.conversation-item{display:flex;align-items:center;padding:15px;cursor:pointer;border-bottom:1px solid #e0e0e0;transition:background-color .2s;gap:12px}.conversation-item:hover{background-color:#f0f0f0}.conversation-item.active{background-color:var(--teacher-primary-lightest);border-left:3px solid var(--teacher-primary)}.conversation-avatar{flex-shrink:0}.avatar-circle{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--teacher-primary) 0%,var(--teacher-primary-dark) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px}.conversation-info{flex:1;min-width:0}.conversation-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}.conversation-name{font-weight:600;color:#333;font-size:15px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.unread-badge{background-color:#f44336;color:#fff;border-radius:12px;padding:2px 8px;font-size:12px;font-weight:600;min-width:20px;text-align:center}.conversation-preview{display:flex;justify-content:space-between;align-items:center;gap:10px}.last-message{color:#666;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.last-time{color:#999;font-size:12px;flex-shrink:0}.chat-window{flex:1;display:flex;flex-direction:column;min-width:0;background:#fff}.chat-header{padding:15px 20px;border-bottom:1px solid #e0e0e0;background:#f9f9f9}.chat-header-info{display:flex;align-items:center;gap:12px}.chat-avatar .avatar-circle{width:40px;height:40px;font-size:16px}.chat-title h3{margin:0;font-size:16px;color:#333}.chat-subject{margin:2px 0 0;font-size:13px;color:#666}.messages-area{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:15px;background:#f5f5f5}.message{display:flex;margin-bottom:10px}.message.sent{justify-content:flex-end}.message.received{justify-content:flex-start}.message-content{max-width:70%;padding:10px 15px;border-radius:18px;position:relative}.message.sent .message-content{background:linear-gradient(135deg,var(--teacher-primary) 0%,var(--teacher-primary-dark) 100%);color:#fff;border-bottom-right-radius:4px}.message.received .message-content{background:#fff;color:#333;border:1px solid #e0e0e0;border-bottom-left-radius:4px}.message-text{word-wrap:break-word;line-height:1.4;margin-bottom:5px}.message-time{font-size:11px;opacity:.7;text-align:right}.message.received .message-time{color:#999;text-align:left}.message-input-form{display:flex;gap:10px;padding:15px 20px;border-top:1px solid #e0e0e0;background:#fff}.message-input{flex:1;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--teacher-border);border-radius:20px;font-size:var(--font-size-base);outline:none;transition:border-color var(--transition-base);min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.message-input:focus{border-color:var(--teacher-primary)}.message-input:disabled{background-color:#f5f5f5;cursor:not-allowed}.send-button{padding:var(--spacing-md) var(--spacing-xl);background:var(--teacher-primary);color:#fff;border:none;border-radius:20px;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-base);min-height:44px;min-width:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.send-button:hover:not(:disabled){opacity:.9}.send-button:disabled{opacity:.5;cursor:not-allowed}.teacher-messaging-page .empty-state{padding:40px 20px}@media (max-width: 768px){.teacher-messaging-page{padding:var(--spacing-lg)!important;padding-top:calc(var(--spacing-lg) + env(safe-area-inset-top,0px));padding-bottom:calc(var(--spacing-lg) + env(safe-area-inset-bottom,0px));padding-left:calc(var(--spacing-lg) + env(safe-area-inset-left,0px));padding-right:calc(var(--spacing-lg) + env(safe-area-inset-right,0px));margin:0;max-width:100%}.messaging-container{flex-direction:column}.conversations-sidebar{width:100%;max-height:300px;border-right:none;border-bottom:1px solid var(--teacher-border);overflow-y:auto;-webkit-overflow-scrolling:touch}.message-content{max-width:85%;font-size:var(--font-size-base)!important}.message-input,.send-button{font-size:var(--font-size-base)!important;min-height:44px!important;min-width:44px!important}button,input,.conversation-item{min-height:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}}.teacher-docs{width:100%}.teacher-docs-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px;flex-wrap:wrap}.header-left h1{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:700;color:#1e293b;margin:0 0 4px}.header-left p{color:#64748b;font-size:14px;margin:0}.header-right{display:flex;align-items:center;gap:12px}.search-box{display:flex;align-items:center;gap:8px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:10px 16px;min-width:240px}.search-box:focus-within{border-color:#6366f1}.search-box svg{color:#94a3b8}.search-box input{border:none;outline:none;background:transparent;font-size:14px;width:100%}.btn-icon{width:42px;height:42px;border-radius:10px;border:2px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;transition:all .2s}.btn-icon:hover{border-color:#6366f1;color:#6366f1}.btn-primary{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;border:none;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{padding:10px 20px;border-radius:12px;border:2px solid #e2e8f0;background:#fff;color:#64748b;font-size:14px;font-weight:600;cursor:pointer}.btn-ghost:hover{background:#f8fafc}.teacher-docs-tabs{display:flex;gap:8px;margin-bottom:20px}.tab{display:flex;align-items:center;gap:8px;padding:12px 20px;border-radius:12px;background:#fff;border:2px solid #e2e8f0;font-size:14px;font-weight:600;color:#64748b;cursor:pointer;transition:all .2s}.tab:hover{border-color:#cbd5e1}.tab.active{background:#6366f1;border-color:#6366f1;color:#fff}.class-filter{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;background:#fff;border-radius:12px;flex-wrap:wrap}.class-filter span{font-size:13px;color:#64748b;font-weight:500}.filter-btn{padding:6px 14px;border-radius:8px;border:none;background:#f1f5f9;color:#64748b;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.filter-btn:hover{background:#e2e8f0}.filter-btn.active{background:#6366f1;color:#fff}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;color:#64748b}.spinner{width:36px;height:36px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;background:#fff;border-radius:16px;text-align:center}.empty-state svg{color:#cbd5e1;margin-bottom:16px}.empty-state h3{font-size:18px;font-weight:600;color:#1e293b;margin:0 0 8px}.empty-state p{color:#64748b;margin:0 0 20px;max-width:300px}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.doc-card{background:#fff;border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:12px;cursor:pointer;transition:all .2s;position:relative;border:1px solid #f1f5f9}.doc-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.doc-card-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.doc-card-info h4{font-size:15px;font-weight:600;color:#1e293b;margin:0 0 4px;line-height:1.3}.doc-filename{font-size:12px;color:#94a3b8;margin:0}.doc-desc{font-size:13px;color:#64748b;margin:4px 0 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.doc-card-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#94a3b8;padding-top:12px;border-top:1px solid #f1f5f9}.doc-date{display:flex;align-items:center;gap:4px}.doc-card-badge{position:absolute;top:12px;right:12px}.badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600}.badge.public{background:#dcfce7;color:#16a34a}.badge.class{background:#dbeafe;color:#2563eb}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#fff;border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.modal-header h2{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;margin:0}.close-btn{background:#fff3;border:none;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff}.close-btn:hover{background:#ffffff4d}.modal-body{padding:24px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;margin-top:16px;border-top:1px solid #e2e8f0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#1e293b}.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:14px;color:#1e293b;outline:none;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:#6366f1}.form-group textarea{resize:vertical;min-height:60px}.file-drop{border:2px dashed #cbd5e1;border-radius:16px;padding:32px 20px;text-align:center;cursor:pointer;transition:all .2s;background:#fafafa}.file-drop:hover{border-color:#6366f1;background:#f5f3ff}.file-drop.has-file{border-style:solid;border-color:#22c55e;background:#f0fdf4;padding:16px 20px}.file-drop svg{color:#94a3b8;margin-bottom:8px}.file-drop p{font-size:14px;font-weight:600;color:#1e293b;margin:0 0 4px}.file-drop span{font-size:12px;color:#94a3b8}.file-preview{display:flex;align-items:center;gap:12px;text-align:left}.file-preview .file-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:11px;font-weight:700;flex-shrink:0}.file-preview .file-name{display:block;font-weight:600;color:#1e293b;font-size:14px}.file-preview .file-size{display:block;font-size:12px;color:#64748b}@media (max-width: 768px){.teacher-docs{margin:0;max-width:100%}.teacher-docs-header{flex-direction:column;gap:var(--spacing-md)}.header-left h1{font-size:var(--font-size-2xl)!important}.header-right{width:100%;flex-wrap:wrap}.search-box{flex:1;min-width:180px;font-size:var(--font-size-base)!important;min-height:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}.docs-grid{grid-template-columns:1fr;gap:var(--spacing-md)}button,input,select{font-size:var(--font-size-base)!important;min-height:44px!important;min-width:44px!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important}.docs-grid,.table-container{overflow-x:auto!important;-webkit-overflow-scrolling:touch!important;scrollbar-width:thin}}*,*:before,*:after{box-sizing:border-box}:root{--vh: 1vh;--teacher-primary: #10b981;--teacher-primary-dark: #059669;--teacher-primary-light: #34d399;--teacher-primary-lighter: #d1fae5;--teacher-primary-lightest: #ecfdf5;--teacher-accent: #3b82f6;--teacher-accent-gradient: linear-gradient(135deg, #10b981 0%, #3b82f6 100%);--teacher-bg: #ffffff;--teacher-bg-secondary: #f8fafc;--teacher-bg-tertiary: #f1f5f9;--teacher-border: #e2e8f0;--teacher-border-light: #f1f5f9;--teacher-text-primary: #0f172a;--teacher-text-secondary: #475569;--teacher-text-tertiary: #94a3b8;--teacher-text-muted: #cbd5e1;--teacher-text-inverse: #ffffff;--teacher-success: #10b981;--teacher-success-bg: #ecfdf5;--teacher-success-text: #065f46;--teacher-error: #ef4444;--teacher-error-bg: #fef2f2;--teacher-error-text: #991b1b;--teacher-warning: #f59e0b;--teacher-warning-bg: #fffbeb;--teacher-warning-text: #92400e;--teacher-info: #3b82f6;--teacher-info-bg: #eff6ff;--teacher-info-text: #1e40af;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--spacing-3xl: 48px;--font-family: "Inter", system-ui, -apple-system, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-colored: 0 10px 15px -3px rgba(16, 185, 129, .2);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}body{font-family:var(--font-family);color:var(--teacher-text-primary);background-color:#f8fafc;background-image:radial-gradient(at 0% 0%,hsla(142,40%,96%,1) 0,transparent 50%),radial-gradient(at 50% 0%,hsla(210,40%,96%,1) 0,transparent 50%),radial-gradient(at 100% 0%,hsla(142,40%,96%,1) 0,transparent 50%);background-attachment:fixed}.teacher-page-base{padding:var(--spacing-2xl);max-width:1400px;margin:0 auto;width:100%}.teacher-page-header{margin-bottom:var(--spacing-2xl);position:relative}.teacher-page-header h1{margin:0 0 var(--spacing-sm) 0;font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--teacher-text-primary);line-height:var(--line-height-tight);background:linear-gradient(135deg,var(--teacher-text-primary) 0%,var(--teacher-text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;display:inline-block}.teacher-page-header p{margin:0;font-size:var(--font-size-base);color:var(--teacher-text-secondary);line-height:var(--line-height-normal);max-width:600px}.btn-teacher{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:.75rem 1.5rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);line-height:1;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none}.btn-teacher-primary{background:var(--teacher-primary);background:linear-gradient(135deg,var(--teacher-primary) 0%,var(--teacher-primary-dark) 100%);color:var(--teacher-text-inverse);box-shadow:0 4px 6px -1px #10b98133,0 2px 4px -1px #10b9811a}.btn-teacher-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 15px -3px #10b9814d,0 4px 6px -2px #10b98126;filter:brightness(1.05)}.btn-teacher-primary:active:not(:disabled){transform:translateY(0)}.btn-teacher-secondary{background:var(--teacher-bg);color:var(--teacher-text-primary);border:1px solid var(--teacher-border);box-shadow:var(--shadow-sm)}.btn-teacher-secondary:hover:not(:disabled){background:var(--teacher-bg-secondary);border-color:var(--teacher-text-tertiary);color:var(--teacher-primary-dark);transform:translateY(-1px)}.btn-teacher:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(1)}.card-teacher{background:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-lg);transition:transform var(--transition-slow),box-shadow var(--transition-slow)}.card-teacher:hover{box-shadow:var(--shadow-xl)}.card-teacher-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--teacher-border);display:flex;justify-content:space-between;align-items:center}.card-teacher-header h2{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--teacher-text-primary)}.table-teacher{width:100%;border-collapse:separate;border-spacing:0;background:transparent}.table-teacher thead tr{background:transparent}.table-teacher th{padding:var(--spacing-lg) var(--spacing-xl);text-align:left;font-weight:var(--font-weight-semibold);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:1px;color:var(--teacher-text-secondary);background:var(--teacher-bg-secondary);border-bottom:1px solid var(--teacher-border)}.table-teacher th:first-child{border-top-left-radius:var(--radius-md)}.table-teacher th:last-child{border-top-right-radius:var(--radius-md)}.table-teacher td{padding:var(--spacing-lg) var(--spacing-xl);font-size:var(--font-size-sm);color:var(--teacher-text-primary);border-bottom:1px solid var(--teacher-border-light);background:var(--teacher-bg);transition:background var(--transition-fast)}.table-teacher tbody tr:hover td{background:var(--teacher-bg-secondary)}.table-teacher tbody tr:last-child td{border-bottom:none}.table-teacher tbody tr:last-child td:first-child{border-bottom-left-radius:var(--radius-md)}.table-teacher tbody tr:last-child td:last-child{border-bottom-right-radius:var(--radius-md)}.badge-teacher{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);line-height:1;text-transform:uppercase;letter-spacing:.5px}.badge-teacher-primary{background:var(--teacher-primary-lightest);color:var(--teacher-primary-dark);border:1px solid var(--teacher-primary-lighter)}.badge-teacher-success{background:var(--teacher-success-bg);color:var(--teacher-success-text);border:1px solid #bbf7d0}.badge-teacher-error{background:var(--teacher-error-bg);color:var(--teacher-error-text);border:1px solid #fecaca}.badge-teacher-warning{background:var(--teacher-warning-bg);color:var(--teacher-warning-text);border:1px solid #fde68a}.badge-teacher-info{background:var(--teacher-info-bg);color:var(--teacher-info-text);border:1px solid #bfdbfe}.badge-teacher-secondary{background:var(--teacher-bg-tertiary);color:var(--teacher-text-secondary);border:1px solid var(--teacher-border)}.form-group-teacher{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.form-group-teacher label{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--teacher-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-left:2px}.form-group-teacher input,.form-group-teacher select,.form-group-teacher textarea{padding:.75rem 1rem;font-size:var(--font-size-sm);background:var(--teacher-bg);border:1px solid var(--teacher-border);border-radius:var(--radius-md);transition:all var(--transition-base);width:100%;color:var(--teacher-text-primary);box-shadow:var(--shadow-sm)}.form-group-teacher input:focus,.form-group-teacher select:focus,.form-group-teacher textarea:focus{outline:none;border-color:var(--teacher-primary);box-shadow:0 0 0 4px var(--teacher-primary-lighter);background:#fff}@media (max-width: 768px){.teacher-page-base{padding:var(--spacing-lg)}.teacher-page-header h1{font-size:var(--font-size-2xl)}.card-teacher{padding:var(--spacing-lg)}.table-teacher th,.table-teacher td{padding:var(--spacing-md)}}.teacher-dashboard-container{display:flex;min-height:100vh;min-height:calc(var(--vh, 1vh) * 100);width:100%;position:relative;overflow-x:hidden;background-color:var(--teacher-bg-secondary)}.teacher-sidebar{width:260px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;height:calc(var(--vh, 1vh) * 100);overflow-y:auto;border-right:1px solid var(--teacher-border);background:#ffffffe6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:10;box-shadow:var(--shadow-lg);transition:width .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}.teacher-sidebar.collapsed{width:80px}.teacher-sidebar-header{padding:24px;background:#fff;border-bottom:1px solid var(--teacher-border);position:relative;display:flex;flex-direction:column;align-items:center;min-height:120px;justify-content:center}.teacher-sidebar.collapsed .teacher-sidebar-header{padding:16px 8px;min-height:80px}.teacher-sidebar-collapse-btn{position:absolute;top:12px;right:12px;width:24px;height:24px;border-radius:50%;background:var(--teacher-bg-secondary);border:1px solid var(--teacher-border);color:var(--teacher-text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:20;font-size:16px;line-height:1;padding:0;transition:all .2s}.teacher-sidebar-collapse-btn:hover{background:var(--teacher-primary-lightest);color:var(--teacher-primary);border-color:var(--teacher-primary-light)}.teacher-sidebar.collapsed .teacher-sidebar-collapse-btn{right:50%;transform:translate(50%);top:8px}.teacher-sidebar-header h2{margin:0 0 8px;font-size:14px;font-weight:800;letter-spacing:1px;color:var(--teacher-text-secondary);text-transform:uppercase;text-align:center;width:100%}.teacher-sidebar-header p{margin:0;font-size:16px;font-weight:700;color:var(--teacher-text-primary);line-height:1.4;text-align:center;width:100%}.teacher-code{margin-top:8px;font-size:12px;font-weight:600;padding:4px 10px;background-color:var(--teacher-primary-lightest);color:var(--teacher-primary-dark);border-radius:99px;border:1px solid var(--teacher-primary-lighter);display:inline-block}.teacher-code-collapsed{font-size:10px;font-weight:700;padding:2px 6px;background-color:var(--teacher-primary-lightest);color:var(--teacher-primary-dark);border-radius:4px;margin-top:24px}.teacher-sidebar-nav{padding:16px 12px;flex:1;display:flex;flex-direction:column;gap:4px}.teacher-sidebar.collapsed .teacher-sidebar-nav{padding:16px 8px;align-items:center}.teacher-sidebar-nav button{width:100%;padding:12px 16px;margin-bottom:4px;border:none;background:transparent;text-align:left;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500;color:var(--teacher-text-secondary);border-radius:8px;cursor:pointer;transition:all .2s ease;overflow:hidden;white-space:nowrap}.teacher-sidebar.collapsed .teacher-sidebar-nav button{padding:12px;justify-content:center;width:48px;height:48px;border-radius:12px}.teacher-sidebar-nav button:hover{background-color:var(--teacher-bg-secondary);color:var(--teacher-text-primary);transform:translate(4px)}.teacher-sidebar.collapsed .teacher-sidebar-nav button:hover{transform:none;background-color:var(--teacher-primary-lightest);color:var(--teacher-primary)}.teacher-sidebar-nav button.active{background:var(--teacher-primary-lightest);color:var(--teacher-primary-dark);font-weight:600;box-shadow:0 1px 2px #0000000d}.menu-icon{font-size:18px;width:24px;text-align:center;opacity:.8;display:flex;justify-content:center;align-items:center}.teacher-sidebar.collapsed .menu-icon{font-size:22px;opacity:1;width:auto}.teacher-sidebar-footer{padding:16px;border-top:1px solid var(--teacher-border);background:#fff;display:flex;justify-content:center}.teacher-sidebar.collapsed .teacher-sidebar-footer{padding:16px 8px}.btn-logout{width:100%;padding:12px;border:1px solid var(--teacher-error-bg);background:var(--teacher-error-bg);color:var(--teacher-error-text);border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap}.teacher-sidebar.collapsed .btn-logout{padding:12px;width:48px;height:48px}.teacher-main-content{flex:1;height:100vh;height:calc(var(--vh, 1vh) * 100);overflow-y:auto;overflow-x:hidden}.teacher-content-wrapper{padding:32px;max-width:1600px;margin:0 auto}.mobile-menu-btn{display:none}@media (max-width: 768px){.teacher-dashboard-container{flex-direction:column}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;position:fixed;top:12px;left:12px;z-index:1000;width:44px;height:44px;border-radius:12px;background:#fff;box-shadow:0 4px 6px -1px #0000001a;border:1px solid var(--teacher-border);font-size:20px;color:var(--teacher-text-primary);cursor:pointer}.mobile-menu-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:998}.mobile-menu-overlay.active{display:block}.teacher-sidebar{position:fixed;left:-100%;top:0;bottom:0;width:280px;transition:left .3s cubic-bezier(.4,0,.2,1);z-index:999}.teacher-sidebar.collapsed{width:280px}.teacher-sidebar.mobile-open{left:0}.teacher-sidebar-collapse-btn{display:none}.teacher-main-content{width:100%}.teacher-content-wrapper{padding:70px 16px 16px}}.admin-mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;align-items:center;padding:8px 0;z-index:100;box-shadow:0 -2px 8px #0000001a}.admin-mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:none;border:none;color:#6b7280;font-size:12px;cursor:pointer;transition:all .2s}.admin-mobile-nav-item.active{color:#059669}.admin-mobile-nav-icon{font-size:20px}.admin-mobile-nav-label{font-size:10px;font-weight:500}:root{--mobile-spacing-xs: 4px;--mobile-spacing-sm: 8px;--mobile-spacing-md: 16px;--mobile-spacing-lg: 24px;--mobile-spacing-xl: 32px;--mobile-touch-target: 44px;--mobile-touch-target-large: 48px;--mobile-font-base: 16px;--mobile-font-sm: 14px;--mobile-font-lg: 18px;--mobile-font-xl: 20px;--mobile-font-2xl: 24px;--mobile-line-height-tight: 1.2;--mobile-line-height-normal: 1.5;--mobile-line-height-relaxed: 1.6;--mobile-bg: #f8fafc;--mobile-card-bg: #ffffff;--mobile-border: #e2e8f0;--mobile-text: #0f172a;--mobile-text-muted: #64748b;--mobile-text-light: #94a3b8}======================================== */ :root{--mobile-spacing-xs: 4px;--mobile-spacing-sm: 8px;--mobile-spacing-md: 16px;--mobile-spacing-lg: 24px;--mobile-spacing-xl: 32px;--mobile-touch-target: 44px;--mobile-touch-target-large: 48px;--mobile-font-base: 16px;--mobile-font-sm: 14px;--mobile-font-lg: 18px;--mobile-font-xl: 20px;--mobile-font-2xl: 24px;--mobile-line-height-tight: 1.2;--mobile-line-height-normal: 1.5;--mobile-line-height-relaxed: 1.6;--mobile-bg: #f8fafc;--mobile-card-bg: #ffffff;--mobile-border: #e2e8f0;--mobile-text: #0f172a;--mobile-text-muted: #64748b;--mobile-text-light: #94a3b8}.admin-mobile-page{padding:16px 16px 80px;background:var(--mobile-bg);min-height:calc(100vh - 64px);overflow-x:hidden;max-width:100%;box-sizing:border-box}@media (max-width: 480px){.admin-mobile-page{padding:12px 12px 76px}}@media (max-width: 360px){.admin-mobile-page{padding:10px 10px 74px}}.admin-mobile-page h1{font-size:var(--mobile-font-2xl);font-weight:700;color:var(--mobile-text);line-height:var(--mobile-line-height-tight);margin:0 0 8px}.admin-mobile-page h2{font-size:var(--mobile-font-xl);font-weight:700;color:var(--mobile-text);line-height:var(--mobile-line-height-tight);margin:0 0 12px}.admin-mobile-page h3{font-size:var(--mobile-font-lg);font-weight:600;color:var(--mobile-text);line-height:var(--mobile-line-height-normal);margin:0 0 8px}.admin-mobile-page p{font-size:var(--mobile-font-base);color:var(--mobile-text);line-height:var(--mobile-line-height-relaxed);margin:0 0 12px}.admin-mobile-page small{font-size:var(--mobile-font-sm);color:var(--mobile-text-muted);line-height:var(--mobile-line-height-normal)}.admin-mobile-card{background:var(--mobile-card-bg);border-radius:12px;padding:var(--mobile-spacing-md);margin-bottom:var(--mobile-spacing-md);box-shadow:0 1px 3px #0000001a;border:1px solid var(--mobile-border)}.admin-mobile-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--mobile-spacing-md);padding-bottom:var(--mobile-spacing-md);border-bottom:1px solid var(--mobile-border)}.admin-mobile-card-title{font-size:var(--mobile-font-lg);font-weight:600;color:var(--mobile-text);margin:0}.admin-mobile-card-content{font-size:var(--mobile-font-base);color:var(--mobile-text);line-height:var(--mobile-line-height-relaxed)}.admin-mobile-btn{min-height:var(--mobile-touch-target);padding:12px 20px;font-size:var(--mobile-font-base);font-weight:600;border-radius:12px;border:none;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:8px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.admin-mobile-btn:active{transform:scale(.98)}.admin-mobile-btn-primary{background:#16a34a;color:#fff}.admin-mobile-btn-primary:active{background:#15803d}.admin-mobile-btn-secondary{background:#f1f5f9;color:var(--mobile-text)}.admin-mobile-btn-secondary:active{background:#e2e8f0}.admin-mobile-btn-outline{background:transparent;color:#16a34a;border:1px solid #16a34a}.admin-mobile-btn-outline:active{background:#f0fdf4}.admin-mobile-btn-danger{background:#dc2626;color:#fff}.admin-mobile-btn-danger:active{background:#b91c1c}.admin-mobile-btn-ghost{background:transparent;color:var(--mobile-text-muted)}.admin-mobile-btn-ghost:active{background:#f1f5f9}.admin-mobile-btn-full{width:100%}.admin-mobile-btn-icon{width:var(--mobile-touch-target);height:var(--mobile-touch-target);padding:0;min-width:var(--mobile-touch-target)}@media (max-width: 480px){.admin-mobile-btn{padding:10px 16px;font-size:13px;min-height:40px;gap:6px;border-radius:10px}.admin-mobile-btn-icon{width:40px;height:40px;min-width:40px}}@media (max-width: 360px){.admin-mobile-btn{padding:8px 12px;font-size:12px;min-height:38px;gap:4px;border-radius:8px}.admin-mobile-btn-icon{width:38px;height:38px;min-width:38px}}.admin-mobile-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--mobile-spacing-md);margin-bottom:var(--mobile-spacing-lg)}.admin-mobile-stat-card{background:var(--mobile-card-bg);border-radius:12px;padding:var(--mobile-spacing-md);box-shadow:0 1px 3px #0000001a;border:1px solid var(--mobile-border)}.admin-mobile-stat-value{font-size:var(--mobile-font-2xl);font-weight:800;color:var(--mobile-text);margin:8px 0 4px}.admin-mobile-stat-label{font-size:var(--mobile-font-sm);color:var(--mobile-text-muted);font-weight:500}.admin-mobile-list{display:flex;flex-direction:column;gap:0}.admin-mobile-list-item{min-height:56px;padding:var(--mobile-spacing-md);background:var(--mobile-card-bg);border-bottom:1px solid var(--mobile-border);display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:all .2s ease;touch-action:manipulation}.admin-mobile-list-item:active{background:#f1f5f9}.admin-mobile-list-item:last-child{border-bottom:none}.admin-mobile-empty{text-align:center;padding:var(--mobile-spacing-xl) var(--mobile-spacing-md);color:var(--mobile-text-muted)}.admin-mobile-empty-icon{width:64px;height:64px;margin:0 auto var(--mobile-spacing-md);opacity:.5}.admin-mobile-empty-text{font-size:var(--mobile-font-base);color:var(--mobile-text-muted)}.admin-mobile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--mobile-spacing-xl);color:var(--mobile-text-muted)}.admin-mobile-spinner{width:32px;height:32px;border:3px solid var(--mobile-border);border-top-color:#16a34a;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--mobile-spacing-md)}@supports (padding: max(0px)){.admin-mobile-safe-top{padding-top:max(16px,env(safe-area-inset-top))}.admin-mobile-safe-bottom{padding-bottom:max(16px,env(safe-area-inset-bottom))}.admin-mobile-safe-left{padding-left:max(16px,env(safe-area-inset-left))}.admin-mobile-safe-right{padding-right:max(16px,env(safe-area-inset-right))}}.admin-mobile-section{margin-bottom:var(--mobile-spacing-lg)}.admin-mobile-divider{height:1px;background:var(--mobile-border);margin:var(--mobile-spacing-md) 0}.admin-mobile-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:12px;font-size:var(--mobile-font-sm);font-weight:600;line-height:1.2}.admin-mobile-badge-success{background:#f0fdf4;color:#16a34a}.admin-mobile-badge-warning{background:#fffbeb;color:#f59e0b}.admin-mobile-badge-danger{background:#fef2f2;color:#dc2626}.admin-mobile-badge-info{background:#eff6ff;color:#3b82f6}@media (max-width: 480px){.admin-mobile-stats-grid{grid-template-columns:1fr}.admin-mobile-page{padding:12px}}.admin-mobile-layout.ios,.admin-mobile-page.ios{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.admin-mobile-layout.ios,.admin-mobile-page.ios{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Helvetica Neue,Arial,sans-serif}.admin-mobile-layout.ios .admin-mobile-content,.admin-mobile-page.ios{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.admin-mobile-layout.ios .admin-mobile-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation}.admin-mobile-layout.ios .admin-mobile-btn:active{opacity:.7;transform:scale(.97)}.admin-mobile-layout.ios .admin-mobile-card,.admin-mobile-page.ios .admin-mobile-card{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.admin-mobile-layout.ios .mobile-modal{border-radius:20px 20px 0 0;animation:slideUpIOS .3s cubic-bezier(.36,.66,.04,1)}@keyframes slideUpIOS{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.admin-mobile-layout.ios input,.admin-mobile-layout.ios textarea,.admin-mobile-layout.ios select{-webkit-appearance:none;-moz-appearance:none;appearance:none;font-size:16px}.admin-mobile-layout.ios .admin-mobile-list-item:active{background:#0000000d}.admin-mobile-layout.ios .pull-to-refresh{position:relative}.admin-mobile-layout.ios .admin-mobile-header{padding-top:max(12px,env(safe-area-inset-top))}.admin-mobile-layout.ios .mobile-bottom-nav{padding-bottom:max(8px,env(safe-area-inset-bottom))}.admin-mobile-layout.ios .mobile-form{padding-bottom:env(safe-area-inset-bottom)}.admin-mobile-layout.ios *{transition-timing-function:cubic-bezier(.36,.66,.04,1)}.admin-mobile-layout.android,.admin-mobile-page.android{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif}.admin-mobile-layout.android .admin-mobile-card,.admin-mobile-page.android .admin-mobile-card{box-shadow:0 2px 4px #0000001a;border:none}.admin-mobile-layout.android .admin-mobile-card:active{box-shadow:0 4px 8px #00000026}.admin-mobile-layout.android .admin-mobile-btn{text-transform:uppercase;letter-spacing:.5px;font-weight:500;box-shadow:0 2px 4px #0000001a}.admin-mobile-layout.android .admin-mobile-btn-primary{box-shadow:0 2px 4px #16a34a4d}.admin-mobile-layout.android .admin-mobile-btn:active{box-shadow:0 1px 2px #0000001a;transform:translateY(1px)}.admin-mobile-layout.android .admin-mobile-btn,.admin-mobile-layout.android .admin-mobile-list-item{position:relative;overflow:hidden}.admin-mobile-layout.android .admin-mobile-btn:after,.admin-mobile-layout.android .admin-mobile-list-item:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#0000001a;transform:translate(-50%,-50%);transition:width .3s,height .3s}.admin-mobile-layout.android .admin-mobile-btn:active:after,.admin-mobile-layout.android .admin-mobile-list-item:active:after{width:200px;height:200px}.admin-mobile-layout.android input,.admin-mobile-layout.android textarea,.admin-mobile-layout.android select{border-bottom:2px solid #e2e8f0;border-radius:0;padding:12px 0;background:transparent}.admin-mobile-layout.android input:focus,.admin-mobile-layout.android textarea:focus,.admin-mobile-layout.android select:focus{border-bottom-color:#16a34a;box-shadow:none}.admin-mobile-layout.android .mobile-modal{border-radius:16px 16px 0 0;box-shadow:0 -8px 24px #0003}.admin-mobile-layout.android .admin-mobile-list-item{padding-left:16px;padding-right:16px}.admin-mobile-layout.android .admin-mobile-list-item:active{background:#00000014}.admin-mobile-layout.android .mobile-fab{position:fixed;bottom:80px;right:16px;width:56px;height:56px;border-radius:50%;background:#16a34a;color:#fff;border:none;box-shadow:0 4px 8px #0003;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:50;transition:all .2s ease}.admin-mobile-layout.android .mobile-fab:active{box-shadow:0 2px 4px #0003;transform:scale(.95)}.admin-mobile-layout.android .admin-mobile-header{box-shadow:0 2px 4px #0000001a}.admin-mobile-layout.android *{transition-timing-function:cubic-bezier(.4,0,.2,1)}@supports (padding: max(0px)){.admin-mobile-layout.android{padding-top:max(0px,env(safe-area-inset-top));padding-bottom:max(0px,env(safe-area-inset-bottom))}}.admin-mobile-layout.android .mobile-form{padding-bottom:env(safe-area-inset-bottom,0px)}.admin-mobile-layout{min-height:100vh;display:flex;flex-direction:column;background:#f8fafc;position:relative}.admin-mobile-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.admin-mobile-header.ios{background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.admin-mobile-header-content{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;height:56px}.admin-mobile-menu-btn,.admin-mobile-action-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#0f172a;cursor:pointer;border-radius:12px;transition:all .2s ease}.admin-mobile-menu-btn:active,.admin-mobile-action-btn:active{background:#f1f5f9;transform:scale(.95)}.admin-mobile-header-actions{display:flex;gap:8px}.admin-mobile-title{flex:1;font-size:18px;font-weight:700;color:#0f172a;text-align:center;margin:0;padding:0 16px}.admin-mobile-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 16px 92px}.admin-mobile-layout.ios .admin-mobile-content{padding-bottom:calc(92px + env(safe-area-inset-bottom))}@media (max-width: 768px){.admin-mobile-header-content{padding:14px 18px;height:68px}.admin-mobile-menu-btn,.admin-mobile-action-btn{width:52px;height:52px;border-radius:14px}.admin-mobile-title{font-size:22px;padding:0 12px}.admin-mobile-content{padding:18px}}@media (max-width: 480px){.admin-mobile-content{padding:14px 14px 90px}}.admin-mobile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:60;animation:fadeIn .2s cubic-bezier(.4,0,.2,1);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.admin-mobile-drawer{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;background:#fff;z-index:70;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a;will-change:transform}.admin-mobile-drawer.open{transform:translate(0)}.admin-mobile-drawer-header{padding:16px;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;justify-content:space-between}.admin-mobile-drawer-user{display:flex;align-items:center;gap:12px;flex:1}.admin-mobile-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#22c55e);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:20px}.admin-mobile-user-name{font-size:16px;font-weight:600;color:#0f172a;margin:0}.admin-mobile-user-role{font-size:12px;color:#64748b;margin:2px 0 0;text-transform:uppercase;letter-spacing:.5px}.admin-mobile-close-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:#64748b;cursor:pointer;border-radius:12px;transition:all .2s ease}.admin-mobile-close-btn:active{background:#f1f5f9}.admin-mobile-drawer-nav{flex:1;overflow-y:auto;padding:8px 0}.admin-mobile-drawer-item{width:100%;padding:16px 20px;border:none;background:transparent;text-align:left;font-size:16px;color:#0f172a;cursor:pointer;transition:all .2s ease;min-height:44px;display:flex;align-items:center}.admin-mobile-drawer-item:active{background:#f1f5f9}.admin-mobile-drawer-item.active{background:#f0fdf4;color:#16a34a;font-weight:600;border-left:3px solid #16a34a}.admin-mobile-drawer-footer{padding:16px;border-top:1px solid #e2e8f0}.admin-mobile-logout-btn{width:100%;padding:14px;border:none;background:#fef2f2;color:#dc2626;font-size:16px;font-weight:600;border-radius:12px;cursor:pointer;transition:all .2s ease;min-height:44px}.admin-mobile-logout-btn:active{background:#fee2e2;transform:scale(.98)}.admin-mobile-layout.ios .admin-mobile-content{-webkit-overflow-scrolling:touch}.admin-mobile-layout.android .admin-mobile-drawer{box-shadow:0 0 20px #00000026}.admin-mobile-layout.android .admin-mobile-drawer-item:active{background:#e2e8f0}html,body{overflow-x:hidden;max-width:100%}:root{--admin-primary: #16a34a;--admin-primary-light: #22c55e;--admin-primary-dark: #15803d;--admin-accent: #6366f1;--admin-accent-light: #818cf8;--admin-success: #10b981;--admin-success-light: #34d399;--admin-warning: #f59e0b;--admin-warning-light: #fbbf24;--admin-danger: #ef4444;--admin-danger-light: #f87171;--admin-info: #3b82f6;--admin-info-light: #60a5fa;--admin-purple: #8b5cf6;--admin-cyan: #06b6d4;--admin-pink: #ec4899;--admin-bg: #f8fafc;--admin-card: #ffffff;--admin-border: #e2e8f0;--admin-text: #0f172a;--admin-text-muted: #64748b;--admin-text-light: #94a3b8;--gradient-primary: linear-gradient(135deg, #16a34a 0%, #22c55e 50%, #4ade80 100%);--gradient-accent: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #06b6d4 100%);--gradient-warning: linear-gradient(135deg, #f59e0b 0%, #f97316 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #ec4899 100%);--gradient-info: linear-gradient(135deg, #3b82f6 0%, #6366f1 100%);--gradient-dark: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);--gradient-mesh: linear-gradient(135deg, rgba(22, 163, 74, .03) 0%, rgba(99, 102, 241, .03) 50%, rgba(236, 72, 153, .03) 100%);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08), 0 2px 4px -1px rgba(0, 0, 0, .04);--shadow-lg: 0 10px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .06);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-glow: 0 0 60px rgba(22, 163, 74, .15);--shadow-card: 0 4px 20px rgba(0, 0, 0, .06);--shadow-card-hover: 0 20px 40px rgba(0, 0, 0, .12);--shadow-green: 0 10px 30px rgba(22, 163, 74, .25);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-2xl: 32px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes blob{0%{transform:translate(0) scale(1)}33%{transform:translate(30px,-50px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}to{transform:translate(0) scale(1)}}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.7}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.admin-page{min-height:100vh;padding:32px;background:var(--admin-bg);background-image:var(--gradient-mesh);position:relative;overflow-x:hidden}@media (max-width: 768px){.admin-page{padding:16px}}.admin-page:before,.admin-page:after{content:"";position:fixed;border-radius:50%;filter:blur(100px);opacity:.4;pointer-events:none;z-index:0;animation:blob 20s infinite ease-in-out}.admin-page:before{width:400px;height:400px;background:linear-gradient(135deg,#16a34a4d,#22c55e33);top:-100px;right:-100px}.admin-page:after{width:300px;height:300px;background:linear-gradient(135deg,#6366f14d,#8b5cf633);bottom:-50px;left:-50px;animation-delay:5s}.admin-page>*{position:relative;z-index:1}.admin-header{margin-bottom:40px;animation:fadeIn .5s ease-out}@media (max-width: 768px){.admin-header{margin-bottom:24px}.admin-header h1{font-size:24px}.admin-header p{font-size:14px}}.admin-header h1{font-size:32px;font-weight:800;color:var(--admin-text);margin:0 0 8px;letter-spacing:-.02em;display:flex;align-items:center;gap:12px}.admin-header h1 svg{color:var(--admin-primary)}.admin-header p{font-size:15px;color:var(--admin-text-muted);margin:0}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-bottom:40px}@media (max-width: 1024px){.admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}}@media (max-width: 768px){.admin-stats-grid{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px}}@media (max-width: 480px){.admin-stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.admin-stat-item{padding:8px!important}}@media (max-width: 360px){.admin-stats-grid{grid-template-columns:1fr;gap:8px}.admin-page{padding:12px!important}.admin-header h1{font-size:18px!important}.admin-header p{font-size:12px!important}}.admin-stat-card{position:relative;background:var(--admin-card);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);border:1px solid rgba(226,232,240,.8);overflow:hidden;transition:all var(--transition-normal);animation:fadeIn .5s ease-out backwards;cursor:pointer}.admin-stat-card:nth-child(1){animation-delay:.1s}.admin-stat-card:nth-child(2){animation-delay:.2s}.admin-stat-card:nth-child(3){animation-delay:.3s}.admin-stat-card:nth-child(4){animation-delay:.4s}.admin-stat-card:nth-child(5){animation-delay:.5s}.admin-stat-card:nth-child(6){animation-delay:.6s}.admin-stat-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-card-hover);border-color:transparent}.admin-stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-accent);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.admin-stat-card.success:before{background:var(--gradient-success)}.admin-stat-card.warning:before{background:var(--gradient-warning)}.admin-stat-card.danger:before{background:var(--gradient-danger)}.admin-stat-card.info:before{background:var(--gradient-info)}.admin-stat-card.primary:before{background:var(--gradient-primary)}.admin-stat-card.purple:before{background:linear-gradient(135deg,#8b5cf6,#ec4899)}.admin-stat-card:after{content:"";position:absolute;top:10px;right:10px;width:100px;height:100px;background:currentColor;opacity:.03;border-radius:50%;transition:all var(--transition-normal)}.admin-stat-card:hover:after{opacity:.08;transform:scale(1.2)}.admin-stat-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.admin-stat-icon{width:56px;height:56px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 20px #6366f140}.admin-stat-card.success .admin-stat-icon{background:var(--gradient-success);box-shadow:0 8px 20px #10b98140}.admin-stat-card.warning .admin-stat-icon{background:var(--gradient-warning);box-shadow:0 8px 20px #f59e0b40}.admin-stat-card.danger .admin-stat-icon{background:var(--gradient-danger);box-shadow:0 8px 20px #ef444440}.admin-stat-card.info .admin-stat-icon{background:var(--gradient-info);box-shadow:0 8px 20px #3b82f640}.admin-stat-card.primary .admin-stat-icon{background:var(--gradient-primary);box-shadow:var(--shadow-green)}.admin-stat-card.purple .admin-stat-icon{background:linear-gradient(135deg,#8b5cf6,#ec4899);box-shadow:0 8px 20px #8b5cf640}.admin-stat-trend{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:700;padding:6px 10px;border-radius:20px}.admin-stat-trend.up{color:var(--admin-success);background:#10b9811a}.admin-stat-trend.down{color:var(--admin-danger);background:#ef44441a}.admin-stat-value{font-size:40px;font-weight:800;color:var(--admin-text);line-height:1;margin-bottom:6px;font-feature-settings:"tnum";letter-spacing:-.02em}.admin-stat-label{font-size:14px;color:var(--admin-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.admin-card{background:var(--admin-card);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);border:1px solid rgba(226,232,240,.8);transition:all var(--transition-normal)}.admin-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}@media (max-width: 768px){.admin-card{padding:16px;border-radius:var(--radius-lg);margin:0;max-width:100%;box-sizing:border-box}}@media (max-width: 480px){.admin-card{padding:12px;border-radius:var(--radius-md)}}@media (max-width: 360px){.admin-card{padding:10px;border-radius:var(--radius-sm)}}.admin-stat-item{display:flex;align-items:center;gap:16px;padding:20px;background:var(--admin-card);border-radius:var(--radius-lg);border:1px solid var(--admin-border);transition:all var(--transition-normal)}.admin-stat-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--admin-primary)}@media (max-width: 768px){.admin-stat-item{padding:12px;gap:10px}}@media (max-width: 480px){.admin-stat-item{padding:10px;gap:8px}}@media (max-width: 360px){.admin-stat-item{padding:8px;gap:6px}}.admin-glass-card{background:#ffffffb3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-lg)}.admin-dark-card{background:var(--gradient-dark);color:#fff;border-radius:var(--radius-xl);padding:28px;position:relative;overflow:hidden}.admin-dark-card:before{content:"";position:absolute;top:0;right:0;width:200px;height:200px;background:var(--admin-primary);opacity:.1;border-radius:50%;filter:blur(60px);animation:blob 15s infinite ease-in-out}.admin-table-container{background:var(--admin-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);border:1px solid rgba(226,232,240,.8);overflow:hidden;animation:fadeIn .5s ease-out}.admin-table-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--admin-border);background:linear-gradient(to bottom,#fff,#fafafa)}.admin-table-header h2{font-size:20px;font-weight:700;color:var(--admin-text);margin:0;display:flex;align-items:center;gap:10px}.admin-table{width:100%;border-collapse:collapse}.admin-table th{background:#f8fafc;padding:16px 24px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--admin-text-muted);border-bottom:1px solid var(--admin-border)}.admin-table td{padding:18px 24px;font-size:14px;color:var(--admin-text);border-bottom:1px solid rgba(226,232,240,.6);transition:all var(--transition-fast)}@media (max-width: 768px){.admin-table-container{border-radius:16px;overflow-x:auto}.admin-table{min-width:600px}.admin-table th,.admin-table td{padding:12px 16px;font-size:13px}}.admin-table tr:hover td{background:linear-gradient(135deg,#16a34a05,#6366f105)}.admin-table tr:last-child td{border-bottom:none}.admin-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:100px;font-size:12px;font-weight:700;letter-spacing:.02em}.admin-badge.success{background:linear-gradient(135deg,#10b98126,#06b6d41a);color:#059669}.admin-badge.warning{background:linear-gradient(135deg,#f59e0b26,#f973161a);color:#d97706}.admin-badge.danger{background:linear-gradient(135deg,#ef444426,#ec48991a);color:#dc2626}.admin-badge.info{background:linear-gradient(135deg,#3b82f626,#6366f11a);color:#2563eb}.admin-badge.purple{background:linear-gradient(135deg,#8b5cf626,#ec48991a);color:#7c3aed}.admin-badge.default{background:#64748b1a;color:var(--admin-text-muted)}.admin-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);font-size:14px;font-weight:700;cursor:pointer;transition:all var(--transition-normal);border:none;position:relative;overflow:hidden;min-height:44px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}@media (max-width: 768px){.admin-btn{padding:10px 16px;font-size:13px;min-height:42px}}@media (max-width: 480px){.admin-btn{padding:8px 14px;font-size:12px;min-height:40px;gap:6px}}@media (max-width: 360px){.admin-btn{padding:8px 12px;font-size:11px;min-height:38px;gap:4px}}.admin-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.admin-btn:hover:before{left:100%}.admin-btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-green)}.admin-btn-primary:hover{transform:translateY(-3px);box-shadow:0 15px 35px #16a34a59}.admin-btn-success{background:var(--gradient-success);color:#fff;box-shadow:0 8px 20px #10b98140}.admin-btn-success:hover{transform:translateY(-3px);box-shadow:0 15px 35px #10b98159}.admin-btn-outline{background:#fff;color:var(--admin-primary);border:2px solid var(--admin-primary)}.admin-btn-outline:hover{background:var(--admin-primary);color:#fff;transform:translateY(-2px)}.admin-btn-ghost{background:transparent;color:var(--admin-text-muted)}.admin-btn-ghost:hover{background:#16a34a14;color:var(--admin-primary)}.admin-quick-actions{background:var(--admin-card);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);border:1px solid rgba(226,232,240,.8);margin-bottom:32px}.admin-quick-actions h2{font-size:20px;font-weight:700;color:var(--admin-text);margin:0 0 24px;display:flex;align-items:center;gap:12px}.admin-actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.admin-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px 16px;background:linear-gradient(145deg,#fff,#f8fafc);border:1px solid var(--admin-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);font-size:13px;font-weight:600;color:var(--admin-text);position:relative;z-index:10;pointer-events:auto;-webkit-user-select:none;-moz-user-select:none;user-select:none}.admin-action-btn:hover{background:var(--gradient-primary);color:#fff;border-color:transparent;transform:translateY(-4px);box-shadow:var(--shadow-green);z-index:20}.admin-action-btn .icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#16a34a1a,#6366f11a);color:var(--admin-primary);transition:all var(--transition-normal);pointer-events:none}.admin-action-btn:hover .icon{background:#fff3;color:#fff}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--admin-text-muted)}.admin-loading-spinner{width:56px;height:56px;border:4px solid var(--admin-border);border-top-color:var(--admin-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:20px}.admin-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--admin-text-muted);text-align:center}.admin-empty-state svg{width:72px;height:72px;margin-bottom:20px;opacity:.3}.admin-empty-state p{font-size:15px;margin:0;font-weight:500}.admin-alerts-section{background:var(--admin-card);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);border:1px solid rgba(226,232,240,.8);margin-bottom:32px}.admin-alerts-section h2{font-size:20px;font-weight:700;color:var(--admin-text);margin:0 0 20px}.admin-alert-item{display:flex;align-items:center;gap:16px;padding:18px;border-radius:var(--radius-lg);margin-bottom:12px;transition:all var(--transition-fast);cursor:pointer}.admin-alert-item:hover{transform:translate(4px)}.admin-alert-item.warning{background:linear-gradient(135deg,#f59e0b1a,#f59e0b08);border-left:4px solid var(--admin-warning)}.admin-alert-item.danger{background:linear-gradient(135deg,#ef44441a,#ef444408);border-left:4px solid var(--admin-danger)}.admin-alert-item.info{background:linear-gradient(135deg,#3b82f61a,#3b82f608);border-left:4px solid var(--admin-info)}.admin-alert-item.success{background:linear-gradient(135deg,#10b9811a,#10b98108);border-left:4px solid var(--admin-success)}.admin-alert-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-alert-item.warning .admin-alert-icon{background:#f59e0b26;color:var(--admin-warning)}.admin-alert-item.danger .admin-alert-icon{background:#ef444426;color:var(--admin-danger)}.admin-alert-item.info .admin-alert-icon{background:#3b82f626;color:var(--admin-info)}.admin-activity-section{background:var(--admin-card);border-radius:var(--radius-xl);padding:28px;box-shadow:var(--shadow-card);border:1px solid rgba(226,232,240,.8)}.admin-activity-section h2{font-size:20px;font-weight:700;color:var(--admin-text);margin:0 0 24px}.admin-activity-item{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid rgba(226,232,240,.6);cursor:pointer;transition:all var(--transition-fast)}.admin-activity-item:last-child{border-bottom:none}.admin-activity-item:hover{background:linear-gradient(135deg,rgba(22,163,74,.02) 0%,transparent 100%);margin:0 -16px;padding:18px 16px;border-radius:var(--radius-md)}.admin-activity-icon{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.admin-activity-icon.student{background:linear-gradient(135deg,#10b98126,#06b6d41a);color:var(--admin-success)}.admin-activity-icon.class{background:linear-gradient(135deg,#6366f126,#8b5cf61a);color:var(--admin-accent)}.admin-activity-icon.payment{background:linear-gradient(135deg,#f59e0b26,#f973161a);color:var(--admin-warning)}.admin-activity-text{font-size:14px;color:var(--admin-text)}.admin-activity-text strong{font-weight:700;color:var(--admin-primary)}.admin-activity-time{font-size:12px;color:var(--admin-text-light);margin-top:4px}@media (max-width: 768px){.admin-page{padding:16px;overflow-x:hidden}.admin-page:before,.admin-page:after{display:none}.admin-header h1{font-size:22px}.admin-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.admin-stat-card{padding:16px}.admin-stat-value{font-size:24px}.admin-stat-icon{width:40px;height:40px}.admin-actions-grid{grid-template-columns:repeat(2,1fr)}.admin-table-container{border-radius:var(--radius-lg);margin:0 -16px}}@media (max-width: 480px){.admin-page{padding:12px}.admin-header h1{font-size:20px}.admin-stats-grid{gap:10px}.admin-stat-card{padding:12px}.admin-stat-value{font-size:20px}.admin-stat-icon{width:36px;height:36px}.admin-table-container{margin:0 -12px}}@media (max-width: 360px){.admin-page{padding:10px}.admin-header h1{font-size:18px}.admin-stats-grid{gap:8px}.admin-stat-card{padding:10px}.admin-stat-value{font-size:18px}.admin-stat-icon{width:32px;height:32px}.admin-table-container{margin:0 -10px}}.admin-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;z-index:999999;padding:8vh 20px 20px;box-sizing:border-box;overflow-y:auto}.admin-modal-content{background:#fff;border-radius:20px;box-shadow:0 25px 60px #0000004d;max-width:800px;width:100%;max-height:90vh;min-height:200px;overflow-y:auto;animation:fadeIn .3s ease-out;margin-bottom:20px}.admin-modal-content.large{max-width:1100px}.admin-modal-content.small{max-width:420px}.admin-modal-header{padding:24px;border-bottom:1px solid var(--admin-border);display:flex;align-items:center;justify-content:space-between}.admin-modal-header h2{font-size:20px;font-weight:700;color:var(--admin-text);margin:0;display:flex;align-items:center;gap:12px}.admin-modal-close{width:36px;height:36px;border-radius:50%;border:none;background:var(--admin-bg);color:var(--admin-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.admin-modal-close:hover{background:var(--admin-danger-light);color:#fff}.admin-modal-body{padding:24px}.admin-modal-footer{padding:20px 24px;border-top:1px solid var(--admin-border);display:flex;align-items:center;justify-content:flex-end;gap:12px;background:var(--admin-bg);border-radius:0 0 20px 20px}@media (max-width: 768px){.admin-modal-overlay{padding:16px}.admin-modal-content{width:100%;max-height:90vh;border-radius:16px}.admin-modal-content.large{max-width:100%}}.unified-card{display:flex;flex-direction:column;padding:0!important;gap:0!important;background:#fff;overflow:hidden;border-radius:var(--radius-xl);box-shadow:var(--shadow-card);border:1px solid rgba(226,232,240,.8)}.admin-stats-unified{padding:24px;border-bottom:1px solid var(--admin-border);background:linear-gradient(to bottom,#fff,#fafafa)}.admin-toolbar-unified{padding:16px 24px;border-bottom:1px solid var(--admin-border);background:#fff;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;z-index:10;position:relative;box-shadow:0 4px 6px -4px #0000000d}@media (max-width: 768px){.admin-stats-unified{padding:16px}.admin-toolbar-unified{padding:12px 16px;gap:12px}}@media (max-width: 480px){.admin-stats-unified{padding:12px}.admin-toolbar-unified{padding:12px;flex-direction:column;align-items:stretch}}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s}.confirm-dialog{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000004d;max-width:500px;width:90%;animation:slideUp .3s}.confirm-dialog-header{padding:20px 24px;border-radius:12px 12px 0 0}.confirm-dialog-header h3{margin:0;font-size:20px;color:#fff}.confirm-dialog-danger{background:#e74c3c}.confirm-dialog-warning{background:#f39c12}.confirm-dialog-info{background:#3498db}.confirm-dialog-body{padding:24px}.confirm-dialog-body p{margin:0;color:#2c3e50;font-size:16px;line-height:1.6}.confirm-dialog-footer{padding:16px 24px;border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}html{margin:0!important;padding:0!important;width:100%!important;max-width:100vw!important;height:100%;font-size:13px;overflow-x:hidden!important}body,#root{margin:0!important;padding:0!important;width:100%!important;max-width:100vw!important;min-height:100vh;position:relative;overflow-x:hidden!important}.dashboard-container{display:flex;background:#f6f7fb;margin:0!important;padding:0!important;width:100%!important;max-width:100vw!important;min-height:100vh;position:relative;box-sizing:border-box;overflow-x:hidden!important}.sidebar{width:250px!important;background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;box-shadow:4px 0 20px #00000026;height:100vh;overflow:hidden;flex-shrink:0;position:fixed!important;top:0!important;left:0!important;z-index:100;margin:0!important;padding:0!important}.sidebar-header{padding:20px 16px;border-bottom:1px solid rgba(255,255,255,.2)}.sidebar-header h2{font-size:17px;margin-bottom:4px}.sidebar-header p{font-size:12px;opacity:.9;margin:4px 0}.admin-role{display:inline-block;padding:3px 8px;background:#fff3;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase;margin-top:6px}.sidebar-nav{flex:1;padding:12px 0;overflow-y:auto}.sidebar-nav button{width:100%;padding:12px 16px;border:none;background:transparent;color:#fff;text-align:left;font-size:13px;cursor:pointer;transition:all .3s;border-left:3px solid transparent;display:flex;align-items:center;gap:10px}.menu-icon{font-size:16px;width:20px;text-align:center}.menu-label{flex:1}.sidebar-nav button:hover{background:#ffffff1a}.sidebar-nav button.active{background:#ffffff26;border-left-color:#fff;font-weight:600}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.2)}.btn-logout{width:100%;padding:10px;border:1px solid white;background:transparent;color:#fff;border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;transition:all .3s}.btn-logout:hover{background:#fff;color:#667eea}.main-content{flex:1;width:calc(100% - 250px)!important;max-width:calc(100vw - 250px)!important;margin:0 0 0 250px!important;padding:24px;overflow-y:auto;overflow-x:hidden!important;background:#f6f7fb;min-height:100vh;display:flex;flex-direction:column;box-sizing:border-box;position:relative;left:0!important;right:0!important}.content-section{width:100%!important;max-width:100%!important;overflow:visible;display:flex;flex-direction:column;flex:1;box-sizing:border-box;margin:0!important;padding:0!important}.content-section h1{color:#333;margin:0 0 12px;font-size:20px;font-weight:700;flex-shrink:0;line-height:1.3}.section-header{display:flex;justify-content:space-between;align-items:center;margin:0 0 20px;flex-shrink:0;gap:16px;padding:16px 20px;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000000f}.section-header h1{flex:1;margin:0}.btn-group{display:flex;gap:12px;flex-shrink:0;align-items:center}.btn-group .btn{min-width:160px;padding:10px 20px;font-size:13px;white-space:nowrap}.section-header h1{margin:0}.header-actions{display:flex;gap:12px;align-items:center;flex-shrink:0}.header-actions .btn{min-width:140px;padding:10px 18px;font-size:13px;white-space:nowrap}.coming-soon{text-align:center;padding:80px 40px;color:#666;font-size:18px;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:16px;box-shadow:0 4px 20px #00000014;border:2px dashed #ddd}.coming-soon h3{color:#667eea;font-size:24px;margin-bottom:20px}.coming-soon ul{text-align:left;max-width:600px;margin:20px auto 0;padding-left:30px}.coming-soon li{margin-bottom:12px;color:#555;line-height:1.6}.class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;align-content:start;padding-bottom:12px}.class-card{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:8px;padding:10px;box-shadow:0 1px 4px #0000000d;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid rgba(102,126,234,.1)}.class-card:hover{transform:translateY(-3px);box-shadow:0 4px 16px #667eea26;border-color:#667eea4d}.class-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.class-card-header h3{color:#333;font-size:15px;flex:1;font-weight:700;line-height:1.4}.badge{padding:3px 8px;border-radius:6px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.2px;box-shadow:0 1px 2px #00000014}.badge-open{background:linear-gradient(135deg,#d4edda,#c3e6cb);color:#155724;border:1px solid #b8dacc}.badge-closed{background:linear-gradient(135deg,#f8d7da,#f5c6cb);color:#721c24;border:1px solid #f1b0b7}.badge-completed{background:linear-gradient(135deg,#d1ecf1,#bee5eb);color:#0c5460;border:1px solid #abdde5}.class-card-body{margin-bottom:10px}.class-card-body p{font-size:13px;color:#666;margin-bottom:4px;line-height:1.4}.class-card-footer{display:flex;gap:6px;flex-wrap:wrap}.search-bar{display:flex;gap:12px;margin-bottom:0;align-items:center;padding:16px 20px;background:#fff;border-radius:8px;box-shadow:0 1px 4px #0000000f}.search-bar input{flex:1;padding:12px 18px;border:1px solid #ddd;border-radius:6px;font-size:14px;min-width:300px}.search-bar .btn{padding:8px 16px;font-size:12px;min-width:auto;white-space:nowrap}.search-bar input:focus{outline:none;border-color:#667eea}.table-container{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:8px;padding:16px;box-shadow:0 1px 4px #0000000f;border:1px solid rgba(102,126,234,.1);width:100%;overflow-x:auto;overflow-y:visible}.table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.table-header h3{color:#333;font-size:16px;font-weight:600}table{width:100%;border-collapse:collapse;table-layout:auto}thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}th{padding:8px 10px;text-align:center;font-weight:600;color:#fff;font-size:11px;text-transform:uppercase;letter-spacing:.3px;border-bottom:none;white-space:nowrap}td{padding:8px 10px;border-bottom:1px solid #f0f0f0;font-size:12px;color:#555;background:#fff;word-wrap:break-word;max-width:200px;line-height:1.4}tbody tr{transition:all .2s}tbody tr:hover{background:linear-gradient(90deg,#f0f4ff,#fff);box-shadow:0 2px 8px #667eea1a}.select-sm{padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-size:13px;cursor:pointer}.btn{padding:10px 20px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000001a;text-transform:none;letter-spacing:.2px;display:inline-flex;align-items:center;justify-content:center;gap:6px}.btn-sm{padding:4px 10px;font-size:11px}.btn-xs{padding:3px 8px;font-size:10px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#5568d3,#6a3d8a);transform:translateY(-2px);box-shadow:0 4px 16px #667eea66}.btn-secondary{background:linear-gradient(135deg,#e0e0e0,#d0d0d0);color:#333;border:1px solid #c0c0c0}.btn-secondary:hover{background:linear-gradient(135deg,#d0d0d0,silver);transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.btn-success{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#218838,#1aa179);transform:translateY(-2px);box-shadow:0 4px 16px #28a74566}.btn-info{background:linear-gradient(135deg,#17a2b8,#138496);color:#fff}.btn-info:hover{background:linear-gradient(135deg,#138496,#0f6674);transform:translateY(-2px);box-shadow:0 4px 16px #17a2b866}.loading,.empty-state{text-align:center;padding:60px 20px;color:#999;font-size:16px}@media (max-width: 768px){.dashboard-container{flex-direction:column;position:relative}.sidebar{width:100%;position:fixed;top:0;left:-100%;height:100vh;z-index:1000;transition:left .3s ease;box-shadow:2px 0 10px #0000001a}.sidebar.mobile-open{left:0}.sidebar-header{padding:25px 20px}.sidebar-header h2{font-size:22px;font-weight:700}.sidebar-header p{font-size:16px}.sidebar-nav{padding:10px 0}.sidebar-nav button{padding:16px 20px;font-size:18px;font-weight:500}.menu-icon{font-size:22px;width:28px}.menu-label{font-size:18px}.main-content{width:100%;padding:15px;margin-left:0}.mobile-menu-toggle{position:fixed;top:15px;left:15px;z-index:1001;background:#667eea;color:#fff;border:none;padding:10px 15px;border-radius:8px;font-size:20px;cursor:pointer;box-shadow:0 2px 8px #0003}.mobile-menu-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:999;display:none}.mobile-menu-overlay.active{display:block}.content-section{padding:0}.section-header{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:20px}.section-header h1{font-size:22px}.stats-grid{grid-template-columns:1fr;gap:15px}.stat-card{padding:15px}.table-container{padding:15px;overflow-x:auto}table{font-size:12px;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}thead,tbody,tr{display:block}thead{display:none}tbody tr{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:16px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000014;border:1px solid #e0e0e0}tbody td{padding:8px 0;font-size:13px;display:flex;justify-content:space-between;align-items:center;max-width:100%}tbody td:before{content:attr(data-label);font-weight:600;color:#667eea;margin-right:12px;flex-shrink:0}.filters-section{flex-direction:column;gap:10px}.filter-group{width:100%}}@media (max-width: 968px) and (min-width: 769px){.sidebar{width:100%;position:fixed;top:0;left:0;z-index:100;height:auto;max-height:70px;overflow:visible}.sidebar-header,.sidebar-footer{display:none}.sidebar-nav{display:flex;overflow-x:auto;overflow-y:hidden;padding:10px 0}.sidebar-nav button{white-space:nowrap;flex-shrink:0}.main-content{margin-left:0;width:100%;margin-top:70px}.class-grid{grid-template-columns:1fr}.table-container{overflow-x:auto}table{overflow-x:auto;-webkit-overflow-scrolling:touch}}.upload-card{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 4px #0000000f;margin-bottom:16px}.upload-card h2{color:#333;font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid #667eea}.upload-card .form-group{margin-bottom:14px}.upload-card .form-group label{display:block;margin-bottom:6px;color:#333;font-weight:500;font-size:12px}.upload-card .required{color:#dc3545}.upload-card input[type=text],.upload-card input[type=file],.upload-card textarea{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:12px;transition:border-color .2s}.upload-card input:focus,.upload-card textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.file-info{margin-top:10px;padding:10px;background:#f8f9fa;border-radius:6px;font-size:14px;color:#666}.message{padding:15px;border-radius:8px;margin-bottom:20px;font-weight:500}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.info-box{background:#e7f3ff;border-left:4px solid #2196f3;padding:20px;border-radius:8px}.info-box h3{color:#1976d2;margin-bottom:12px;font-size:16px}.info-box ul{margin-left:20px;color:#555;line-height:1.8}.info-box li{margin-bottom:8px;font-size:14px}.info-box strong{color:#1976d2}.dashboard-overview{display:flex;flex-direction:column;gap:16px;flex:1;min-height:0;overflow:visible}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px;flex-shrink:0}.stat-card{background:#fff;border-radius:8px;padding:12px;box-shadow:0 1px 4px #0000000f;display:flex;align-items:center;gap:12px;transition:all .2s;border-left:3px solid}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.stat-card.stat-primary{border-left-color:#667eea}.stat-card.stat-success{border-left-color:#28a745}.stat-card.stat-warning{border-left-color:#ffc107}.stat-card.stat-info{border-left-color:#17a2b8}.stat-card.stat-purple{border-left-color:#764ba2}.stat-card.stat-danger{border-left-color:#dc3545}.stat-icon{font-size:24px;opacity:.6}.stat-content{flex:1}.stat-value{font-size:24px;font-weight:700;color:#333;margin-bottom:4px;line-height:1.2}.stat-label{font-size:12px;color:#666;font-weight:500;margin-bottom:2px}.stat-sublabel{font-size:10px;color:#999}.quick-actions{background:#fff;border-radius:8px;padding:12px;box-shadow:0 1px 4px #0000000f;flex-shrink:0}.quick-actions h2{color:#333;font-size:14px;font-weight:600;margin-bottom:12px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px}.action-btn{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;border:2px dashed #ddd;background:#f8f9fa;border-radius:8px;cursor:pointer;transition:all .2s}.action-btn:hover{border-color:#667eea;background:#f0f4ff;transform:translateY(-2px)}.action-icon{font-size:20px}.action-text{font-size:11px;font-weight:600;color:#333}.recent-activity{background:#fff;border-radius:8px;padding:12px;box-shadow:0 1px 4px #0000000f;flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.recent-activity h2{color:#333;font-size:14px;font-weight:600;margin-bottom:12px;flex-shrink:0}.activity-list{display:flex;flex-direction:column;gap:10px}.activity-item{display:flex;align-items:center;gap:10px;padding:10px;background:#f8f9fa;border-radius:6px;transition:all .2s}.activity-item:hover{background:#e9ecef}.activity-icon{font-size:18px}.activity-content{flex:1}.activity-text{font-size:12px;color:#333;margin-bottom:3px;line-height:1.4}.activity-time{font-size:10px;color:#999}body.modal-open{overflow:hidden;padding-right:0!important}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;width:100vw;height:100vh;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px;overflow:hidden;box-sizing:border-box;margin:0}.modal-content{background:#fff;border-radius:8px;padding:0;width:1100px;max-width:95vw;max-height:90vh;overflow:hidden;overflow-x:hidden;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column;margin:0 auto;position:relative;left:0;transform:none}.modal-content:not(.class-modal-content){background:#fff}.modal-content h2{color:#2c3e50;font-size:18px;font-weight:700;margin:0;padding:16px 20px;background:#fff;border-bottom:2px solid #667eea;box-shadow:0 1px 3px #0000000a;flex-shrink:0}.modal-content form{display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1;background:#fff}.modal-content.class-modal-content form{background:#f5f6fa!important}.modal-content form::-webkit-scrollbar{width:8px}.modal-content form::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.modal-content form::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.modal-content form::-webkit-scrollbar-thumb:hover{background:#555}.modal-content h2:not(:first-of-type){color:#333;font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid #e0e0e0}.modal-large{max-width:900px}.form-group{margin-bottom:14px}.form-group label{display:block;margin-bottom:6px;color:#333;font-weight:500;font-size:12px;width:100%}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:12px;transition:all .2s;box-sizing:border-box;display:block}.form-group small{display:block;margin-top:6px;line-height:1.4;font-size:11px;color:#777}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.date-input-wrapper,.datetime-input-wrapper{position:relative}.date-input-wrapper input[type=date],.datetime-input-wrapper input[type=datetime-local]{color-scheme:light}.date-input-wrapper input[type=date]::-webkit-calendar-picker-indicator,.datetime-input-wrapper input[type=datetime-local]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:1;margin-left:5px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}.form-group.full-width{grid-column:1 / -1}.student-detail{display:flex;flex-direction:column;gap:15px;margin-bottom:20px}.detail-row{display:flex;padding:10px 12px;background:#f8f9fa;border-radius:6px;border-left:3px solid #667eea}.detail-row strong{min-width:140px;color:#667eea;font-size:12px;font-weight:600}.detail-row span{flex:1;color:#333;font-size:12px}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.detail-item{display:flex;flex-direction:column;gap:4px;padding:10px 12px;background:#f8f9fa;border-radius:6px;border-left:3px solid #667eea}.detail-item label{font-size:11px;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.3px;margin:0}.detail-item span{font-size:13px;color:#333;line-height:1.4;word-break:break-word}.form-section-title{font-size:14px;font-weight:600;color:#333;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e5e7eb}.registration-card{padding:12px;background:#f8f9fa;border-radius:6px;border:1px solid #e5e7eb;margin-bottom:12px}.registration-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:10px}.registration-title{font-size:14px;font-weight:600;color:#333;margin:0}.registration-code{margin-left:8px;color:#666;font-size:12px;font-weight:400}.registration-details{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;font-size:12px;color:#666}.registration-details strong{font-weight:600;color:#555}.certificate-card{padding:12px;background:#e7f3ff;border-radius:6px;border:1px solid #b3d9ff;margin-bottom:12px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid #e0e0e0;flex-shrink:0}.form-actions .btn{min-width:100px;padding:8px 16px}.btn-danger{background:linear-gradient(135deg,#dc3545,#c82333);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#c82333,#bd2130);transform:translateY(-2px);box-shadow:0 4px 16px #dc354566}.class-card-selectable{cursor:pointer}.class-card-selectable:hover{transform:translateY(-4px);box-shadow:0 4px 20px #0000001f}.class-selector{background:#fff;border-radius:12px;padding:30px;box-shadow:0 2px 10px #00000014}.class-selector h3{color:#333;margin-bottom:20px}.selected-class-info{display:flex;align-items:center;gap:15px;margin-bottom:20px;padding:15px;background:#fff;border-radius:8px;box-shadow:0 2px 10px #00000014}.selected-class-info h3{margin:0;color:#333}.so-phach-input{width:100px;padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-size:13px}.student-detail{display:flex;flex-direction:column;gap:15px}.detail-row{display:flex;padding:12px;background:#f8f9fa;border-radius:8px}.detail-row strong{min-width:150px;color:#667eea}.detail-row span{color:#333;flex:1}.alerts-section{background:#fff;border-radius:8px;padding:12px;box-shadow:0 1px 4px #0000000f;flex-shrink:0}.alerts-section h2{color:#333;font-size:14px;font-weight:600;margin-bottom:12px}.alerts-list{display:flex;flex-direction:column;gap:12px}.alert-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:6px;border-left:3px solid;transition:all .2s}.alert-item:hover{transform:translate(4px);box-shadow:0 4px 12px #0000001a}.alert-warning{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-left-color:#ffc107}.alert-danger{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border-left-color:#dc3545}.alert-info{background:linear-gradient(135deg,#d1ecf1,#bee5eb);border-left-color:#17a2b8}.alert-icon{font-size:18px;flex-shrink:0}.alert-content{flex:1;display:flex;justify-content:space-between;align-items:center}.alert-message{font-size:12px;font-weight:600;color:#333}.alert-action{padding:6px 12px;background:#fff;border:1px solid;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s}.alert-warning .alert-action{border-color:#ffc107;color:#856404}.alert-warning .alert-action:hover{background:#ffc107;color:#fff}.alert-danger .alert-action{border-color:#dc3545;color:#721c24}.alert-danger .alert-action:hover{background:#dc3545;color:#fff}.alert-info .alert-action{border-color:#17a2b8;color:#0c5460}.alert-info .alert-action:hover{background:#17a2b8;color:#fff}.multi-select-container{display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;padding:15px;background:#f8f9fa;border-radius:8px;border:2px solid #e0e0e0}.checkbox-label{display:flex;align-items:center;gap:10px;padding:10px;background:#fff;border-radius:6px;cursor:pointer;transition:all .2s;border:1px solid #e0e0e0}.checkbox-label:hover{background:#f0f4ff;border-color:#667eea}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{flex:1;font-size:14px;color:#333}.filters-section{display:flex;gap:20px;margin-bottom:20px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #00000014}.filter-group{display:flex;align-items:center;gap:10px}.filter-group label{font-size:14px;font-weight:600;color:#333;white-space:nowrap}.filter-select{padding:10px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;cursor:pointer;transition:all .3s;min-width:200px}.filter-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.row-overdue{background:#fff3cd!important;border-left:4px solid #ffc107}.modal-image{max-width:90vw;max-height:90vh}.modal-image img{max-width:100%;max-height:70vh;-o-object-fit:contain;object-fit:contain;margin:20px 0;border-radius:8px;box-shadow:0 4px 12px #00000026}.settings-container{display:flex;flex-direction:column;gap:30px}.settings-section{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 4px #0000000f}.settings-section h2{color:#333;font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.settings-list{display:flex;flex-direction:column;gap:15px}.setting-item{padding:12px;background:#f8f9fa;border-radius:6px;transition:all .2s}.setting-item:hover{background:#e9ecef}.setting-item label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:12px;color:#333;font-weight:500}.setting-item input[type=checkbox]{width:20px;height:20px;cursor:pointer}.stats-editor{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.docs-management{padding:24px;min-height:100vh;background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.docs-header{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px;flex-wrap:wrap}.docs-header-left h1{display:flex;align-items:center;gap:12px;font-size:26px;font-weight:700;color:#0f172a;margin:0}.docs-subtitle{margin:4px 0 0 40px;font-size:14px;color:#64748b}.docs-header-right{display:flex;align-items:center;gap:12px}.docs-search{display:flex;align-items:center;gap:10px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:10px 16px;min-width:280px;transition:all .2s}.docs-search:focus-within{border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a}.docs-search svg{color:#94a3b8;flex-shrink:0}.docs-search input{border:none;outline:none;background:transparent;font-size:14px;color:#1e293b;width:100%}.docs-search input::-moz-placeholder{color:#94a3b8}.docs-search input::placeholder{color:#94a3b8}.docs-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:none;white-space:nowrap}.docs-btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 4px 12px #6366f14d}.docs-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.docs-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.docs-btn-ghost{background:#fff;color:#64748b;border:2px solid #e2e8f0}.docs-btn-ghost:hover{background:#f8fafc;border-color:#cbd5e1}.docs-tabs{display:flex;align-items:center;gap:8px;background:#fff;padding:8px;border-radius:16px;margin-bottom:24px;box-shadow:0 2px 8px #0000000a;flex-wrap:wrap}.docs-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;background:transparent;border:none;cursor:pointer;font-size:14px;font-weight:500;color:#64748b;transition:all .2s}.docs-tab:hover{background:#f1f5f9;color:#1e293b}.docs-tab.active{background:#6366f1;color:#fff}.docs-tab.active .docs-tab-count{background:#fff3;color:#fff}.docs-tab-count{background:#f1f5f9;color:#64748b;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:600}.docs-tabs-right{margin-left:auto;display:flex;gap:4px}.docs-view-btn{padding:8px;border-radius:8px;background:transparent;border:none;cursor:pointer;color:#94a3b8;transition:all .2s}.docs-view-btn:hover{background:#f1f5f9;color:#64748b}.docs-view-btn.active{background:#6366f1;color:#fff}.docs-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;color:#64748b}.docs-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.docs-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;background:#fff;border-radius:20px;text-align:center}.docs-empty svg{color:#cbd5e1;margin-bottom:16px}.docs-empty h3{font-size:18px;font-weight:600;color:#1e293b;margin:0 0 8px}.docs-empty p{color:#64748b;margin:0 0 24px}.docs-table-wrapper{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #0000000a}.docs-table{width:100%;border-collapse:collapse}.docs-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.docs-table th{padding:14px 16px;text-align:left;font-size:12px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.docs-table th.th-index{width:50px;text-align:center}.docs-table th.th-sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.docs-table th.th-sortable:hover{color:#6366f1}.docs-table th.th-sortable svg{display:inline-block;margin-left:4px;transition:transform .2s}.docs-table th.th-sortable svg.rotated{transform:rotate(180deg)}.docs-table th.th-actions{width:140px;text-align:center}.docs-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background .15s}.docs-table tbody tr:hover{background:#fafafa}.docs-table td{padding:16px;font-size:14px;color:#1e293b;vertical-align:middle}.docs-table td.td-index{text-align:center;color:#94a3b8;font-weight:500}.docs-table td.td-size,.docs-table td.td-date{color:#64748b;font-size:13px;white-space:nowrap}.docs-table td.td-date{display:flex;align-items:center;gap:6px}.docs-table td.td-actions{text-align:center}.doc-title-cell{display:flex;align-items:center;gap:12px}.doc-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;font-weight:700;flex-shrink:0}.doc-info{display:flex;flex-direction:column;min-width:0}.doc-name{font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-filename{font-size:12px;color:#94a3b8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-ext-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;display:inline-block}.doc-access-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.docs-action-btn{background:transparent;border:none;padding:8px;border-radius:8px;cursor:pointer;color:#64748b;transition:all .15s}.docs-action-btn:hover{background:#f1f5f9;color:#6366f1}.docs-action-btn.danger:hover{background:#fef2f2;color:#dc2626}.docs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.docs-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 8px #0000000a;transition:all .2s;position:relative}.docs-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.docs-card-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;margin-bottom:16px}.docs-card-content{margin-bottom:16px}.docs-card-title{font-size:15px;font-weight:600;color:#1e293b;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.docs-card-meta{font-size:12px;color:#94a3b8;margin:0 0 12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.docs-card-badges{display:flex;gap:8px;flex-wrap:wrap}.docs-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid #f1f5f9;font-size:12px;color:#94a3b8}.docs-card-date{display:flex;align-items:center;gap:4px}.docs-card-actions{position:absolute;top:16px;right:16px;display:flex;gap:4px;opacity:0;transition:opacity .2s}.docs-card:hover .docs-card-actions{opacity:1}.docs-card-actions button{background:#fff;border:1px solid #e2e8f0;padding:6px;border-radius:8px;cursor:pointer;color:#64748b;transition:all .15s}.docs-card-actions button:hover{background:#f1f5f9;color:#6366f1}.docs-card-actions button.danger:hover{background:#fef2f2;color:#dc2626;border-color:#fecaca}.docs-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0f172a99;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.docs-modal{background:#fff;border-radius:20px;width:100%;max-width:560px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 48px #0003}.docs-modal.docs-modal-sm{max-width:480px}.docs-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.docs-modal-header.share{background:linear-gradient(135deg,#0ea5e9,#22c55e)}.docs-modal-header h2{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:700;margin:0}.docs-modal-close{background:#fff3;border:none;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .2s}.docs-modal-close:hover{background:#ffffff4d}.docs-modal-body{padding:24px;overflow-y:auto;flex:1}.docs-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;background:#f8fafc;border-top:1px solid #e2e8f0}.docs-form-group{margin-bottom:20px}.docs-form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:#1e293b}.docs-form-group label .required{color:#dc2626}.docs-form-group input,.docs-form-group textarea{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:14px;color:#1e293b;transition:all .2s;outline:none}.docs-form-group input:focus,.docs-form-group textarea:focus{border-color:#6366f1;box-shadow:0 0 0 4px #6366f11a}.docs-form-group textarea{resize:vertical;min-height:60px}.docs-access-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.docs-access-option{display:flex;align-items:flex-start;gap:12px;padding:14px;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;transition:all .2s}.docs-access-option:hover{border-color:#cbd5e1;background:#f8fafc}.docs-access-option.selected{border-color:#6366f1;background:#eef2ff}.docs-access-option input{display:none}.docs-access-option svg{color:#6366f1;flex-shrink:0;margin-top:2px}.docs-access-option div{display:flex;flex-direction:column}.docs-access-option strong{font-size:13px;font-weight:600;color:#1e293b}.docs-access-option span{font-size:11px;color:#64748b;margin-top:2px}.docs-class-list{background:#f8fafc;border-radius:12px;padding:12px;max-height:180px;overflow-y:auto}.docs-checkbox{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;cursor:pointer;transition:background .15s}.docs-checkbox:hover{background:#e2e8f0}.docs-checkbox input{width:18px;height:18px;accent-color:#6366f1}.docs-checkbox span{font-size:14px;font-weight:500;color:#1e293b}.docs-file-drop{border:2px dashed #cbd5e1;border-radius:16px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s;background:#fafafa}.docs-file-drop:hover{border-color:#6366f1;background:#f5f3ff}.docs-file-drop.has-file{border-style:solid;border-color:#22c55e;background:#f0fdf4}.docs-file-drop svg{color:#94a3b8;margin-bottom:12px}.docs-file-drop p{font-size:15px;font-weight:600;color:#1e293b;margin:0 0 4px}.docs-file-drop span{font-size:12px;color:#94a3b8}.docs-file-preview{display:flex;align-items:center;gap:12px;text-align:left;padding:0 20px}.docs-file-preview .file-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;flex-shrink:0}.docs-file-preview .file-info{display:flex;flex-direction:column;flex:1;min-width:0}.docs-file-preview .file-name{font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.docs-file-preview .file-size{font-size:12px;color:#64748b}.docs-file-preview button{background:transparent;border:none;padding:8px;border-radius:8px;cursor:pointer;color:#dc2626}.docs-file-preview button:hover{background:#fef2f2}.share-doc-info{display:flex;align-items:center;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;margin-bottom:20px}.share-doc-info .doc-icon{width:44px;height:44px}.share-doc-info h4{font-size:14px;font-weight:600;color:#1e293b;margin:0 0 4px}.share-doc-info span{font-size:12px;color:#64748b}@media (max-width: 768px){.docs-management{padding:16px}.docs-header{flex-direction:column;align-items:stretch}.docs-header-left h1{font-size:22px}.docs-header-right{flex-wrap:wrap}.docs-search{min-width:100%}.docs-tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch}.docs-tabs-right{display:none}.docs-table-wrapper{overflow-x:auto}.docs-access-options{grid-template-columns:1fr}.docs-modal{max-width:100%;max-height:100%;border-radius:0}.upload-layout{flex-direction:column}}.docs-modal.docs-modal-wide{max-width:900px}.upload-layout{display:flex;gap:32px}.upload-col{flex:1;min-width:0}.docs-access-options-horizontal{display:flex;flex-wrap:wrap;gap:8px}.docs-access-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .2s;font-size:13px;font-weight:500;color:#64748b;background:#fff}.docs-access-chip:hover{border-color:#6366f1;color:#6366f1}.docs-access-chip.selected{border-color:#6366f1;background:#6366f1;color:#fff}.docs-access-chip input{display:none}.class-selection-tabs{background:#f8fafc;border-radius:12px;padding:12px;max-height:280px;overflow-y:auto}.class-group{margin-bottom:16px}.class-group:last-child{margin-bottom:0}.class-group-header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#6366f1;text-transform:uppercase;padding-bottom:8px;margin-bottom:8px;border-bottom:1px solid #e2e8f0}.class-list-scroll{display:flex;flex-direction:column;gap:4px}.class-checkbox{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .15s}.class-checkbox:hover{background:#e2e8f0}.class-checkbox input{width:18px;height:18px;accent-color:#6366f1;flex-shrink:0}.class-checkbox span{font-size:13px;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.no-classes{text-align:center;color:#94a3b8;padding:20px;font-size:13px}.docs-form-group select{width:100%;padding:12px 16px;border:2px solid #e2e8f0;border-radius:12px;font-size:14px;color:#1e293b;background:#fff;cursor:pointer;outline:none;transition:border-color .2s}.docs-form-group select:focus{border-color:#6366f1}.upload-col .docs-file-drop{padding:24px 16px}.upload-col .docs-file-drop svg{width:32px;height:32px}.upload-col .docs-file-drop p{font-size:13px;margin:4px 0 2px}.upload-col .docs-file-drop span{font-size:11px}.reports-page{padding:24px;max-width:1400px;margin:0 auto;width:100%}.reports-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px 24px;background:#fff;border-radius:16px;border:1px solid #e5e7eb;box-shadow:0 2px 12px #00000014}.reports-header h1{margin:0;font-size:20px;font-weight:700;color:#2c3e50}.reports-controls{display:flex;gap:12px;align-items:center}.year-select{padding:10px 16px;border:1px solid #ddd;border-radius:6px;font-size:13px;background:#fff;cursor:pointer}.btn-export{padding:10px 20px;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-export:hover{background:#45a049}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.summary-card{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 4px #0000000f;display:flex;align-items:center;gap:12px;transition:transform .2s,box-shadow .2s;border-left:4px solid transparent}.summary-card.success{border-left-color:#4caf50}.summary-card.info{border-left-color:#2196f3}.summary-card.warning{border-left-color:#ff9800}.summary-card.danger{border-left-color:#f44336}.summary-card.primary{border-left-color:#9c27b0}.summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.summary-icon{font-size:28px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:8px;flex-shrink:0}.summary-content{flex:1}.summary-label{font-size:11px;color:#7f8c8d;margin-bottom:4px;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.summary-value{font-size:20px;font-weight:700;color:#2c3e50;line-height:1.2}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:20px}.chart-card{background:#fff;border-radius:8px;padding:20px;box-shadow:0 1px 4px #0000000f}.chart-card h2{margin:0 0 16px;font-size:16px;font-weight:600;color:#2c3e50}.no-data{padding:40px;text-align:center;color:#7f8c8d;font-size:14px}.export-options{display:flex;flex-direction:column;gap:12px;margin:20px 0;padding:16px;background:#f9fafb;border-radius:10px;border:1px solid #e5e7eb}.export-option{display:flex;align-items:center;gap:12px;padding:10px;background:#fff;border-radius:8px;cursor:pointer;transition:background-color .2s;border:1px solid #e5e7eb}.export-option:hover{background:#f0f4ff;border-color:#667eea}.export-option input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.export-option span{font-size:14px;font-weight:500;color:#374151;flex:1}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb}.form-actions .btn{padding:10px 20px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.form-actions .btn-secondary{background:#6b7280;color:#fff}.form-actions .btn-secondary:hover{background:#4b5563}.form-actions .btn-primary{background:#4caf50;color:#fff}.form-actions .btn-primary:hover{background:#45a049}.form-actions .btn-primary:disabled{background:#9ca3af;cursor:not-allowed}@media (max-width: 768px){.reports-page{padding:16px}.reports-header{flex-direction:column;align-items:flex-start;gap:16px;padding:16px}.charts-grid,.summary-cards{grid-template-columns:1fr}}.admin-profile-page{padding:24px}.admin-profile-page h1{margin-bottom:24px}.profile-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.profile-section{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.profile-section h2{margin:0 0 20px;font-size:20px;color:#2c3e50}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#2c3e50}.form-group input{width:100%;padding:10px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}@media (max-width: 768px){.profile-sections{grid-template-columns:1fr}}.backup-page{padding:24px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.backup-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.backup-section{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.backup-section h2{margin:0 0 20px;font-size:20px;color:#2c3e50}.export-actions{display:flex;flex-direction:column;gap:20px}.csv-exports h3{font-size:16px;margin-bottom:12px;color:#34495e}.csv-buttons{display:flex;flex-wrap:wrap;gap:8px}.backups-list{display:flex;flex-direction:column;gap:16px}.backup-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.backup-info h4{margin:0 0 8px;font-size:16px;color:#2c3e50}.backup-info p{margin:4px 0;font-size:14px;color:#7f8c8d}.backup-actions{display:flex;gap:8px}.empty-state{text-align:center;padding:40px;color:#95a5a6}@media (max-width: 768px){.backup-sections{grid-template-columns:1fr}.backup-item{flex-direction:column;align-items:flex-start;gap:12px}}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f0f23);position:relative;overflow:hidden}.admin-login-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.admin-login-bg-circle{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s ease-in-out infinite}.admin-login-bg-circle-1{width:400px;height:400px;background:linear-gradient(135deg,#667eea,#764ba2);top:-100px;right:-100px;animation-delay:0s}.admin-login-bg-circle-2{width:300px;height:300px;background:linear-gradient(135deg,#f093fb,#f5576c);bottom:-50px;left:-50px;animation-delay:-5s}.admin-login-bg-circle-3{width:250px;height:250px;background:linear-gradient(135deg,#4facfe,#00f2fe);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-10s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-30px) rotate(5deg)}66%{transform:translateY(20px) rotate(-5deg)}}.admin-login-container{width:100%;max-width:420px;position:relative;z-index:10;animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.admin-login-header{text-align:center;margin-bottom:32px}.admin-login-logo img{height:60px;width:auto;-o-object-fit:contain;object-fit:contain;filter:brightness(1.1) drop-shadow(0 4px 20px rgba(255,255,255,.1));transition:transform .3s ease}.admin-login-logo:hover img{transform:scale(1.05)}.admin-login-badge{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:8px 16px;background:linear-gradient(135deg,#667eea33,#764ba233);border:1px solid rgba(102,126,234,.3);border-radius:100px;color:#a78bfa;font-size:13px;font-weight:600;letter-spacing:.5px}.admin-login-badge svg{color:#a78bfa}.admin-login-card{background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;box-shadow:0 25px 50px -12px #00000080}.admin-login-card-content{padding:40px!important}.admin-login-title{text-align:center;margin-bottom:32px}.admin-login-title h1{font-size:28px;font-weight:700;color:#fff;margin-bottom:8px;letter-spacing:-.5px}.admin-login-title p{font-size:14px;color:#fff9}.admin-login-error{display:flex;align-items:center;gap:12px;padding:14px 18px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:12px;margin-bottom:24px;color:#fca5a5;font-size:14px;animation:shake .4s ease-out}.admin-login-error-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#ef44444d;border-radius:50%;font-weight:700;font-size:14px;flex-shrink:0}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.admin-login-form{display:flex;flex-direction:column;gap:24px}.admin-login-field{display:flex;flex-direction:column;gap:8px}.admin-login-field label{font-size:14px;font-weight:500;color:#fffc}.admin-login-input-wrapper{position:relative}.admin-login-input-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#fff6;pointer-events:none;transition:color .2s ease}.admin-login-input-wrapper:focus-within .admin-login-input-icon{color:#a78bfa}.admin-login-input{width:100%;padding:14px 14px 14px 46px!important;background:#ffffff0d!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:12px!important;color:#fff!important;font-size:15px!important;transition:all .2s ease!important}.admin-login-input::-moz-placeholder{color:#ffffff4d}.admin-login-input::placeholder{color:#ffffff4d}.admin-login-input:focus{outline:none!important;border-color:#a78bfa80!important;box-shadow:0 0 0 4px #a78bfa1a!important;background:#ffffff14!important}.admin-login-field-error{font-size:12px;color:#fca5a5;margin-top:4px}.admin-login-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:16px 24px!important;background:linear-gradient(135deg,#667eea,#764ba2)!important;border:none!important;border-radius:12px!important;color:#fff!important;font-size:16px!important;font-weight:600!important;cursor:pointer;transition:all .3s ease!important;box-shadow:0 8px 24px #667eea59;margin-top:8px}.admin-login-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #667eea73}.admin-login-btn:active:not(:disabled){transform:translateY(0)}.admin-login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.admin-login-btn-icon{flex-shrink:0}.admin-login-footer{text-align:center;margin-top:32px;color:#fff6;font-size:13px}.admin-login-footer p{margin-bottom:12px}.admin-login-back-link{color:#a78bfacc;text-decoration:none;font-weight:500;transition:color .2s ease}.admin-login-back-link:hover{color:#a78bfa}@media (max-width: 480px){.admin-login-page{padding:16px}.admin-login-card-content{padding:28px!important}.admin-login-title h1{font-size:24px}.admin-login-logo img{height:50px}.admin-login-badge{font-size:12px;padding:6px 12px}}.logo-container{display:flex;align-items:center;gap:16px;position:relative;z-index:1;margin-left:0;padding-left:0}.logo-icon{width:70px;height:60px;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0}.logo-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;transition:transform .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.logo-container:hover .logo-image{transform:scale(1.08)}.logo-svg{width:100%;height:100%}.logo-svg.fallback{display:none}.logo-main{font-size:22px;font-weight:700;color:#2c3e50;line-height:1;letter-spacing:.5px}.logo-sub{font-size:11px;color:#5a6c7d;font-weight:600;letter-spacing:1px;margin-top:3px;text-transform:uppercase}@media (max-width: 640px){.logo-icon{width:50px;height:42px}.logo-main{font-size:18px}.logo-sub{font-size:9px}}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}#root{min-height:100vh}.layout{min-height:100vh;display:flex;flex-direction:column;background:#fff;width:100%}.top-bar{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);color:#fff;padding:10px 0;font-size:13px;border-bottom:1px solid rgba(255,255,255,.1);width:100%}.top-bar-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.top-bar-left{display:flex;gap:30px;align-items:center}.top-bar-link{color:#ffffffd9;text-decoration:none;display:flex;align-items:center;gap:8px;transition:all .3s ease;padding:4px 8px;border-radius:4px;font-weight:500}.top-bar-link:hover{color:#4caf50;background:#4caf501a;transform:translateY(-1px)}.top-bar-link .icon{font-size:14px;opacity:.9}.top-bar-right{display:flex;gap:12px;align-items:center}.top-bar-btn{padding:8px 18px;border-radius:6px;font-size:13px;font-weight:700;text-decoration:none;transition:all .3s ease;cursor:pointer;border:none;white-space:nowrap;display:inline-flex;align-items:center;justify-content:center}.top-bar-btn-outline{background:transparent;color:#ffffffe6;border:2px solid rgba(255,255,255,.3)}.top-bar-btn-outline:hover{background:#ffffff1a;border-color:#ffffff80;color:#fff;transform:translateY(-1px)}.top-bar-btn-primary{background:linear-gradient(135deg,#4caf50,#2e7d32);color:#fff;border:2px solid transparent;box-shadow:0 4px 12px #4caf504d}.top-bar-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 18px #4caf5066;background:linear-gradient(135deg,#45a049,#2d6e31)}.top-bar-btn-ghost{background:transparent;color:#fffc;border:2px solid transparent}.top-bar-btn-ghost:hover{background:#ffffff1a;color:#fff}.lang-separator{width:1px;height:20px;background:#fff3;margin:0 8px}.lang-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fffc;padding:6px 14px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:700;transition:all .3s ease;min-width:40px;text-align:center}.lang-btn:hover{background:#fff3;border-color:#fff6;color:#fff;transform:translateY(-1px)}.lang-btn.active{background:#4caf50;border-color:#4caf50;color:#fff;box-shadow:0 2px 8px #4caf504d}.navbar{background:#fff;box-shadow:0 4px 20px #0000000f;position:sticky;top:0;z-index:1000;border-bottom:1px solid rgba(0,0,0,.05);width:100%}.navbar-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:90px}.navbar-logo{text-decoration:none;display:flex;align-items:center;transition:transform .3s ease}.navbar-logo:hover{transform:scale(1.02)}.logo-text{display:flex;flex-direction:column}.footer-tax{color:#ffffffd9;font-size:13px;margin-top:12px;font-weight:500}.footer-representative{color:#ffffffd9;font-size:13px;margin-top:8px;font-weight:500}.navbar-menu{display:flex;list-style:none;gap:8px;margin:0;padding:0;flex:1;justify-content:center;align-items:center}.navbar-menu li{position:relative}.navbar-menu li a{color:#2c3e50;text-decoration:none;font-weight:600;font-size:14px;transition:all .3s cubic-bezier(.4,0,.2,1);padding:14px 18px;display:flex;align-items:center;gap:6px;border-radius:8px;white-space:nowrap;position:relative}.navbar-menu li a:before{content:"";position:absolute;bottom:8px;left:50%;transform:translate(-50%) scaleX(0);width:60%;height:2px;background:#4caf50;transition:transform .3s cubic-bezier(.4,0,.2,1);border-radius:2px}.navbar-menu li a:hover:before,.navbar-menu li a.active:before{transform:translate(-50%) scaleX(1)}.navbar-menu li a:hover,.navbar-menu li a.active{color:#4caf50;background:#4caf5014;transform:translateY(-1px)}.dropdown-arrow{font-size:10px;margin-left:4px;transition:transform .3s cubic-bezier(.4,0,.2,1);opacity:.7}.navbar-menu li.has-dropdown:hover .dropdown-arrow{transform:rotate(180deg);opacity:1}.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;background:#fff;min-width:280px;box-shadow:0 12px 40px #00000026;border-radius:12px;list-style:none;padding:12px 0;margin:0;opacity:0;visibility:hidden;transform:translateY(-15px);transition:all .3s cubic-bezier(.4,0,.2,1);z-index:100;border:1px solid rgba(0,0,0,.05)}.navbar-menu li.has-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-menu li{margin:0}.dropdown-menu li a{padding:14px 24px;display:block;color:#2c3e50;font-size:14px;font-weight:500;border-radius:0;transition:all .2s ease}.dropdown-menu li a:before{display:none}.dropdown-menu li a:hover{background:linear-gradient(90deg,#4caf501a,#4caf500d);color:#4caf50;padding-left:28px}.navbar-actions{display:flex;gap:14px;align-items:center}.mobile-menu-toggle{display:none;flex-direction:column;gap:5px;background:transparent;border:none;cursor:pointer;padding:8px}.mobile-menu-toggle span{width:25px;height:3px;background:#333;border-radius:2px;transition:all .3s}.main-content{flex:1;background:#fff;width:100%}.footer{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);color:#fff;padding:60px 0 0;margin-top:80px;border-top:1px solid rgba(255,255,255,.1)}.footer-container{max-width:1200px;margin:0 auto 50px;padding:0 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:50px}.footer-section h3{color:#4caf50;font-size:22px;margin-bottom:20px;font-weight:700;letter-spacing:.5px}.footer-section h4{color:#fff;font-size:17px;margin-bottom:18px;font-weight:600}.footer-tagline{color:#ffffffbf;font-size:14px;font-style:italic;margin-bottom:20px;line-height:1.6}.footer-certifications{display:flex;gap:10px;flex-wrap:wrap;margin-top:15px}.cert-badge{background:#ffffff1a;padding:8px 14px;border-radius:6px;font-size:11px;font-weight:600;border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.cert-badge:hover{background:#4caf5033;border-color:#4caf50;transform:translateY(-2px)}.footer-section p,.footer-section ul{color:#ffffffbf;font-size:14px;line-height:1.9}.footer-section ul{list-style:none;padding:0}.footer-section ul li{margin-bottom:12px}.footer-section ul li strong{color:#fff;display:block;margin-bottom:6px;font-weight:600}.footer-section ul li a{color:#ffffffbf;text-decoration:none;transition:all .3s ease}.footer-section ul li a:hover{color:#4caf50;transform:translate(3px)}.contact-list{list-style:none;padding:0}.contact-item-footer{margin-bottom:18px}.contact-item-footer strong{color:#fff;display:block;margin-bottom:10px;font-weight:600;font-size:15px}.phone-numbers{display:flex;flex-direction:column;gap:8px}.phone-link{color:#ffffffd9;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;font-size:14px;padding:4px 0}.phone-link:hover{color:#4caf50;transform:translate(5px)}.email-link{color:#ffffffd9;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;font-size:14px;padding:4px 0}.email-link:hover{color:#4caf50;transform:translate(5px)}.social-links{display:flex;flex-direction:column;gap:10px}.zalo-link,.facebook-link{color:#ffffffd9;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:all .3s ease;font-size:14px;padding:4px 0;line-height:1.4}.zalo-link:hover{color:#0068ff;transform:translate(3px)}.zalo-link:hover .zalo-icon{transform:scale(1.1)}.facebook-link:hover{color:#1877f2;transform:translate(3px)}.facebook-link:hover .facebook-icon{transform:scale(1.1)}.social-icon{width:18px;height:18px;flex-shrink:0;display:block;transition:transform .3s ease}.zalo-icon{width:18px;height:18px}.facebook-icon{color:#1877f2;width:18px;height:18px}.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:25px 0;text-align:center;color:#fff9;font-size:13px}@media (max-width: 1400px){.top-bar-container,.navbar-container,.footer-container{max-width:100%;padding:0 20px}}@media (max-width: 1200px){.navbar-menu{gap:4px}.navbar-menu li a{padding:12px 14px;font-size:13px}}@media (max-width: 968px){.top-bar{display:block;padding:8px 0}.top-bar-container{padding:0 15px;flex-wrap:wrap;gap:8px}.top-bar-left{gap:10px;flex-wrap:wrap;font-size:11px}.top-bar-link{font-size:10px;padding:2px 4px;white-space:nowrap}.top-bar-right{gap:6px;flex-wrap:wrap}.top-bar-btn{padding:5px 10px;font-size:10px}.lang-separator{display:none}.lang-btn{padding:4px 8px;font-size:10px;min-width:32px}.navbar-container{height:70px;padding:0 15px}.mobile-menu-toggle{display:flex}.navbar-menu{position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:20px;box-shadow:0 4px 12px #0000001a;max-height:0;overflow:hidden;transition:max-height .3s;margin:0;gap:0}.navbar-menu.active{max-height:80vh;overflow-y:auto}.navbar-menu li{width:100%;border-bottom:1px solid #eee}.navbar-menu li:last-child{border-bottom:none}.navbar-menu li a{padding:15px;width:100%;justify-content:space-between}.dropdown-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;background:#f8f9fa;margin:0;padding:0;max-height:0;overflow:hidden;transition:max-height .3s}.dropdown-menu.active{max-height:500px}.dropdown-menu li a{padding-left:30px}.navbar-actions{gap:8px}.btn{padding:10px 18px;font-size:13px}.footer-container{grid-template-columns:1fr;text-align:left;gap:40px;padding:0 20px}}@media (max-width: 640px){.logo-main{font-size:18px}.logo-sub{font-size:8px}.navbar-actions .btn{display:none}.navbar-actions .btn-primary-nav{display:block;padding:8px 12px;font-size:12px}}@media (max-width: 480px){.top-bar-container{padding:0 10px}.top-bar-left{gap:6px;font-size:9px}.top-bar-link{font-size:9px;padding:2px 3px}.top-bar-btn{padding:4px 8px;font-size:9px}.navbar-container{padding:0 10px;height:65px}.navbar-menu{padding:12px}.navbar-menu li a{padding:12px;font-size:14px}.footer-container{padding:0 10px;gap:25px}}@media (min-width: 769px){html{font-size:14px}body{font-size:1rem;line-height:1.6}.top-bar{padding:10px 0;font-size:13px}.navbar-container{height:85px}.navbar-menu li a{padding:12px 16px;font-size:14px}.footer{padding:60px 0 0}.footer-section h3{font-size:20px}.footer-section h4{font-size:16px}.layout,.main-content{overflow-x:hidden}}.password-reset-page{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:40px 20px}.password-reset-card{background:#fff;border-radius:12px;padding:40px;max-width:500px;width:100%;box-shadow:0 4px 20px #0000001a}.password-reset-card h1{margin:0 0 12px;font-size:28px;color:#2c3e50;text-align:center}.password-reset-card p{color:#7f8c8d;text-align:center;margin-bottom:30px}.password-reset-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#2c3e50;font-size:14px}.form-group input{padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4caf50}.error-message{background:#fee;color:#c33;padding:12px;border-radius:8px;font-size:14px;text-align:center}.btn-primary{background:#4caf50;color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-primary:hover:not(:disabled){background:#45a049}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-large{width:100%;padding:16px;font-size:16px}.password-reset-card.success{text-align:center}.password-reset-card.success h1{color:#4caf50}@media (max-width: 640px){.password-reset-card{padding:30px 20px}}
