@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;600;700;800&family=Sora:wght@600;700;800&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Nunito,ui-sans-serif,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%;touch-action:manipulation}body{margin:0;font-family:Nunito,ui-sans-serif,system-ui,sans-serif;color:#0f172a;background:#f8fbff;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body,#root{width:100%;min-height:100%}body{overflow-x:hidden}img,video,canvas,svg{max-width:100%;height:auto}input,select,textarea{font-size:16px}.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.-bottom-5{bottom:-1.25rem}.-left-6{left:-1.5rem}.-top-4{top:-1rem}.-top-6{top:-1.5rem}.bottom-3{bottom:.75rem}.left-1\/2{left:50%}.left-3{left:.75rem}.left-4{left:1rem}.left-6{left:1.5rem}.right-3{right:.75rem}.top-2{top:.5rem}.z-10{z-index:10}.order-1{order:1}.order-2{order:2}.mx-3{margin-left:.75rem;margin-right:.75rem}.mx-auto{margin-left:auto;margin-right:auto}.mb-10{margin-bottom:2.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-16{margin-top:4rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-7{margin-top:1.75rem}.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}.h-1\.5{height:.375rem}.h-24{height:6rem}.h-4{height:1rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-72{height:18rem}.h-\[620px\]{height:620px}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.min-h-64{min-height:16rem}.min-h-screen{min-height:100vh}.w-1\/2{width:50%}.w-20{width:5rem}.w-24{width:6rem}.w-4\/5{width:80%}.w-6{width:1.5rem}.w-8{width:2rem}.w-\[270px\]{width:270px}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.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{flex-shrink:0}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.-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))}.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 fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-fade-up{animation:fade-up .6s ease-out both}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.list-disc{list-style-type:disc}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.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-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-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-\[2\.4rem\]{border-radius:2.4rem}.rounded-\[2\.6rem\]{border-radius:2.6rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-sm{border-radius:.125rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-indigo-100{--tw-border-opacity: 1;border-color:rgb(224 231 255 / var(--tw-border-opacity, 1))}.border-indigo-200{--tw-border-opacity: 1;border-color:rgb(199 210 254 / var(--tw-border-opacity, 1))}.border-slate-200{--tw-border-opacity: 1;border-color:rgb(226 232 240 / var(--tw-border-opacity, 1))}.border-white\/70{border-color:#ffffffb3}.bg-\[\#f1f3f9\]{--tw-bg-opacity: 1;background-color:rgb(241 243 249 / var(--tw-bg-opacity, 1))}.bg-amber-100{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity, 1))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-emerald-100{--tw-bg-opacity: 1;background-color:rgb(209 250 229 / var(--tw-bg-opacity, 1))}.bg-indigo-100{--tw-bg-opacity: 1;background-color:rgb(224 231 255 / var(--tw-bg-opacity, 1))}.bg-indigo-400{--tw-bg-opacity: 1;background-color:rgb(129 140 248 / var(--tw-bg-opacity, 1))}.bg-indigo-50{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.bg-indigo-50\/70{background-color:#eef2ffb3}.bg-indigo-500{--tw-bg-opacity: 1;background-color:rgb(99 102 241 / var(--tw-bg-opacity, 1))}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-slate-900{--tw-bg-opacity: 1;background-color:rgb(15 23 42 / var(--tw-bg-opacity, 1))}.bg-violet-100{--tw-bg-opacity: 1;background-color:rgb(237 233 254 / var(--tw-bg-opacity, 1))}.bg-violet-200\/60{background-color:#ddd6fe99}.bg-violet-50{--tw-bg-opacity: 1;background-color:rgb(245 243 255 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/10{background-color:#ffffff1a}.bg-white\/20{background-color:#fff3}.bg-white\/85{background-color:#ffffffd9}.bg-white\/95{background-color:#fffffff2}.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))}.from-\[\#667eea\]{--tw-gradient-from: #667eea var(--tw-gradient-from-position);--tw-gradient-to: rgb(102 126 234 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-\[\#eef1ff\]{--tw-gradient-from: #eef1ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(238 241 255 / 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-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-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-indigo-100{--tw-gradient-from: #e0e7ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(224 231 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-500{--tw-gradient-from: #6366f1 var(--tw-gradient-from-position);--tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-sky-500{--tw-gradient-from: #0ea5e9 var(--tw-gradient-from-position);--tw-gradient-to: rgb(14 165 233 / 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-violet-100{--tw-gradient-from: #ede9fe var(--tw-gradient-from-position);--tw-gradient-to: rgb(237 233 254 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-violet-600{--tw-gradient-from: #7c3aed var(--tw-gradient-from-position);--tw-gradient-to: rgb(124 58 237 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-\[\#f7f5ff\]{--tw-gradient-to: rgb(247 245 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #f7f5ff var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-\[\#764ba2\]{--tw-gradient-to: #764ba2 var(--tw-gradient-to-position)}.to-\[\#efeaff\]{--tw-gradient-to: #efeaff var(--tw-gradient-to-position)}.to-fuchsia-100{--tw-gradient-to: #fae8ff var(--tw-gradient-to-position)}.to-indigo-100{--tw-gradient-to: #e0e7ff var(--tw-gradient-to-position)}.to-indigo-600{--tw-gradient-to: #4f46e5 var(--tw-gradient-to-position)}.to-indigo-900{--tw-gradient-to: #312e81 var(--tw-gradient-to-position)}.to-orange-600{--tw-gradient-to: #ea580c var(--tw-gradient-to-position)}.to-purple-700{--tw-gradient-to: #7e22ce var(--tw-gradient-to-position)}.to-teal-600{--tw-gradient-to: #0d9488 var(--tw-gradient-to-position)}.to-violet-100{--tw-gradient-to: #ede9fe var(--tw-gradient-to-position)}.to-violet-600{--tw-gradient-to: #7c3aed var(--tw-gradient-to-position)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-\[3px\]{padding:3px}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-1{padding-bottom:.25rem}.pb-20{padding-bottom:5rem}.pl-5{padding-left:1.25rem}.pt-6{padding-top:1.5rem}.text-center{text-align:center}.font-heading{font-family:Sora,ui-sans-serif,system-ui,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[120px\]{font-size:120px}.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-medium{font-weight:500}.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-\[0\.12em\]{letter-spacing:.12em}.tracking-\[0\.14em\]{letter-spacing:.14em}.tracking-\[0\.15em\]{letter-spacing:.15em}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-widest{letter-spacing:.1em}.text-amber-700{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.text-emerald-600{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-emerald-700{--tw-text-opacity: 1;color:rgb(4 120 87 / var(--tw-text-opacity, 1))}.text-indigo-100{--tw-text-opacity: 1;color:rgb(224 231 255 / var(--tw-text-opacity, 1))}.text-indigo-300{--tw-text-opacity: 1;color:rgb(165 180 252 / var(--tw-text-opacity, 1))}.text-indigo-50{--tw-text-opacity: 1;color:rgb(238 242 255 / var(--tw-text-opacity, 1))}.text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.text-indigo-700{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.text-purple-200{--tw-text-opacity: 1;color:rgb(233 213 255 / var(--tw-text-opacity, 1))}.text-sky-600{--tw-text-opacity: 1;color:rgb(2 132 199 / var(--tw-text-opacity, 1))}.text-sky-700{--tw-text-opacity: 1;color:rgb(3 105 161 / var(--tw-text-opacity, 1))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-slate-700{--tw-text-opacity: 1;color:rgb(51 65 85 / var(--tw-text-opacity, 1))}.text-slate-800{--tw-text-opacity: 1;color:rgb(30 41 59 / var(--tw-text-opacity, 1))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.text-violet-600{--tw-text-opacity: 1;color:rgb(124 58 237 / var(--tw-text-opacity, 1))}.text-violet-700{--tw-text-opacity: 1;color:rgb(109 40 217 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/5{color:#ffffff0d}.text-white\/70{color:#ffffffb3}.text-white\/85{color:#ffffffd9}.underline{text-decoration-line:underline}.underline-offset-2{text-underline-offset:2px}.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-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-indigo-100{--tw-shadow-color: #e0e7ff;--tw-shadow: var(--tw-shadow-colored)}.shadow-indigo-200{--tw-shadow-color: #c7d2fe;--tw-shadow: var(--tw-shadow-colored)}.shadow-slate-100{--tw-shadow-color: #f1f5f9;--tw-shadow: var(--tw-shadow-colored)}.shadow-slate-400{--tw-shadow-color: #94a3b8;--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-4{--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(4px + 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-indigo-100{--tw-ring-opacity: 1;--tw-ring-color: rgb(224 231 255 / var(--tw-ring-opacity, 1))}.ring-indigo-300{--tw-ring-opacity: 1;--tw-ring-color: rgb(165 180 252 / var(--tw-ring-opacity, 1))}.ring-sky-500\/30{--tw-ring-color: rgb(14 165 233 / .3)}.ring-slate-100{--tw-ring-opacity: 1;--tw-ring-color: rgb(241 245 249 / var(--tw-ring-opacity, 1))}.ring-slate-200{--tw-ring-opacity: 1;--tw-ring-color: rgb(226 232 240 / var(--tw-ring-opacity, 1))}.ring-slate-800{--tw-ring-opacity: 1;--tw-ring-color: rgb(30 41 59 / var(--tw-ring-opacity, 1))}.ring-violet-100{--tw-ring-opacity: 1;--tw-ring-color: rgb(237 233 254 / var(--tw-ring-opacity, 1))}.ring-white\/20{--tw-ring-color: rgb(255 255 255 / .2)}.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-\[3px\]{--tw-blur: blur(3px);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-xl{--tw-blur: blur(24px);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)}.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-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}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}@media (max-width: 640px){html{-webkit-text-size-adjust:100%}}.placeholder\:text-slate-400::-moz-placeholder{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.placeholder\:text-slate-400::placeholder{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.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\:border-indigo-300:hover{--tw-border-opacity: 1;border-color:rgb(165 180 252 / var(--tw-border-opacity, 1))}.hover\:bg-indigo-50:hover{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-700:hover{--tw-bg-opacity: 1;background-color:rgb(67 56 202 / var(--tw-bg-opacity, 1))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:text-indigo-200:hover{--tw-text-opacity: 1;color:rgb(199 210 254 / var(--tw-text-opacity, 1))}.hover\:text-indigo-700:hover{--tw-text-opacity: 1;color:rgb(67 56 202 / var(--tw-text-opacity, 1))}.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)}.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)}@media (min-width: 640px){.sm\:block{display:block}.sm\:h-80{height:20rem}.sm\:h-\[640px\]{height:640px}.sm\:w-32{width:8rem}.sm\:w-\[290px\]{width:290px}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-start{align-items:flex-start}.sm\:gap-8{gap:2rem}.sm\:p-10{padding:2.5rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width: 768px){.md\:order-1{order:1}.md\:order-2{order:2}.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\:items-center{align-items:center}.md\:p-10{padding:2.5rem}}@media (min-width: 1024px){.lg\:h-96{height:24rem}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:px-12{padding-left:3rem;padding-right:3rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:text-5xl{font-size:3rem;line-height:1}}@media (min-width: 1280px){.xl\:px-16{padding-left:4rem;padding-right:4rem}}@media (min-width: 1536px){.\32xl\:px-20{padding-left:5rem;padding-right:5rem}}.donate-header-btn{background:linear-gradient(135deg,#f59e0b,#ea580c);color:#fff;border:none;border-radius:8px;padding:.4rem .85rem;font-weight:700;font-size:.8rem;cursor:pointer;box-shadow:0 2px 8px #ea580c59}.donate-header-btn:hover{filter:brightness(1.05)}.donate-header-btn--compact{width:40px;height:40px;padding:0;border-radius:50%;font-size:1.1rem;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.donate-header-btn--fab{width:52px;height:52px;border-radius:50%;font-size:1.35rem;box-shadow:0 4px 14px #ea580c73}.donate-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;z-index:2000;display:flex;align-items:center;justify-content:center;padding:1rem}.donate-modal{background:#fff;border-radius:16px;padding:1.5rem;max-width:400px;width:100%;box-shadow:0 20px 50px #0003}.donate-modal h3{margin:0 0 .5rem;color:#1e40af}.donate-tagline{font-size:.9rem;color:#475569;line-height:1.5}.donate-providers-note{font-size:.8rem;color:#334155;background:#f1f5f9;padding:.55rem .65rem;border-radius:8px;line-height:1.45;margin:.5rem 0}.donate-providers-note code{font-size:.75rem}.donate-hint{font-size:.8rem;color:#b45309;background:#fffbeb;padding:.5rem;border-radius:8px}.donate-modal label{display:block;margin:.75rem 0;font-size:.85rem;font-weight:600}.donate-modal input{display:block;width:100%;margin-top:.35rem;padding:.55rem;border:1px solid #cbd5e1;border-radius:8px}.donate-err{color:#dc2626;font-size:.85rem}.donate-ok{color:#166534;font-size:.85rem}.donate-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.donate-banner{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;margin-bottom:1rem;border-radius:12px;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d}.donate-banner-compact{padding:.75rem 1rem;margin-bottom:.75rem}.donate-banner-text strong{display:block;color:#92400e;margin-bottom:.25rem}.donate-banner-text p{margin:0;font-size:.88rem;color:#78350f;line-height:1.45;max-width:520px}.tutorial-video{margin:1.5rem 0 2rem;padding:1.25rem 1.25rem 1rem;border-radius:1rem;background:linear-gradient(145deg,#eef2ff,#f8fafc 55%,#ecfdf5);border:1px solid #c7d2fe;box-shadow:0 8px 24px #4f46e514}.tutorial-video__header h2{margin:0 0 .35rem;font-size:1.25rem;font-weight:800;color:#312e81}.tutorial-video__subtitle{margin:0 0 .85rem;font-size:.9rem;color:#475569;line-height:1.45}.tutorial-video__frame{border-radius:.75rem;overflow:hidden;background:#0f172a;box-shadow:0 4px 20px #0f172a40}.tutorial-video__player-wrap{position:relative;width:100%;background:#000}.tutorial-video__player{display:block;width:100%;max-height:min(56vw,420px);background:#000}.tutorial-video__fs-btn{position:absolute;right:10px;bottom:52px;z-index:2;width:2.25rem;height:2.25rem;border:none;border-radius:8px;background:#0f172ab8;color:#fff;font-size:1.1rem;cursor:pointer;line-height:1}.tutorial-video__fs-btn:hover{background:#4f46e5e6}.tutorial-video__hint{margin:.75rem 0 0;font-size:.8rem;color:#64748b;line-height:1.5}.tutorial-video__hint a{color:#4f46e5;font-weight:600}.tutorial-video__download{display:inline-flex;align-items:center;gap:.35rem;margin-top:.5rem;font-size:.85rem;font-weight:600;color:#4338ca;text-decoration:none}.tutorial-video__download:hover{text-decoration:underline}.tutorial-video--compact{margin:0 0 1rem;padding:0;background:transparent;border:none;box-shadow:none}.tutorial-video__compact-btn{display:flex;align-items:center;gap:.75rem;width:100%;text-align:left;padding:.85rem 1rem;border-radius:12px;border:1px solid #a5b4fc;background:linear-gradient(135deg,#eef2ff,#faf5ff);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.tutorial-video__compact-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #4f46e526}.tutorial-video__compact-btn strong{display:block;font-size:.95rem;color:#312e81}.tutorial-video__compact-btn small{display:block;margin-top:.15rem;font-size:.78rem;color:#64748b;font-weight:500}.tutorial-video__play-icon{flex-shrink:0;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:.85rem;padding-left:2px}.tutorial-video__modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10050;display:flex;align-items:center;justify-content:center;padding:1rem}.tutorial-video__modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172ab8}.tutorial-video__modal-body{position:relative;width:min(960px,100%);z-index:1}.tutorial-video__modal-toolbar{position:absolute;top:-2.75rem;right:0;display:flex;gap:.5rem;z-index:2}.tutorial-video__toolbar-btn,.tutorial-video__close{background:#ffffff26;border:none;color:#fff;width:2rem;height:2rem;border-radius:50%;cursor:pointer;font-size:1rem}.tutorial-video__modal-body .tutorial-video__player{max-height:min(80vh,540px);border-radius:12px}.tutorial-video__modal--fullscreen .tutorial-video__modal-body{width:100%;height:100%;max-width:none;display:flex;flex-direction:column;justify-content:center;background:#000}.tutorial-video__modal--fullscreen .tutorial-video__modal-toolbar{top:12px;right:12px}.tutorial-video__modal--fullscreen .tutorial-video__modal-body .tutorial-video__player-wrap{aspect-ratio:auto;height:100%;max-height:100vh}.tutorial-video__modal--fullscreen .tutorial-video__modal-body .tutorial-video__player{max-height:100vh;height:100%;border-radius:0;-o-object-fit:contain;object-fit:contain}.tutorial-video__modal--fullscreen .tutorial-video__fs-btn{bottom:72px;right:16px}.landing-page .tutorial-video{margin-top:2.5rem}.staff-hub-page .tutorial-video--compact,.guest-dashboard-page .tutorial-video--compact,.phub-page .tutorial-video--compact{max-width:640px}@media (max-width: 640px){.tutorial-video__player{max-height:52vw}}.auth-app-shell{min-height:100dvh;display:flex;flex-direction:column;background:#f0f2f5}.auth-app-shell__header{background:linear-gradient(135deg,#128c7e,#25d366);color:#fff;padding:16px 18px 20px;flex-shrink:0}.auth-app-shell__brand{display:flex;align-items:center;gap:12px}.auth-app-shell__logo{font-size:36px;line-height:1}.auth-app-shell__brand strong{display:block;font-size:20px;font-weight:800}.auth-app-shell__brand span{font-size:12px;opacity:.9}.auth-app-shell__dean{margin:10px 0 0;font-size:13px;font-weight:600;opacity:.95}.auth-app-shell__main{flex:1;padding:20px 16px 24px;display:flex;justify-content:center;align-items:flex-start}.auth-app-shell__card{width:100%;max-width:440px;background:#fff;border-radius:14px;padding:24px 20px;box-shadow:0 2px 12px #00000014}.auth-app-shell__card h1{margin:0 0 6px;font-size:22px;font-weight:800;color:#075e54;text-align:center}.auth-app-shell__sub{margin:0 0 20px;text-align:center;color:#667781;font-size:14px;line-height:1.45}.auth-app-shell__footer{padding:12px 16px calc(16px + env(safe-area-inset-bottom,0px));text-align:center;font-size:14px;color:#667781;background:#fff;border-top:1px solid #e9edef}.auth-app-shell__footer a{color:#128c7e;font-weight:700;text-decoration:none}.auth-app-shell .form-group{margin-bottom:14px}.auth-app-shell .form-group label{display:block;font-size:13px;font-weight:600;color:#075e54;margin-bottom:6px}.auth-app-shell .form-group input,.auth-app-shell .form-group select,.auth-app-shell .form-group textarea{width:100%;box-sizing:border-box;padding:12px 14px;border:1.5px solid #e9edef;border-radius:10px;font-size:15px;background:#f0f2f5}.auth-app-shell .form-group input:focus,.auth-app-shell .form-group select:focus{outline:none;border-color:#25d366;background:#fff}.auth-app-shell .btn-primary{background:linear-gradient(135deg,#25d366,#128c7e);border:none;color:#fff;font-weight:700;border-radius:10px;padding:12px 16px;width:100%;font-size:15px;cursor:pointer}.auth-app-shell .btn-secondary{background:#fff;border:1.5px solid #128c7e;color:#128c7e;font-weight:600;border-radius:10px;padding:10px 14px;cursor:pointer}.auth-app-shell .role-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.auth-app-shell .role-card{border:2px solid #e9edef;border-radius:12px;padding:14px 10px;text-align:center;cursor:pointer;background:#fff;transition:border-color .15s,background .15s}.auth-app-shell .role-card.active{border-color:#25d366;background:#e7ffdb}.auth-app-shell .role-card strong{display:block;font-size:14px;color:#075e54}.auth-app-shell .alert-error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c;padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:12px}.auth-app-shell__hint{text-align:center;color:#667781;font-size:14px;margin:0 0 16px;line-height:1.45}.auth-back-link{display:inline-flex;align-items:center;gap:6px;margin-bottom:18px;font-size:14px;font-weight:700;color:#4f46e5;text-decoration:none;line-height:1.35}.auth-back-link:hover{color:#4338ca;text-decoration:underline}.auth-back-link__en{font-weight:600;color:#64748b}.auth-app-shell .auth-back-link{margin-bottom:14px}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px #0003}.auth-logo{font-size:48px;text-align:center;margin-bottom:8px}.auth-card h2{text-align:center;font-size:24px;font-weight:700;color:#1a1a2e;margin:0 0 4px}.auth-sub{text-align:center;color:#666;margin:0 0 24px;font-size:14px}.auth-link{text-align:center;margin-top:20px;font-size:14px;color:#666}.auth-link a{color:#667eea;font-weight:600;text-decoration:none}.auth-school-email-row{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.auth-school-email-local{flex:1 1 140px;min-width:120px}.auth-school-email-domain{color:#475569;font-weight:600;font-size:14px;word-break:break-all}.auth-password-wrap{position:relative}.auth-password-wrap input{padding-right:44px;width:100%;box-sizing:border-box}.auth-password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:18px;padding:2px;line-height:1;color:#64748b}.auth-password-toggle:hover{color:#334155}.phub-page{min-height:100dvh;display:flex;flex-direction:column;background:#f8fafc;font-family:Google Sans,Segoe UI,system-ui,sans-serif}.phub-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#fff;border-bottom:1px solid #e8eaed;box-shadow:0 1px 2px #3c40430f}.phub-brand{display:flex;flex-direction:column}.phub-logo{font-weight:700;font-size:20px;color:#1a73e8}.phub-sub{font-size:12px;color:#5f6368}.phub-header-actions{display:flex;gap:8px;align-items:center}.phub-nav{display:flex;gap:4px;padding:8px 12px;background:#fff;border-bottom:1px solid #e8eaed}.phub-nav-btn{flex:1;border:none;background:transparent;padding:10px 12px;border-radius:24px;font-weight:600;font-size:14px;color:#5f6368;cursor:pointer;position:relative}.phub-nav-btn.active{background:#e8f0fe;color:#1a73e8}.phub-badge{position:absolute;top:4px;right:8px;background:#d93025;color:#fff;font-size:10px;padding:2px 6px;border-radius:10px}.phub-body{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.phub-chat-wrap{flex:1;min-height:0;width:100%;max-width:none;height:calc(100dvh - 128px)}.phub-panel{padding:16px 20px;max-width:none;width:100%;margin:0;overflow-y:auto;height:calc(100dvh - 120px);box-sizing:border-box}.phub-card{background:#fff;border:1px solid #e8eaed;border-radius:12px;padding:14px 16px;margin-bottom:12px;box-shadow:0 1px 2px #3c40430d}.phub-card-unread{border-left:4px solid #1a73e8}.phub-child-hero{background:linear-gradient(135deg,#e8f0fe,#fff)}.phub-muted{color:#5f6368;font-size:14px}.phub-section{margin-top:20px}.phub-section h3{font-size:15px;color:#202124;margin-bottom:8px}.phub-row{font-size:14px;padding:8px 0;border-bottom:1px solid #f1f3f4}.phub-select-label{display:block;margin-bottom:16px;font-weight:600}.phub-select-label select{display:block;width:100%;margin-top:6px;padding:8px;border-radius:8px}.phub-chat-header{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid #eee;background:#fff}.phub-chat-meta{font-size:12px;color:#5f6368;margin-top:4px;line-height:1.4}@media (min-width: 900px){.phub-nav{max-width:400px;margin:0 auto;border-radius:0 0 24px 24px}}.wa-theme.phub-page,.staff-hub-page{--wa-green: #25d366;--wa-green-dark: #128c7e;--wa-chat-bg: #e5ddd5;--wa-bubble-in: #ffffff;--wa-bubble-out: #d9fdd3}.wa-theme .phub-nav-btn.active{background:#dcf8c6;color:#075e54}.wa-theme .msg-bubble.sent{background:var(--wa-bubble-out);color:#111}.wa-theme .msg-bubble.received{background:var(--wa-bubble-in)}.wa-messages{background:var(--wa-chat-bg)}.wa-context-banner{background:#fff;border-left:4px solid var(--wa-green, #25d366);padding:10px 12px;margin:8px 12px;border-radius:8px;font-size:12px;color:#303030;line-height:1.45;box-shadow:0 1px 2px #0000000f}.wa-chat-header{background:var(--wa-green-dark, #128c7e)!important;color:#fff!important}.wa-chat-header .phub-chat-meta{color:#ffffffd9!important}.wa-input-bar{background:#f0f2f5}.staff-hub-page{min-height:100dvh;display:flex;flex-direction:column;background:#f0f2f5}.staff-hub-page .dash-main{flex:1;max-width:none;width:100%;margin:0}.staff-hub-nav{position:sticky;top:0;z-index:20}@media (max-width: 768px){.staff-hub-nav{position:fixed;bottom:0;left:0;right:0;top:auto;border-top:1px solid #e8eaed;border-bottom:none;padding-bottom:env(safe-area-inset-bottom,8px)}.staff-hub-page .dash-main{padding-bottom:72px}}.phub-period-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}.phub-period-tabs button{border:1px solid #dadce0;background:#fff;padding:6px 14px;border-radius:20px;font-size:13px;cursor:pointer}.phub-period-tabs button.active{background:#dcf8c6;border-color:#25d366;color:#075e54;font-weight:600}.phub-pinned{border-left:4px solid #f59e0b;background:#fffbeb}.phub-teachers-strip{background:#fff;border-bottom:1px solid #e8eaed;padding:12px 16px 8px;flex-shrink:0}.phub-teachers-strip-title{font-size:13px;font-weight:700;color:#075e54;margin:0 0 10px}.phub-teachers-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch}.phub-teachers-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.phub-teacher-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:12px 14px;min-width:240px;flex-shrink:0}.phub-teacher-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:4px}.phub-teacher-role{font-size:11px;text-transform:capitalize;color:#64748b;background:#e2e8f0;padding:2px 8px;border-radius:10px}.phub-teacher-meta{margin:2px 0 8px;font-size:12px}.phub-teacher-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.phub-contact-link{font-size:13px;color:#1a73e8;word-break:break-all}.phub-chat-contact-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px;font-size:12px}.phub-chat-contact-row a{color:#fffffff2;text-decoration:underline}.phub-chat-header-main{flex:1;min-width:0}.msg-contact-sub{display:block;font-size:11px;color:#667781;margin-top:2px}.phub-download-row{margin-top:14px;display:flex;flex-wrap:wrap;gap:8px}.phub-row--quiz{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.phub-page--chats .phub-body{flex:1;min-height:0}.phub-chat-wrap--full{flex:1;min-height:0;height:auto!important}.phub-page--chats{height:100dvh;max-height:100dvh;overflow:hidden}.phub-page--chats .phub-teachers-strip{max-height:28vh}@media (max-width: 768px){.phub-header{flex-wrap:wrap;gap:8px;padding:10px 12px}.phub-header-actions{flex-wrap:wrap;width:100%;justify-content:flex-start}.phub-header-actions .btn{font-size:12px;padding:6px 10px}.phub-nav{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding:6px 8px}.phub-nav-btn{flex:0 0 auto;white-space:nowrap;font-size:12px;padding:8px 12px}.phub-panel{padding:12px;height:auto;max-height:none;flex:1;overflow-y:auto}.phub-chat-wrap,.phub-chat-wrap--full{height:calc(100dvh - 200px)!important;min-height:320px}.phub-page--chats .phub-teachers-strip{max-height:22vh}.phub-teacher-card{min-width:200px}.phub-teachers-grid{grid-template-columns:1fr}}@media (min-width: 900px){.phub-page--chats .phub-chat-wrap--full{height:calc(100dvh - 220px)!important;min-height:480px}}.wa-chat-shell.msg-page,.msg-page.wa-chat-shell{display:flex;flex-direction:row;width:100%;height:100%;min-height:0;overflow:hidden}.msg-page--fullscreen,.app-wa-shell--chat-fullscreen .msg-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;height:100dvh;max-height:100dvh;width:100%;max-width:none;padding-bottom:env(safe-area-inset-bottom,0px);box-sizing:border-box}.app-wa-shell--chat-fullscreen .msg-input-row{padding-bottom:max(10px,env(safe-area-inset-bottom,0px))}.app-wa-shell--chat-fullscreen{min-height:100dvh;height:100dvh;overflow:hidden}.app-wa-shell--chat-fullscreen>div:first-of-type+div{flex:1;min-height:0;overflow:hidden;display:flex;flex-direction:column}.wa-chat-shell .msg-sidebar,.wa-chat-shell .msg-chat{min-height:0}.wa-chat-shell .msg-chat{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.wa-chat-shell .msg-chat-header,.wa-chat-shell .phub-chat-header,.wa-chat-shell .wa-chat-header,.wa-chat-shell .wa-context-banner,.wa-chat-shell .msg-img-preview{flex:0 0 auto;flex-shrink:0}.wa-chat-shell .wa-chat-body{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;overflow:hidden}.wa-chat-shell .msg-thread,.wa-chat-shell .msg-messages,.wa-chat-shell .wa-messages{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.wa-chat-shell .msg-input-row,.wa-chat-shell .msg-input-bar,.wa-chat-shell .wa-input-bar{flex:0 0 auto;flex-shrink:0;margin-top:auto;order:99}.msg-page--hub-embed,.phub-chat-wrap.wa-chat-shell,.staff-hub-page .phub-chat-wrap.wa-chat-shell{display:flex;flex-direction:row;width:100%;max-width:none;min-height:420px;height:calc(100dvh - 128px);overflow:hidden}.msg-page--hub-embed .msg-chat{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.phub-body{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.phub-body>.phub-chat-wrap{flex:1;min-height:0}@media (min-width: 769px){.phub-chat-wrap.wa-chat-shell,.staff-hub-page .phub-chat-wrap.wa-chat-shell{height:calc(100dvh - 140px);min-height:560px}.staff-hub-page .dash-main:has(.phub-chat-wrap){padding:0;display:flex;flex-direction:column;min-height:0;overflow:hidden}.staff-hub-page .phub-chat-wrap.wa-chat-shell{flex:1;height:calc(100dvh - 152px);border-radius:0}}@media (max-width: 768px){.phub-chat-wrap.wa-chat-shell{height:calc(100dvh - 120px - env(safe-area-inset-bottom,0px))}.phub-page--chats .phub-chat-wrap.wa-chat-shell{height:100%!important;min-height:280px}}.msg-page{display:flex;height:calc(100dvh - 56px);background:#d1d7db;overflow:hidden;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.msg-page--fullscreen,.app-wa-shell--chat-fullscreen .msg-page{position:fixed;top:0;right:0;bottom:0;left:0;z-index:8000;height:100dvh;max-height:100dvh;width:100%}.msg-sidebar{width:30%;min-width:280px;max-width:420px;flex-shrink:0;background:#fff;border-right:1px solid #e9edef;display:flex;flex-direction:column;overflow:hidden}.msg-sidebar-header{display:flex;align-items:center;gap:12px;padding:10px 16px;min-height:60px;font-weight:600;font-size:16px;background:#f0f2f5;border-bottom:1px solid #e9edef;flex-shrink:0;color:#111b21}.msg-sidebar-title{flex:1;font-size:15px;font-weight:600}.msg-wa-back{width:40px;height:40px;border:none;border-radius:50%;background:transparent;color:#54656f;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.msg-wa-back:hover{background:#0000000f}.msg-contact{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .12s;border-bottom:1px solid #f5f6f6}.msg-contact:hover{background:#f5f6f6}.msg-contact.active{background:#f0f2f5}.msg-contact-avatar-wrap{position:relative;flex-shrink:0}.msg-contact-avatar{width:49px;height:49px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.msg-unread-dot{position:absolute;top:0;right:0;width:12px;height:12px;background:#25d366;border-radius:50%;border:2px solid #fff}.msg-contact-name{font-size:16px;font-weight:400;color:#111b21;display:flex;align-items:center;gap:3px}.msg-contact-role{font-size:13px;color:#667781;text-transform:capitalize}.msg-contact-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.msg-section-label{padding:8px 16px 4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#667781;background:#f0f2f5}.msg-preview{font-size:13px;color:#667781;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.msg-contact.unread .msg-contact-name{font-weight:600}.msg-contact.unread .msg-preview{color:#111b21;font-weight:500}.msg-chat{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;background:#efeae2;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23d4cfc4' fill-opacity='0.35'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.msg-no-chat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#667781;font-size:15px;gap:12px;background:#f0f2f5;border-bottom:6px solid #25d366}.msg-no-chat-icon{font-size:56px;opacity:.5}.msg-chat-header{display:flex;align-items:center;gap:12px;padding:10px 16px;min-height:60px;background:#f0f2f5;border-bottom:1px solid #e9edef;flex-shrink:0}.msg-chat-avatar{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.msg-chat-name{font-size:16px;font-weight:500;color:#111b21;display:flex;align-items:center;gap:4px}.msg-chat-role{font-size:13px;color:#667781;text-transform:capitalize}.msg-thread{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px 8% 16px;display:flex;flex-direction:column;gap:4px;min-height:0}.msg-thread-empty{text-align:center;margin-top:40px;color:#667781}.msg-bubble-wrap{display:flex;margin-bottom:2px}.msg-bubble-wrap.mine{justify-content:flex-end}.msg-bubble-wrap.theirs{justify-content:flex-start}.msg-bubble{max-width:65%;padding:6px 8px 4px 10px;border-radius:8px;position:relative;box-shadow:0 1px .5px #0b141a21}.mine .msg-bubble{background:#d9fdd3;color:#111b21;border-top-right-radius:0}.theirs .msg-bubble{background:#fff;color:#111b21;border-top-left-radius:0}.msg-bubble-announce{border:1px solid #fde68a;background:#fffbeb!important}.msg-type-tag{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:#92400e;margin-bottom:4px;font-weight:700}.msg-bubble p{font-size:14.2px;line-height:1.45;margin:0 0 2px;word-break:break-word}.msg-time{font-size:11px;color:#667781;float:right;margin-left:8px;margin-top:2px;line-height:1}.mine .msg-time{color:#667781}.msg-input-row{display:flex;align-items:flex-end;gap:6px;padding:8px 12px 10px;background:#f0f2f5;flex-shrink:0}.msg-input-row input[type=text],.msg-input-row input:not([type=file]){flex:1;min-width:0;padding:10px 14px;border:none;border-radius:8px;font-size:15px;outline:none;background:#fff;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none}.msg-input-row input:focus{box-shadow:none}.msg-send-btn{width:48px;height:48px;border-radius:50%;background:#00a884;color:#fff;border:none;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.msg-send-btn:disabled{opacity:.5;cursor:not-allowed}.msg-send-btn:hover:not(:disabled){background:#008f72}.msg-icon-btn{width:42px;height:42px;border-radius:50%;background:transparent;border:none;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#54656f}.msg-icon-btn:hover{background:#0000000f}.msg-emoji-wrap{position:relative;display:flex;align-items:center}.emoji-panel{position:absolute;bottom:52px;left:0;background:#fff;border:1px solid #e9edef;border-radius:8px;padding:10px;box-shadow:0 4px 20px #0b141a26;display:flex;flex-wrap:wrap;width:300px;gap:4px;z-index:100}.emoji-btn{background:none;border:none;font-size:22px;cursor:pointer;border-radius:6px;padding:4px;line-height:1}.emoji-btn:hover{background:#f0f2f5}.msg-img-preview{padding:8px 16px;display:flex;align-items:center;gap:10px;background:#f0f2f5;flex-shrink:0}.msg-img-preview img{height:60px;width:80px;-o-object-fit:cover;object-fit:cover;border-radius:8px}.msg-img-clear{background:#fee2e2;color:#dc2626;border:none;border-radius:50%;width:26px;height:26px;font-size:14px;cursor:pointer}.msg-img{max-width:280px;max-height:200px;border-radius:6px;-o-object-fit:cover;object-fit:cover;cursor:pointer;display:block;margin-bottom:4px}.msg-empty{padding:20px 16px;color:#667781;font-size:14px;text-align:center}.msg-back-btn{display:none;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:transparent;border:none;font-size:20px;cursor:pointer;flex-shrink:0;color:#54656f}.msg-attach-wrap{position:relative;flex-shrink:0}.msg-attach-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#fff;border:1px solid #e9edef;border-radius:12px;box-shadow:0 4px 20px #0b141a26;padding:6px;min-width:220px;z-index:30}.msg-attach-menu button{display:block;width:100%;text-align:left;padding:12px 14px;border:none;background:none;font-size:14px;border-radius:8px;cursor:pointer;color:#111b21}.msg-attach-menu button:hover{background:#f0f2f5}@media (min-width: 769px){.msg-sidebar,.msg-chat{display:flex!important;transform:none!important;pointer-events:auto!important}.msg-back-btn{display:none!important}}@media (max-width: 768px){.msg-page{position:fixed;top:0;right:0;bottom:0;left:0;height:100dvh;z-index:8000}.msg-sidebar{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;max-width:none;min-width:0;z-index:2;transition:transform .2s ease}.msg-sidebar-hidden{transform:translate(-100%);pointer-events:none}.msg-chat{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;z-index:1;transition:transform .2s ease}.msg-chat-hidden{transform:translate(100%);pointer-events:none}.msg-back-btn{display:flex}.msg-thread{padding-left:12px;padding-right:12px}}.student-notif-bell-wrap{position:relative;display:inline-flex;align-items:center}.student-notif-bell-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;background:#ffffff26;color:inherit;cursor:pointer;flex-shrink:0}.student-notif-bell-btn:hover{background:#ffffff47}.dash-header--student .student-notif-bell-btn{background:#f1f5f9;color:#0f172a}.dash-header--student .student-notif-bell-btn:hover{background:#e2e8f0}.wa-class-header .student-notif-bell-btn,.staff-hub-page .phub-header .student-notif-bell-btn{background:#ffffff38;color:#fff;box-shadow:0 2px 8px #0000001f}.wa-class-header .student-notif-bell-btn:hover,.staff-hub-page .phub-header .student-notif-bell-btn:hover{background:#ffffff61}.wa-class-header .student-notif-bell-wrap,.staff-hub-page .phub-header .student-notif-bell-wrap{flex-shrink:0;margin-left:auto}.phub-header-actions .student-notif-bell-btn{background:#f1f5f9;color:#0f172a}.phub-header-actions .student-notif-bell-btn:hover{background:#e2e8f0}.phub-header-actions .student-notif-bell-wrap,.dash-user .student-notif-bell-wrap,.mobile-student-row1 .student-notif-bell-wrap{margin-left:4px}@media (max-width: 768px){.staff-hub-page.staff-dashboard-classic .phub-header .mobile-student-row1 .student-notif-bell-btn,.staff-wa-dashboard .mobile-student-row1 .student-notif-bell-btn{background:#fff!important;color:#128c7e!important;box-shadow:0 2px 10px #128c7e40!important;border:2px solid #128c7e}}.wa-class-notif{position:relative;z-index:20}.class-hero-notif{display:flex;align-items:flex-start;flex-shrink:0}.class-hero-notif .student-notif-bell-btn{background:#fff!important;color:#128c7e!important;box-shadow:0 4px 14px #128c7e4d!important;width:44px;height:44px}.class-points-notif-wrap{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;padding:4px 10px 4px 6px;border-radius:999px;background:#fff;border:2px solid #128c7e;box-shadow:0 2px 10px #128c7e2e}.class-points-notif-label{font-size:16px;line-height:1;pointer-events:none}.class-points-notif-wrap .student-notif-bell-btn{background:transparent!important;color:#128c7e!important;border:none;box-shadow:none!important;width:36px;height:36px}.class-points-notif-wrap .student-notif-bell-btn:hover{background:#ecfdf5!important}.wa-class-header-actions{display:flex;align-items:center;margin-left:auto;flex-shrink:0}.teacher-notif-bell--prominent .student-notif-bell-btn{width:44px;height:44px;border:2px solid rgba(255,255,255,.65);box-shadow:0 4px 14px #00000026}.teacher-notif-bell--prominent .student-notif-bell-icon{font-size:20px}.item-card--has-team{border-left:4px solid #128c7e;box-shadow:0 2px 12px #128c7e1a}.class-hero-side{display:flex;flex-direction:column;align-items:flex-end;gap:10px}.student-notif-bell-icon{font-size:18px;line-height:1}.student-notif-badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-weight:700;line-height:18px;text-align:center;box-shadow:0 1px 3px #0003}.student-notif-backdrop{display:none}.student-notif-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:1200;width:min(360px,calc(100vw - 24px));max-height:min(70vh,480px);display:flex;flex-direction:column;background:#fff;border-radius:14px;box-shadow:0 16px 48px #0f172a2e;border:1px solid #e2e8f0;overflow:hidden}.student-notif-panel-head{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 16px;border-bottom:1px solid #e2e8f0;background:#f8fafc;flex-shrink:0}.student-notif-panel-head strong{font-size:16px;color:#0f172a}.student-notif-panel-actions{display:flex;align-items:center;gap:8px}.student-notif-mark-all{border:none;background:none;color:#2563eb;font-size:12px;font-weight:600;cursor:pointer;padding:4px 6px}.student-notif-close{border:none;background:none;font-size:22px;line-height:1;color:#64748b;cursor:pointer;padding:0 4px}.student-notif-list{overflow-y:auto;-webkit-overflow-scrolling:touch}.student-notif-item{display:flex;gap:12px;width:100%;text-align:left;padding:12px 16px;border:none;border-bottom:1px solid #f1f5f9;background:#fff;cursor:pointer}.student-notif-item:hover{background:#f8fafc}.student-notif-item--unread{background:#eff6ff}.student-notif-item--unread:hover{background:#dbeafe}.student-notif-item-icon{font-size:22px;line-height:1.2;flex-shrink:0}.student-notif-item-body{display:flex;flex-direction:column;gap:2px;min-width:0}.student-notif-item-title{font-size:14px;font-weight:700;color:#0f172a}.student-notif-item-text{font-size:13px;color:#475569;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.student-notif-item-time{font-size:11px;color:#94a3b8;margin-top:2px}.student-notif-empty{padding:24px 16px;margin:0;text-align:center;color:#64748b;font-size:14px}.student-notif-bell--header .student-notif-panel{z-index:1300}.wa-class-header .student-notif-bell--header{margin-left:auto;flex-shrink:0}.wa-class-header .student-notif-bell-btn{background:#ffffff38;color:#fff}.wa-class-header .student-notif-bell-btn:hover{background:#ffffff59}@media (max-width: 640px){.student-notif-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:1199;border:none;background:#0f172a59;cursor:pointer}.student-notif-panel{position:fixed;left:0;right:0;bottom:0;top:auto;width:100%;max-height:78vh;border-radius:16px 16px 0 0;z-index:1200}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#f5f6fa;color:#333}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s;text-decoration:none}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a6fd6}.btn-danger{background:#ff4757;color:#fff}.btn-danger:hover{background:#e84393}.btn-outline{background:transparent;color:#667eea;border:2px solid #667eea}.btn-outline:hover{background:#667eea;color:#fff}.btn-logout{background:#fff3!important;color:#fff!important;border:1px solid rgba(255,255,255,.75)!important;font-weight:600}.btn-logout:hover{background:#ffffff59!important;color:#fff!important}.dash-header--student .btn-logout,.student-dashboard-classic .dash-header--student .btn-logout{background:#fff!important;color:#128c7e!important;border:1px solid #128c7e!important}.dash-header--student .btn-logout:hover{background:#e7fce8!important;color:#075e54!important}.btn-secondary{background:#f0f2ff;color:#667eea}.btn-secondary:hover{background:#e0e4ff}.btn-full{width:100%;justify-content:center;padding:12px;font-size:15px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:5px 12px;font-size:13px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;transition:border-color .2s;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.alert{padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.alert-error{background:#fff0f0;color:#e74c3c;border:1px solid #ffcdd2}.alert-success{background:#f0fff4;color:#27ae60;border:1px solid #c8e6c9}.dashboard{min-height:100vh;background:#f5f6fa}.dash-header{background:#fff;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #00000014;position:sticky;top:0;z-index:100}.dash-brand{font-size:20px;font-weight:700;color:#667eea}.dash-user{display:flex;align-items:center;gap:16px;font-size:14px;color:#555}.dash-main{max-width:none;width:100%;margin:0;padding:32px 24px;box-sizing:border-box}.dash-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.dash-top h1{font-size:28px;font-weight:700;color:#1a1a2e}.dash-sub{color:#888;font-size:14px;margin-top:4px}.classes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.class-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 12px #00000012;text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column;gap:12px;border:2px solid transparent}.class-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #667eea33;border-color:#667eea}.class-card-header h3{font-size:17px;font-weight:700;color:#1a1a2e}.subject-tag{display:inline-block;background:#f0f2ff;color:#667eea;padding:2px 10px;border-radius:20px;font-size:12px;font-weight:600;margin-top:4px}.class-code-display{background:#f8f9ff;border-radius:8px;padding:10px 14px}.code-label{display:block;font-size:11px;color:#888;font-weight:600;text-transform:uppercase;letter-spacing:1px}.code-value{font-size:22px;font-weight:700;color:#667eea;letter-spacing:3px}.class-teacher{font-size:13px;color:#666}.class-card-footer{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#888}.arrow{color:#667eea;font-weight:700}.class-top-scorers{background:#fffbf0;border:1px solid #ffe58f;border-radius:8px;padding:8px 10px;display:flex;flex-direction:column;gap:5px}.top-scorer-row{display:flex;flex-direction:column;gap:1px}.top-scorer-quiz{font-size:11px;color:#888;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.top-scorer-name{font-size:13px;font-weight:700;color:#b8860b}.empty-state{text-align:center;padding:80px 20px}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{font-size:20px;font-weight:700;margin-bottom:8px;color:#1a1a2e}.empty-state p{color:#888;margin-bottom:24px;font-size:15px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow-y:auto}.modal{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:460px;box-shadow:0 20px 60px #0000004d}.assign-group-overlay{overflow:hidden;padding:max(12px,env(safe-area-inset-top)) 12px max(12px,env(safe-area-inset-bottom))}.assign-group-modal{margin:auto}.assign-group-modal-footer{position:sticky;bottom:0;z-index:2}@media (max-width: 640px){.assign-group-overlay{align-items:flex-end;padding:0}.assign-group-modal{max-height:94vh!important;height:94vh!important;border-radius:16px 16px 0 0;margin:0;width:100%!important;max-width:none!important}}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-size:20px;font-weight:700}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:#888;line-height:1}.modal-close:hover{color:#333}.modal-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}.class-page{min-height:100vh;background:#f5f6fa}.class-main{max-width:none;width:100%;margin:0;padding:32px 24px;box-sizing:border-box}.class-hero{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:28px 32px;color:#fff;margin-bottom:28px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.class-hero h1{font-size:24px;font-weight:700}.class-hero .subject{opacity:.85;font-size:14px;margin-top:4px}.class-hero-code{background:#fff3;border-radius:10px;padding:12px 20px;text-align:center}.class-hero-code .code-label{font-size:11px;opacity:.8;font-weight:600;letter-spacing:1px;text-transform:uppercase;display:block}.class-hero-code .code-big{font-size:26px;font-weight:700;letter-spacing:4px}.tabs{display:flex;gap:4px;background:#fff;border-radius:12px;padding:4px;box-shadow:0 2px 8px #0000000f;margin-bottom:24px;flex-wrap:wrap}.tab{padding:9px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:none;background:transparent;color:#666;transition:all .2s}.tab.active{background:#667eea;color:#fff}.tab:hover:not(.active){background:#f0f2ff;color:#667eea}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{font-size:18px;font-weight:700}.item-card{background:#fff;border-radius:10px;padding:16px 20px;margin-bottom:12px;box-shadow:0 1px 6px #0000000f;display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.item-card-body{flex:1}.item-card-body h3{font-size:15px;font-weight:600;margin-bottom:4px}.item-card-body p{font-size:13px;color:#666}.item-card-body .meta{font-size:12px;color:#aaa;margin-top:6px}.item-card-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.quiz-question{background:#fff;border-radius:10px;padding:20px;margin-bottom:16px;box-shadow:0 1px 6px #0000000f}.quiz-question h3{font-size:15px;font-weight:600;margin-bottom:14px}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border:2px solid #e8e8e8;border-radius:8px;cursor:pointer;transition:all .2s}.quiz-option:hover{border-color:#667eea;background:#f8f9ff}.quiz-option.selected{border-color:#128c7e;background:#ecfdf5;box-shadow:0 0 0 1px #128c7e40}.quiz-option-text{flex:1;min-width:0}.quiz-option-check{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#128c7e;color:#fff;font-size:18px;font-weight:900;line-height:1;font-family:system-ui,-apple-system,sans-serif;box-shadow:0 2px 8px #128c7e59}.quiz-answer-saved{display:inline-flex;align-items:center;gap:6px;margin-top:8px;font-size:13px;font-weight:700;color:#128c7e}.quiz-answer-saved .quiz-option-check{width:22px;height:22px;font-size:14px}.quiz-option.correct{border-color:#27ae60;background:#f0fff4}.quiz-option.wrong{border-color:#e74c3c;background:#fff0f0}.quiz-option input{display:none}.score-card{background:#fff;border-radius:16px;padding:40px;text-align:center;box-shadow:0 4px 20px #0000001a}.score-big{font-size:64px;font-weight:700;color:#667eea;margin:16px 0}.score-sub{color:#666;font-size:16px}.students-table{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 1px 6px #0000000f}.students-table table{width:100%;border-collapse:collapse}.students-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#888;background:#f8f9ff}.students-table td{padding:12px 16px;border-top:1px solid #f0f0f0;font-size:14px}.discussion-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.discussion-msg{background:#fff;border-radius:10px;padding:14px 16px;box-shadow:0 1px 6px #0000000f}.discussion-msg .author{font-size:13px;font-weight:700;margin-bottom:4px;color:#667eea}.discussion-msg .author .role-badge{font-size:10px;background:#f0f2ff;color:#667eea;padding:1px 6px;border-radius:10px;margin-left:6px;font-weight:600}.discussion-msg .teacher-msg .author{color:#764ba2}.discussion-msg .body{font-size:14px;color:#333}.discussion-msg .time{font-size:11px;color:#aaa;margin-top:4px}.disc-actions{display:flex;gap:8px;margin-top:10px}.disc-action-btn{background:#f3f4f6;border:none;border-radius:20px;padding:4px 14px;font-size:13px;font-weight:600;cursor:pointer;color:#6b7280;transition:background .15s,color .15s;display:inline-flex;align-items:center;gap:4px}.disc-action-btn:hover{background:#e5e7eb;color:#374151}.disc-action-btn.liked{background:#fee2e2;color:#dc2626}.disc-comments{margin-top:12px;background:#f9fafb;border-radius:8px;padding:12px;border-left:3px solid #667eea;display:flex;flex-direction:column;gap:8px}.disc-comment{background:#fff;border-radius:8px;padding:8px 12px;box-shadow:0 1px 4px #0000000d}.disc-comment-author{font-weight:700;font-size:13px;color:#374151;margin-right:6px}.disc-comment-role{font-size:10px;background:#f0f2ff;color:#667eea;padding:1px 6px;border-radius:10px;font-weight:600}.disc-comment p{margin:4px 0 2px;font-size:13px;color:#374151}.disc-comment-time{font-size:11px;color:#aaa}.disc-comment-form{display:flex;gap:8px;margin-top:6px}.disc-comment-form input{flex:1;padding:7px 12px;border:1.5px solid #e8e8e8;border-radius:8px;font-size:13px;font-family:inherit}.disc-comment-form input:focus{border-color:#667eea;outline:none}.discussion-input{display:flex;gap:10px}.discussion-input input{flex:1;padding:10px 14px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px}.discussion-input input:focus{border-color:#667eea;outline:none}.class-card-wrap{display:flex;flex-direction:column;gap:10px}.class-card-wrap .class-card{border-radius:12px}.class-card-note-btn{width:100%;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border:none;border-radius:14px;padding:13px 16px;font-size:14px;font-weight:700;cursor:pointer;text-align:center;transition:all .2s;letter-spacing:.2px;box-shadow:0 4px 14px #4f46e559}.class-card-note-btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px #4f46e573;background:linear-gradient(135deg,#4338ca,#6d28d9)}.item-card-btns{display:flex;gap:8px;flex-wrap:wrap;flex-shrink:0}.item-card-stack{flex-wrap:wrap}.item-card-stack .item-card-btns{width:100%}.dash-header--student{flex-wrap:wrap;align-items:flex-start;gap:0}.dash-header-desktop-brand,.dash-header-desktop-actions{display:flex}.mobile-student-header{display:none;width:100%}.mobile-student-row1{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;margin-bottom:10px}.mobile-student-name{display:flex;align-items:center;gap:6px;min-width:0;flex:1}.mobile-student-greet{font-weight:700;font-size:16px;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-profile-btn{flex-shrink:0}.mobile-student-row2{display:flex;align-items:center;flex-wrap:wrap;gap:8px;width:100%}.mobile-student-icon-btn{width:40px;height:40px;border-radius:50%;border:none;background:linear-gradient(135deg,#25d366,#128c7e);cursor:pointer;padding:0;flex-shrink:0;box-shadow:0 2px 8px #128c7e59}.mobile-student-icon-inner{font-size:1.15rem;line-height:1}@media (max-width: 768px){.dash-header--student{padding:12px 14px 14px;flex-direction:column}.dash-header-desktop-brand,.dash-header-desktop-actions{display:none!important}.mobile-student-header{display:block}.dash-top-actions-desktop{display:none!important}.dash-top-actions-mobile{display:flex!important}}.dash-top-actions-mobile{display:none;flex-wrap:wrap;gap:8px;margin-top:12px}@media (max-width: 600px){.dash-main,.class-main{padding:16px}.dash-header:not(.dash-header--student){padding:12px 16px;flex-wrap:wrap;gap:8px}.dash-user{flex-wrap:wrap;gap:6px}.dash-brand{font-size:18px}.classes-grid{grid-template-columns:1fr;gap:14px}.class-hero{flex-direction:column}.tabs{overflow-x:auto;gap:4px}.tab{white-space:nowrap;font-size:13px;padding:7px 12px}.item-card{flex-direction:column;align-items:stretch;gap:12px}.item-card-btns{flex-direction:row;flex-wrap:wrap}.item-card-btns .btn{flex:1;justify-content:center;min-width:0;font-size:12px;padding:7px 8px}}.classmate-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:14px;padding:4px 0 24px}.classmate-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #6366f11a;border:1.5px solid #e8eaf6;display:flex;flex-direction:column;align-items:center;gap:10px;padding:18px 12px 14px;cursor:pointer;transition:transform .18s,box-shadow .18s;text-align:center}.classmate-card:active{transform:scale(.97)}@media (hover: hover){.classmate-card:hover{transform:translateY(-3px);box-shadow:0 8px 28px #6366f12e}}.student-remove-btn{position:absolute;top:6px;right:6px;width:20px;height:20px;padding:0;font-size:10px;line-height:20px;text-align:center;border-radius:50%;border:1.5px solid #f5c6cb;background:#fff5f5;color:#c0392b;cursor:pointer;opacity:0;transition:opacity .18s,background .15s;z-index:2}.classmate-card--teacher:hover .student-remove-btn{opacity:1}.student-remove-btn:hover{background:#e74c3c;color:#fff;border-color:#e74c3c}.classmate-avatar{width:72px;height:72px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:3px solid #e8eaf6;box-shadow:0 2px 8px #0000001f}.classmate-initials{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:24px;box-shadow:0 2px 8px #00000026}.classmate-info{width:100%}.classmate-name{font-weight:700;font-size:13px;color:#1e293b;display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap;line-height:1.3;margin-bottom:5px}.cm-role-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:capitalize;letter-spacing:.3px}.cm-role-badge.student{background:#e0e7ff;color:#3730a3}.cm-role-badge.teacher{background:#d1fae5;color:#065f46}.cm-static-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#1d9bf0;color:#fff;font-size:10px;font-weight:900;flex-shrink:0;line-height:1}.cm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:2000;display:flex;align-items:flex-end;justify-content:center;padding:0;animation:cmFadeIn .2s ease}@keyframes cmFadeIn{0%{opacity:0}to{opacity:1}}.cm-modal{background:#fff;width:100%;max-width:480px;max-height:90vh;border-radius:24px 24px 0 0;overflow-y:auto;box-shadow:0 -8px 40px #0000002e;position:relative;animation:cmSlideUp .25s cubic-bezier(.22,1,.36,1)}@keyframes cmSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media (min-width: 600px){.cm-modal-overlay{align-items:center}.cm-modal{border-radius:24px;max-height:85vh}}.cm-modal-close{position:absolute;top:14px;right:16px;background:#f1f5f9;border:none;border-radius:50%;width:34px;height:34px;font-size:16px;cursor:pointer;color:#475569;display:flex;align-items:center;justify-content:center;z-index:10}.cm-modal-hero{text-align:center;padding:36px 24px 20px;background:linear-gradient(160deg,#667eea10,#764ba210);border-bottom:1px solid #f1f5f9}.cm-modal-avatar{width:96px;height:96px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:4px solid #fff;box-shadow:0 4px 18px #00000026;margin-bottom:12px}.cm-modal-initials{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:32px;margin:0 auto 12px;box-shadow:0 4px 18px #00000026}.cm-modal-name{font-size:20px;font-weight:800;color:#1e293b;margin-bottom:6px}.cm-modal-email{font-size:13px;color:#64748b;margin-top:6px}.cm-modal-body{padding:0 20px 4px}.cm-section{padding:16px 0;border-bottom:1px solid #f1f5f9}.cm-section:last-child{border-bottom:none}.cm-section-title{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#667eea;margin-bottom:10px}.cm-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px;font-size:14px;color:#374151}.cm-label{font-size:16px;flex-shrink:0}.cm-block{margin-bottom:10px}.cm-block .cm-label{font-size:12px;font-weight:700;color:#64748b;margin-bottom:5px}.cm-block p{margin:0;font-size:14px;color:#374151;line-height:1.5}.cm-tags{display:flex;flex-wrap:wrap;gap:6px}.cm-tag{background:#e0e7ff;color:#3730a3;border-radius:20px;padding:3px 12px;font-size:12px;font-weight:600}.cm-modal-footer{display:flex;gap:10px;padding:16px 20px 24px;border-top:1px solid #f1f5f9}.cm-modal-footer .btn{flex:1;justify-content:center}@media (max-width: 480px){.classmate-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.classmate-avatar,.classmate-initials{width:60px;height:60px;font-size:20px}.classmate-card{padding:14px 8px 12px}.classmate-name{font-size:12px}}.cat-panel{background:#fff;padding:20px;border-radius:10px;margin-bottom:20px;box-shadow:0 1px 6px #0000000f}.cat-panel h2{margin-top:0;font-size:18px}.cat-form-row{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}.cat-form-row label,.cat-form-grid label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:600}.cat-form-row select,.cat-form-row input,.cat-form-grid select,.cat-form-grid input{padding:8px 10px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px}.cat-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;align-items:end}.cat-table-wrap{overflow-x:auto}.cat-class-avg{margin-bottom:12px;color:#2563eb}.cat-marks-table{width:100%;min-width:920px;border-collapse:collapse;font-size:13px}.cat-marks-table th,.cat-marks-table td{padding:10px 8px;text-align:center;border-bottom:1px solid #e2e8f0}.cat-marks-table th:first-child,.cat-marks-table td.cat-name{text-align:left;position:sticky;left:0;background:#fff;font-weight:600;z-index:1}.cat-marks-table thead th{background:#f1f5f9;font-weight:700}.cat-marks-table tbody tr:nth-child(2n){background:#f8fafc}.cat-marks-table tbody tr:nth-child(2n) td.cat-name{background:#f8fafc}.cat-marks-table .cat-total,.cat-marks-table .cat-pct{font-weight:700}.cat-marks-table .cat-avg-row{background:#eff6ff;font-weight:700}.cat-marks-table .cat-avg-row td.cat-name{background:#eff6ff}.class-points-panel{margin-top:.5rem}.class-roster-toolbar,.class-roster-tools{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:1rem}.class-points-layout{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 900px){.class-points-layout.with-feed{grid-template-columns:1fr 300px}}.class-roster-grid{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:flex-start}.class-roster-card{display:flex;flex-direction:column;align-items:center;gap:6px;width:76px;cursor:pointer}.class-roster-card--selected .class-roster-avatar{outline:3px solid #667eea;outline-offset:2px}.class-roster-avatar{position:relative;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;box-shadow:0 2px 8px #00000026;border:2.5px solid #fff;transition:transform .15s}.class-roster-card:hover .class-roster-avatar{transform:scale(1.08)}.class-roster-avatar--whole{background:linear-gradient(135deg,#667eea,#764ba2);font-size:22px}.class-roster-avatar--group{background:#f8f9ff;color:#667eea;font-size:16px;border:2px dashed #c7d2fe}.class-roster-point-badge{position:absolute;top:-5px;right:-5px;min-width:22px;height:22px;border-radius:999px;background:#10b981;color:#fff;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.class-roster-name{font-size:11px;color:#374151;text-align:center;line-height:1.3;display:flex;align-items:center;gap:2px;justify-content:center}.class-points-feed{min-width:0}.class-points-feed--undone{opacity:.5}.class-points-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:50;display:flex;align-items:center;justify-content:center;padding:16px}.class-points-modal{background:#fff;border-radius:12px;padding:20px;width:min(400px,100%);max-height:90vh;overflow:auto;box-shadow:0 8px 32px #00000026}.class-skill-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.class-timer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#667eea,#764ba2);z-index:60;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.class-timer-display{font-size:64px;font-weight:800;font-variant-numeric:tabular-nums}.mobile-nav-text-btn{display:inline-flex;align-items:center;padding:0;border:none;background:none;font-size:14px;font-weight:600;color:#128c7e;text-decoration:none;cursor:pointer;font-family:inherit;white-space:nowrap}.mobile-nav-text-btn--muted{color:#54656f}.mobile-staff-header{display:none;width:100%}.mobile-staff-row2{gap:16px}.mobile-bottom-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:#fff;border-top:1px solid #e8eaed;padding:6px 4px calc(6px + env(safe-area-inset-bottom,0px));justify-content:space-around;align-items:stretch;box-shadow:0 -2px 12px #0000000f}.mobile-bottom-bar__btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-width:0;padding:6px 4px;border:none;background:none;color:#667781;text-decoration:none;cursor:pointer;font-family:inherit;border-radius:8px}.mobile-bottom-bar__btn--active{color:#075e54;background:#e7fce8}.mobile-bottom-bar__icon{font-size:20px;line-height:1}.mobile-bottom-bar__label{font-size:10px;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-donate-fab{display:none;position:fixed;z-index:9200;bottom:calc(64px + env(safe-area-inset-bottom,0px));right:14px}.mobile-staff-quick-bar{display:none;position:fixed;bottom:calc(56px + env(safe-area-inset-bottom,0px));left:0;right:0;z-index:99;padding:8px 10px;background:#fffffff5;border-top:1px solid #e8eaed;gap:8px;justify-content:space-between}.mobile-staff-quick-bar button{flex:1;border:1px solid #d1d5db;background:#fff;border-radius:20px;padding:8px 6px;font-size:11px;font-weight:600;color:#075e54;cursor:pointer;font-family:inherit}.student-wa-dashboard{background:#e5ddd5;min-height:100dvh}.student-wa-dashboard .dash-main{background:transparent;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px))}.wa-class-list{display:flex;flex-direction:column;gap:2px;margin-bottom:16px}.wa-class-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#fff;text-decoration:none;color:inherit;border-bottom:1px solid #f0f2f5;transition:background .15s}.wa-class-row:active{background:#f5f6f6}.wa-class-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0}.wa-class-body{flex:1;min-width:0}.wa-class-body strong{display:block;font-size:16px;color:#111b21;margin-bottom:2px}.wa-class-body span{font-size:13px;color:#667781;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wa-class-arrow{color:#aebac1;font-size:18px}.wa-search-bar{background:#fff;border-radius:8px;margin:0 0 8px;padding:8px 12px;font-size:14px;color:#667781;display:flex;align-items:center;gap:8px}.wa-invite-banner{background:#dcf8c6;border-radius:8px;padding:12px 14px;margin-bottom:12px;border:none;box-shadow:0 1px 2px #0000000f}.wa-invite-banner strong{color:#075e54;font-size:14px}.wa-invite-banner p{margin:4px 0 10px;font-size:13px;color:#3b4a54}.wa-invite-banner button{background:#25d366;color:#fff;border:none;padding:8px 16px;border-radius:20px;font-weight:600;font-size:13px;cursor:pointer}@media (max-width: 768px){.mobile-bottom-bar{display:flex}.mobile-donate-fab,.mobile-staff-header{display:block}.staff-hub-page .phub-header .dash-user{display:none!important}.staff-hub-page .phub-brand{display:none}.staff-hub-page .phub-header{flex-direction:column;align-items:stretch;padding:10px 14px 0;border:none;background:#f0f2f5}.staff-hub-page .phub-header .mobile-staff-header .mobile-student-greet{color:#1e293b}.staff-hub-page .phub-header .mobile-staff-header .mobile-nav-text-btn{color:#128c7e}.staff-hub-page .phub-header .mobile-staff-header .mobile-nav-text-btn--muted{color:#54656f}.mobile-staff-quick-bar{display:flex}.staff-hub-page .staff-hub-nav{bottom:0}.staff-hub-page .dash-main{padding-bottom:calc(120px + env(safe-area-inset-bottom,0px))}.student-wa-dashboard .dash-header-desktop-brand,.student-wa-dashboard .dash-header-desktop-actions{display:none!important}.student-wa-dashboard .dash-header--student{background:#128c7e;border:none;padding:10px 14px 12px}.student-wa-dashboard .mobile-student-greet{color:#fff}.student-wa-dashboard .mobile-nav-text-btn{color:#fff;background:#fff3;padding:6px 12px;border-radius:20px}.student-wa-dashboard .mobile-student-row2{gap:14px}.student-wa-dashboard .mobile-student-row2 .mobile-nav-text-btn--muted{color:#fffffff2;background:none;padding:0}.student-wa-dashboard .mobile-student-icon-btn{background:#ffffff40;box-shadow:none}.dash-top--hidden-mobile{display:none!important}}.student-wa-dashboard .dash-header--wa{background:#128c7e;border:none;color:#fff;padding:10px 20px;flex-wrap:wrap;align-items:center}.student-wa-dashboard .dash-header--wa .dash-brand{color:#fff;font-weight:700}.student-wa-dashboard .dash-user--wa{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.student-wa-dashboard .wa-header-name{color:#fff;font-weight:600;display:inline-flex;align-items:center;gap:4px}.student-wa-dashboard .wa-header-link{color:#fff;text-decoration:none;font-size:14px;font-weight:600;background:none;border:none;cursor:pointer;font-family:inherit}.student-wa-dashboard .wa-header-link--btn{opacity:.95}.student-wa-dashboard .wa-header-icon-btn{width:40px;height:40px;border-radius:50%;border:none;background:#fff3;cursor:pointer;font-size:1.1rem}.wa-chat-screen{background:#e5ddd5;min-height:50vh}.wa-section-title{font-size:13px;font-weight:700;color:#128c7e;text-transform:uppercase;letter-spacing:.04em;margin:16px 0 8px;padding:0 4px}.wa-section-hint{font-size:13px;color:#667781;padding:8px}.wa-toolbar-top{display:flex;justify-content:flex-end;margin-bottom:8px}.wa-pill-btn{border:none;background:#25d366;color:#fff;font-weight:600;font-size:13px;padding:8px 16px;border-radius:20px;cursor:pointer;font-family:inherit;text-decoration:none;display:inline-flex;align-items:center}.wa-pill-btn--outline{background:#fff;color:#075e54;border:1px solid #d1d5db}.wa-pill-btn--primary{background:#128c7e}.wa-announce-chip{background:#fff;border-radius:8px;padding:10px 12px;margin-bottom:8px;display:flex;justify-content:space-between;gap:8px;font-size:13px}.wa-empty-chat{background:#fff;border-radius:12px;padding:24px;text-align:center;color:#667781}.wa-class-avatar--mate{background:linear-gradient(135deg,#667eea,#764ba2)}.wa-class-meta{flex-shrink:0;text-align:right}.wa-class-time{font-size:11px;color:#667781}.wa-preview{color:#667781!important}.wa-class-header{background:#128c7e!important;color:#fff;display:flex;align-items:center;gap:12px;padding:10px 14px!important;border:none!important}.wa-back-btn{background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:4px 8px}.wa-class-header-title{flex:1;min-width:0}.wa-class-header-title strong{display:block;font-size:17px}.wa-class-header-title span{font-size:12px;opacity:.9}.wa-staff-class-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.staff-hub-page .phub-header{background:#128c7e;border:none}.staff-hub-page .phub-header .phub-logo,.staff-hub-page .phub-header .phub-sub,.staff-hub-page .phub-header .dash-user .btn,.staff-hub-page .phub-header .dash-user span{color:#fff}.staff-hub-page .phub-header .btn-secondary{background:#fff3;color:#fff;border:none}.staff-hub-page .phub-header .btn-logout{background:#ffffff38!important;color:#fff!important;border:1px solid rgba(255,255,255,.85)!important}.staff-hub-page .staff-hub-nav{background:#fff}.class-page.wa-theme{background:#e5ddd5;min-height:100dvh}@media (min-width: 769px){.mobile-donate-fab,.student-wa-dashboard .mobile-student-header{display:none!important}}.staff-wa-dashboard{background:#e5ddd5;min-height:100dvh}.staff-wa-dashboard .dash-main.wa-chat-screen{background:transparent}.staff-wa-dashboard .phub-header{background:#128c7e;border:none;color:#fff}.staff-wa-dashboard .phub-logo,.staff-wa-dashboard .phub-sub{color:#fff}.staff-wa-dashboard .dash-user .btn{border-color:#ffffff59;color:#fff}.wa-toolbar-top--staff{justify-content:flex-start}.wa-class-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.wa-class-row--mate{width:100%;border:none;cursor:pointer;font-family:inherit;text-align:left}.wa-announce-meta{display:block;font-size:11px;color:#667781;margin-top:4px}.wa-tools-panel{background:#fff;border-radius:12px;padding:14px;margin-bottom:16px;box-shadow:0 1px 2px #0000000f}.wa-tools-panel h2{font-size:17px;color:#075e54;margin:0 0 10px}.wa-chat-section{margin-top:8px}@media (max-width: 768px){.staff-wa-dashboard .staff-hub-nav{display:none}.staff-wa-dashboard .phub-header{flex-direction:column;align-items:stretch;padding:10px 14px 0;background:#128c7e}.staff-wa-dashboard .phub-brand{display:none}.staff-wa-dashboard .phub-header .dash-user{display:none!important}.staff-wa-dashboard .mobile-staff-header .mobile-student-greet,.staff-wa-dashboard .mobile-staff-header .mobile-nav-text-btn{color:#fff}.staff-wa-dashboard .mobile-staff-header .mobile-nav-text-btn--muted{color:#ffffffeb;background:none}.staff-wa-dashboard .dash-main{padding-bottom:calc(72px + env(safe-area-inset-bottom,0px))}.mobile-staff-quick-bar{display:none!important}}.student-dashboard-classic{background:#f5f6fa;min-height:100dvh}.student-dashboard-classic .dash-main{padding-bottom:calc(88px + env(safe-area-inset-bottom,0px))}.student-dashboard-classic .dash-header--student{background:#fff;border-bottom:1px solid #e8eaed}.student-dashboard-classic .mobile-student-greet{color:#1e293b}.mobile-student-header-actions{display:inline-flex;align-items:center;gap:6px;flex-shrink:0}.student-dashboard-classic .dash-header-desktop-actions .student-notif-bell-wrap{margin-right:4px}.student-dashboard-classic .mobile-nav-text-btn{color:#128c7e}.student-dashboard-classic .mobile-nav-text-btn--muted{color:#54656f}.student-parent-invite-banner{margin-bottom:1.25rem}.student-classmates-section{margin-top:2rem}.student-section-title{font-size:1.1rem;font-weight:700;color:#1a1a2e;margin:0 0 12px}.dean-fab-wrap{position:fixed;bottom:calc(76px + env(safe-area-inset-bottom,0px));right:16px;z-index:9000;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.dean-fab-label{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;border-radius:20px;padding:6px 14px;font-size:12px;font-weight:700;box-shadow:0 4px 18px #4f46e573;white-space:nowrap}.dean-fab-btn{width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:26px;cursor:pointer;box-shadow:0 6px 24px #4f46e580;display:flex;align-items:center;justify-content:center}.dean-fab-btn:hover{transform:scale(1.06)}@media (min-width: 769px){.dean-fab-wrap{bottom:24px}}.student-dashboard-classic .student-bottom-nav{display:flex!important}.student-dashboard-classic .dash-main{padding-bottom:calc(88px + env(safe-area-inset-bottom,0px));max-width:none;width:100%;margin:0;padding-left:16px;padding-right:16px;box-sizing:border-box}@media (min-width: 769px){.student-dashboard-classic .dash-main{padding-left:24px;padding-right:24px;padding-bottom:calc(96px + env(safe-area-inset-bottom,0px))}.student-dashboard-classic .dash-top-actions-desktop{display:flex!important}}.student-dash-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start}.student-desktop-quick-nav{display:none;flex-wrap:wrap;gap:8px;margin-bottom:1.25rem;padding:12px 14px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f}@media (min-width: 769px){.student-dashboard-classic .student-desktop-quick-nav{display:flex}}.student-desktop-quick-nav__btn{display:inline-flex;align-items:center;gap:6px;border:1px solid #e2e8f0;background:#f8fafc;border-radius:20px;padding:8px 14px;font-size:13px;font-weight:600;color:#334155;cursor:pointer;text-decoration:none;font-family:inherit}.student-desktop-quick-nav__btn:hover{background:#eef2ff;border-color:#c7d2fe;color:#4338ca}.student-announcement{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;border-radius:12px;padding:1rem 1.25rem;margin-bottom:.75rem;display:flex;justify-content:space-between;gap:1rem}.student-announcement p{margin:4px 0 0;font-size:14px;color:#374151}.student-dean-banner{margin-top:2rem;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#eef2ff,#faf5ff);border:1px solid #c7d2fe;border-radius:16px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem}.student-dean-banner strong{display:block;font-size:1.05rem;color:#312e81;margin-bottom:4px}.student-dean-banner p{margin:0;font-size:14px;color:#475569}.student-dashboard-classic .dean-fab-wrap,.student-dashboard-classic .dean-fab-wrap--global{display:none!important}@media (min-width: 769px){.student-dashboard-classic .mobile-donate-fab{bottom:24px}}.student-classes-section{margin-top:.5rem}.student-classes-heading{font-size:1.35rem;font-weight:800;color:#1a1a2e;margin:0 0 14px}@media (min-width: 769px){.student-classes-heading{display:none}}.student-dashboard-classic .classes-grid--square{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.student-dashboard-classic .class-card-wrap--square{display:flex;flex-direction:column;gap:0}.student-dashboard-classic .class-card--square{aspect-ratio:1;min-height:260px;justify-content:space-between;text-align:center;padding:16px 14px;border-radius:12px 12px 0 0}.student-dashboard-classic .class-card-icon{width:72px;height:72px;margin:0 auto 12px;border-radius:18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:30px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-dashboard-classic .class-card--square .class-card-header h3{font-size:16px;margin-bottom:4px}.student-dashboard-classic .class-card--square .class-code-display{padding:6px 10px;margin:4px 0}.student-dashboard-classic .class-card--square .code-value{font-size:16px;letter-spacing:2px}.student-dashboard-classic .class-card-wrap--square .class-card-note-btn{border-radius:0 0 12px 12px;margin-top:0}.staff-dashboard-classic .classes-grid--square{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}.staff-dashboard-classic .class-card--square{aspect-ratio:1;min-height:280px;text-align:center;padding:18px 14px;border-radius:12px;display:flex;flex-direction:column;justify-content:space-between;text-decoration:none;color:inherit}.staff-dashboard-classic .class-card-icon{width:88px;height:88px;margin:0 auto 12px;border-radius:20px;background:linear-gradient(135deg,#128c7e,#25d366);color:#fff;font-size:36px;font-weight:800;display:flex;align-items:center;justify-content:center}.csp-modal{background:#fff}.csp-title{margin:0 0 6px;color:#075e54;font-size:20px}.csp-sub{margin:0 0 14px;font-size:13px;color:#667781;line-height:1.45}.csp-muted{color:#667781;font-size:14px}.csp-active-card{background:linear-gradient(135deg,#e7fce8,#fff);border-radius:12px;padding:16px;border:1px solid #25d366}.csp-active-ring{font-size:28px;margin-bottom:8px}.csp-active-card h3{margin:0 0 8px;font-size:17px;color:#111b21}.csp-body{margin:0 0 10px;font-size:14px;line-height:1.5;color:#303030}.csp-read-more{border:none;background:none;color:#128c7e;font-weight:600;cursor:pointer;padding:0}.csp-meta{font-size:13px;color:#54656f;margin:0 0 12px}.csp-viewers{font-size:12px;margin-bottom:12px}.csp-viewers ul{margin:6px 0 0;padding-left:18px;color:#303030}.csp-viewers span{color:#667781}.csp-empty{text-align:center;padding:12px 0}.csp-pick-list{display:flex;flex-direction:column;gap:8px}.csp-pick-item{text-align:left;border:1px solid #e8eaed;border-radius:10px;padding:12px;background:#f0f2f5;cursor:pointer;font-family:inherit}.csp-pick-item strong{display:block;color:#111b21;margin-bottom:4px}.csp-pick-item span{font-size:12px;color:#667781}.csp-pick-type{display:block;text-transform:capitalize}.csp-empty-icon{font-size:36px;margin-bottom:8px}.csp-empty--pending{background:linear-gradient(180deg,#fffbeb,#fff);border-radius:12px;padding:8px}.csp-ready-banner{background:linear-gradient(135deg,#dcfce7,#ecfdf5);border:1px solid #86efac;border-radius:12px;padding:12px 14px;margin-bottom:12px}.csp-ready-banner p{margin:8px 0 0;font-size:13px;color:#166534;line-height:1.45}.csp-ready-badge{display:inline-block;background:#16a34a;color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:.02em}.csp-feed-section{margin:20px 0 28px;padding:18px 16px;border-radius:16px;background:linear-gradient(145deg,#f0fdf4,#fff 55%,#ecfeff);border:1px solid #bbf7d0;box-shadow:0 8px 24px #075e5414}.csp-feed-header h2{margin:0 0 6px;font-size:18px;color:#075e54}.csp-feed-header p{margin:0 0 14px;font-size:13px;color:#54656f;line-height:1.45}.csp-feed-list{display:flex;flex-direction:column;gap:10px}.csp-feed-card{background:#fff;border-radius:12px;border:1px solid #e8eaed;overflow:hidden}.csp-feed-card--locked{border-color:#fde68a;background:linear-gradient(180deg,#fffbeb,#fff)}.csp-feed-head{width:100%;display:flex;align-items:center;gap:12px;padding:12px 14px;border:none;background:transparent;cursor:pointer;font-family:inherit;text-align:left}.csp-feed-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#25d366,#128c7e);color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.csp-feed-meta{flex:1;min-width:0}.csp-feed-meta strong{display:block;color:#111b21;font-size:15px}.csp-feed-meta small{color:#667781;font-size:12px}.csp-feed-chevron{color:#128c7e;font-size:14px}.csp-feed-body{padding:0 14px 14px;border-top:1px solid #f0f2f5}.csp-feed-empty{text-align:center;padding:24px 12px;color:#54656f;font-size:14px}.csp-feed-empty-icon{font-size:32px;display:block;margin-bottom:8px}.csp-lock-panel{text-align:center;padding:12px 8px;border-radius:10px;background:linear-gradient(180deg,#fff7ed,#fff);border:1px dashed #fbbf24}.csp-lock-icon{font-size:28px;margin-bottom:6px}.csp-lock-teaser{font-size:13px;color:#78716c;font-style:italic;margin:8px 0 12px}.csp-subscribe-btn{width:100%;padding:12px 16px;border:none;border-radius:999px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;box-shadow:0 4px 14px #d9770659}.csp-subscribe-btn:disabled{opacity:.7;cursor:not-allowed}.csp-teacher-card--locked{border-color:#fde68a}.cm-page{max-width:none;width:100%;margin:0;padding:0 0 5rem;box-sizing:border-box}.cm-hero{position:relative;margin:0 0 1.25rem;padding:1.35rem 1.25rem 1.5rem;border-radius:22px;overflow:hidden;background:linear-gradient(145deg,#1e3a5f,#4f46e5 45%,#7c3aed);color:#fff;box-shadow:0 20px 50px #4f46e559,0 4px 16px #0f172a1f;cursor:pointer;border:1px solid rgba(255,255,255,.15);transition:transform .25s ease,box-shadow .25s ease}.cm-hero:hover,.cm-hero:focus-visible{transform:translateY(-2px);box-shadow:0 24px 56px #4f46e56b,0 8px 24px #0f172a26}.cm-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 85% 15%,rgba(255,255,255,.22),transparent 45%);pointer-events:none}.cm-hero-inner{position:relative;z-index:1}.cm-hero-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background:#ffffff2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:5px 12px;border-radius:999px;margin-bottom:10px}.cm-hero h2{margin:0 0 8px;font-size:1.35rem;font-weight:800;letter-spacing:-.02em;line-height:1.2}.cm-hero p{margin:0 0 14px;font-size:.9rem;line-height:1.5;color:#ffffffe0;max-width:28em}.cm-hero-cta{display:inline-flex;align-items:center;gap:8px;font-size:.88rem;font-weight:700;padding:10px 18px;border-radius:999px;background:#fffffff2;color:#3730a3;border:none;box-shadow:0 4px 14px #0000001f}.cm-fold{margin:0 0 1.25rem}.cm-fold--class-now{margin-top:1.25rem;padding-top:1rem;border-top:1px solid rgba(148,163,184,.35)}.student-class-now-under-classes{margin-top:.5rem}.cm-fold-body--class-now{display:flex;flex-direction:column;gap:14px}.cm-fold-inner-block{padding:14px;border-radius:14px;border:1px solid rgba(148,163,184,.35);background:#fff}.cm-fold-inner-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.cm-fold-inner-title{margin:0;font-size:.95rem;font-weight:700;color:#0f172a}.cm-fold-inner-muted{margin:0;font-size:.85rem;color:#64748b}.cm-fold-badge--amber{background:#f59e0b}.cm-fold-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.cm-fold-toggle{flex:1;min-width:0;display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:14px;border:1px solid rgba(148,163,184,.35);background:#f8fafc;cursor:pointer;text-align:left;color:#0f172a}.cm-fold-toggle:hover,.cm-fold-toggle:focus-visible{background:#f1f5f9;border-color:#4f46e559}.cm-fold-toggle-icon{font-size:12px;color:#64748b;flex-shrink:0}.cm-fold-toggle-text{display:flex;flex-direction:column;gap:2px;min-width:0}.cm-fold-title{font-size:.95rem;font-weight:700}.cm-fold-sub{font-size:.8rem;color:#64748b;font-weight:500}.cm-fold-badge{flex-shrink:0;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:#4f46e5;color:#fff}.cm-fold-open-link{font-size:.82rem;font-weight:600;padding:10px 14px;border-radius:12px;border:1px solid rgba(79,70,229,.35);background:#fff;color:#4338ca;cursor:pointer}.cm-fold-body{margin-top:12px}.cm-fold-hint{margin:0 0 10px;font-size:.8rem;color:#64748b;line-height:1.45}.cm-fold .cm-hero{margin-bottom:0}.cm-class-fold{margin:2rem 0 1rem;padding-top:1.25rem;border-top:1px dashed rgba(148,163,184,.45)}.cm-class-fold-toggle{width:100%;display:flex;align-items:flex-start;gap:10px;padding:12px 14px;border-radius:12px;border:1px solid rgba(148,163,184,.3);background:#f8fafc;cursor:pointer;text-align:left;color:#334155}.cm-class-fold-toggle strong{display:block;font-size:.9rem}.cm-class-fold-sub{display:block;font-size:.78rem;font-weight:500;color:#64748b;margin-top:2px}.cm-class-fold-body,.cm-class-fold-all{margin-top:12px}.cm-feed--compact{gap:1rem}.cm-feed--compact .cm-card{box-shadow:0 6px 20px #0f172a0f}.cm-feed{display:flex;flex-direction:column;gap:1.5rem}.cm-card{background:#ffffffeb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:20px;overflow:hidden;border:1px solid rgba(148,163,184,.25);box-shadow:0 12px 40px #0f172a14,0 2px 8px #0f172a0a;animation:cmFadeUp .45s ease both}@keyframes cmFadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.cm-card-header{display:flex;align-items:center;gap:12px;padding:14px 16px 10px}.cm-avatar{width:44px;height:44px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #fff;box-shadow:0 2px 8px #0000001a}.cm-meta{flex:1;min-width:0}.cm-teacher{font-weight:800;font-size:.95rem;color:#0f172a;margin:0}.cm-sub{font-size:.78rem;color:#64748b;margin:2px 0 0}.cm-card .cm-gallery{position:relative;width:100%;background:#0f172a}.cm-card .cm-gallery img{display:block;width:100%;max-height:420px;-o-object-fit:cover;object-fit:cover}.cm-gallery-dots{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:center;gap:6px}.cm-gallery-dots span{width:7px;height:7px;border-radius:50%;background:#ffffff73}.cm-gallery-dots span.active{background:#fff;width:20px;border-radius:4px}.cm-desc{padding:14px 16px 18px;font-size:.92rem;line-height:1.55;color:#334155;margin:0}.cm-empty{text-align:center;padding:3rem 1.5rem;color:#64748b}.cm-add-fab{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,0px));right:max(16px,env(safe-area-inset-right,0px));z-index:40;width:56px;height:56px;border-radius:50%;border:none;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;font-size:1.5rem;box-shadow:0 8px 28px #4f46e573;cursor:pointer}.cm-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;background:#0f172a8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:flex-end;justify-content:center;padding:0}@media (min-width: 640px){.cm-modal-overlay{align-items:center;padding:24px}}.cm-modal{width:100%;max-width:480px;max-height:92vh;overflow-y:auto;background:#fff;border-radius:24px 24px 0 0;padding:1.25rem 1.25rem 2rem;box-shadow:0 -8px 40px #00000026}@media (min-width: 640px){.cm-modal{border-radius:24px}}.cm-file-label{display:block;font-weight:600;font-size:14px;margin-bottom:4px}.cm-file-hint{margin:0 0 10px;font-size:12px;color:#64748b}.cm-file-input-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.cm-file-picker-btn{width:100%;min-height:44px;font-size:15px}.cm-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:12px 0}.cm-photo-thumb{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden}.cm-photo-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.cm-photo-remove{position:absolute;top:4px;right:4px;width:24px;height:24px;border-radius:50%;border:none;background:#0009;color:#fff;font-size:14px;cursor:pointer}.cm-staff-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:10px}.cm-staff-panel{background:linear-gradient(180deg,#f0f2f5,#e8eaed);border-radius:20px;padding:18px 16px 20px;margin-top:8px;border:1px solid rgba(0,0,0,.06);box-shadow:0 8px 32px #0f172a14}.cm-staff-panel .cm-staff-panel-head h2{color:#075e54!important}.cm-staff-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:1.25rem}.cm-staff-card-wrap{margin-bottom:0}.cm-delete-btn{margin-top:10px;max-width:480px;margin-left:auto;margin-right:auto;width:100%;border-radius:10px;font-size:13px}.cm-upload-status{margin:0 0 12px;padding:10px 14px;border-radius:12px;background:#4f46e514;color:#4338ca;font-size:14px;font-weight:600;animation:cm-pulse 1.2s ease-in-out infinite}@keyframes cm-pulse{0%,to{opacity:1}50%{opacity:.65}}.cm-card--pending,.cm-pending-badge{display:none!important}.cm-gallery-video,.cm-thumb-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;background:#0f172a}.cm-gallery .cm-gallery-video{min-height:220px;max-height:72vh;-o-object-fit:contain;object-fit:contain}.phub-moments-hero-wrap{padding:0 12px 8px;max-width:none;width:100%;margin:0;box-sizing:border-box}@media (min-width: 768px){.phub-moments-hero-wrap{padding:0 20px 12px}}@keyframes cmWaFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cm-wa-page.dashboard,.cm-soc-page.dashboard{min-height:100dvh;background:#f0f2f5;padding-bottom:5rem}.cm-wa-header-sub{margin:6px 0 0;font-size:12px;opacity:.92;font-weight:500}.cm-wa-header{background:#075e54;color:#fff;padding:12px 16px 14px;margin:0 -12px 12px;box-shadow:0 2px 8px #0000001f}.cm-wa-header h1{margin:8px 0 0;font-size:1.1rem;font-weight:700}.cm-wa-header .btn-secondary{background:#fff3;color:#fff;border:none}.cm-wa-feed-wrap{max-width:none;margin:0;width:100%}.cm-wa-feed{display:flex;flex-direction:column;gap:10px;padding-bottom:1rem}.cm-wa-row{display:flex;align-items:flex-start;gap:8px;animation:cmWaFade .35s ease both}.cm-wa-row--pending{opacity:.95}.cm-wa-row--pending .cm-wa-bubble{box-shadow:0 0 0 1px #25d36659}.cm-wa-avatar{width:36px;height:36px;border-radius:50%;-o-object-fit:cover;object-fit:cover;flex-shrink:0;margin-top:2px;box-shadow:0 1px 3px #00000026}.cm-wa-col{flex:1;min-width:0;max-width:min(340px,calc(100% - 44px))}.cm-wa-pending-chip{position:absolute;top:8px;right:8px;z-index:2;font-size:10px;font-weight:700;padding:4px 8px;border-radius:999px;background:#075e54d9;color:#fff}.cm-wa-bubble{position:relative;background:#fff;border-radius:0 12px 12px;box-shadow:0 1px 2px #00000014;overflow:hidden;width:100%;max-width:min(300px,100%);min-width:0}.cm-wa-bubble-head{padding:8px 12px 4px;display:flex;flex-direction:column;gap:2px}.cm-wa-name{font-size:13px;font-weight:700;color:#075e54}.cm-wa-meta{font-size:11px;color:#667781}.cm-wa-media{position:relative;background:#0b141a;overflow:hidden;width:100%;max-width:100%;line-height:0}.cm-wa-media[role=button]{cursor:pointer}.cm-wa-media img,.cm-wa-media video,.cm-wa-video{display:block;width:100%;max-width:100%;height:auto;max-height:min(280px,52vh);-o-object-fit:cover;object-fit:cover;background:#0b141a}.cm-wa-dots{position:absolute;bottom:10px;left:0;right:0;display:flex;justify-content:center;gap:5px}.cm-wa-dots span{width:6px;height:6px;border-radius:50%;background:#ffffff73}.cm-wa-dots span.active{background:#fff;width:18px;border-radius:4px}.cm-wa-caption{margin:0;padding:10px 12px 12px;font-size:14px;line-height:1.45;color:#111b21;white-space:pre-wrap;word-break:break-word}.cm-wa-reactions{margin-top:4px;padding-left:2px}.cm-wa-reaction-summary{display:inline-flex;align-items:center;gap:4px;background:#fff;border-radius:999px;padding:2px 8px 2px 4px;margin-bottom:6px;box-shadow:0 1px 3px #0000001a;font-size:12px}.cm-wa-reaction-emojis{font-size:14px;letter-spacing:-2px}.cm-wa-reaction-count{color:#667781;font-weight:600}.cm-wa-reaction-bar{display:flex;gap:8px}.cm-wa-react-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:999px;background:#ffffffeb;color:#54656f;font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 1px 2px #00000014}.cm-wa-react-btn:hover:not(:disabled){background:#fff}.cm-wa-react-btn.active{color:#075e54;background:#dcf8c6}.cm-wa-react-btn:disabled{opacity:.55;cursor:not-allowed}.cm-wa-react-icon{font-size:18px;line-height:1}.cm-wa-emoji-picker{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;padding:8px 10px;background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001f;max-width:280px}.cm-wa-emoji-picker button{width:40px;height:40px;border:none;border-radius:50%;background:transparent;font-size:22px;cursor:pointer}.cm-wa-emoji-picker button:hover{transform:scale(1.15);background:#f0f2f5}.cm-wa-emoji-picker button.active{background:#dcf8c6}.cm-wa-empty{text-align:center;padding:3rem 1.25rem;color:#54656f;font-size:14px;line-height:1.5}.cm-wa-empty-icon{font-size:2.5rem;margin:0 0 10px}.cm-wa-empty--demo{max-width:420px;margin:0 auto}.cm-wa-demo-bubble{background:#fff;border-radius:0 12px 12px;padding:10px 12px;margin:0 auto 16px;max-width:200px;box-shadow:0 1px 2px #00000014;opacity:.55}.cm-wa-demo-line{height:8px;border-radius:4px;background:#e9edef;margin-bottom:8px}.cm-wa-demo-line--short{width:55%}.cm-wa-demo-photo{height:72px;border-radius:8px;background:linear-gradient(135deg,#dcf8c6,#b8e994);margin-bottom:8px}.cm-wa-empty-text{text-align:center;padding:0 8px}.cm-wa-empty-text p{margin:0 0 8px}.cm-fab{position:fixed;bottom:calc(72px + env(safe-area-inset-bottom,0px));right:max(16px,env(safe-area-inset-right,0px));z-index:40;width:56px;height:56px;border-radius:50%;border:none;background:#25d366;color:#fff;font-size:2rem;line-height:1;font-weight:300;box-shadow:0 6px 20px #25d36673;cursor:pointer}.cm-fab:disabled{background:#94a3b8;cursor:not-allowed;box-shadow:none}@media (min-width: 768px){.cm-fab{bottom:24px}}.cm-fold-tabs{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.cm-fold-tabs button{flex:1;min-width:120px;padding:10px 12px;border-radius:12px;border:1px solid rgba(148,163,184,.4);background:#fff;font-size:.85rem;font-weight:600;cursor:pointer;color:#475569}.cm-fold-tabs button.active{background:#4f46e5;color:#fff;border-color:#4f46e5}.cm-soc-feed-wrap,.cm-wa-feed-wrap{max-width:none;margin:0;width:100%;padding:4px 0 12px}.cm-soc-feed,.cm-wa-feed{display:flex;flex-direction:column;gap:14px}@keyframes cmSocIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cm-soc-post{background:#fff;border-radius:16px;box-shadow:0 1px 2px #0000000f,0 4px 16px #0000000f;border:1px solid rgba(0,0,0,.06);overflow:hidden;animation:cmSocIn .4s ease both;max-width:100%}.cm-soc-post--pending{position:relative}.cm-soc-post--pending:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 40%,rgba(37,211,102,.08) 50%,transparent 60%);animation:cmSocShimmer 1.4s ease-in-out infinite;pointer-events:none;border-radius:inherit}@keyframes cmSocShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.cm-soc-post__head{display:flex;align-items:center;gap:12px;padding:14px 14px 10px}.cm-soc-avatar{width:44px;height:44px;border-radius:50%;-o-object-fit:cover;object-fit:cover;flex-shrink:0;border:2px solid #fff;box-shadow:0 2px 8px #0000001f}.cm-soc-post__meta{flex:1;min-width:0}.cm-soc-post__name{display:block;font-size:15px;font-weight:700;color:#050505;line-height:1.25}.cm-soc-post__sub{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:4px}.cm-soc-pill{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;background:linear-gradient(135deg,#dcf8c6,#b8e994);color:#075e54;letter-spacing:.02em}.cm-soc-time{font-size:12px;color:#65676b;font-weight:500}.cm-soc-sending{flex-shrink:0;font-size:11px;font-weight:700;padding:5px 10px;border-radius:999px;background:#075e54;color:#fff}.cm-soc-post__media-wrap{padding:0 12px 12px}.cm-soc-post__media{position:relative;border-radius:14px;overflow:hidden;background:#0b141a;max-width:100%;box-shadow:inset 0 0 0 1px #ffffff14,0 4px 20px #00000026}.cm-soc-media-el{display:block;width:100%!important;max-width:100%!important;height:auto!important;max-height:min(320px,50vh)!important;-o-object-fit:cover;object-fit:cover;vertical-align:top}.cm-soc-media-badge{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;padding:4px 10px;border-radius:999px;background:#0000008c;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.cm-soc-dots{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:center;gap:6px}.cm-soc-dots span{width:7px;height:7px;border-radius:50%;background:#ffffff73;transition:width .2s ease,background .2s ease}.cm-soc-dots span.active{background:#fff;width:20px;border-radius:6px}.cm-soc-post__caption{margin:0;padding:0 16px 14px;font-size:15px;line-height:1.45;color:#050505;white-space:pre-wrap;word-break:break-word}.cm-soc-post__footer{border-top:1px solid #e4e6eb;padding:6px 10px 10px;background:#fafbfc}.cm-soc-reactions{width:100%}.cm-soc-reaction-tally{display:flex;align-items:center;gap:6px;padding:4px 8px 8px;font-size:13px;color:#65676b}.cm-soc-reaction-tally__icons{font-size:15px;letter-spacing:-3px}.cm-soc-reaction-tally__count{font-weight:600}.cm-soc-action-bar{display:flex;gap:4px}.cm-soc-action{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 8px;border:none;border-radius:10px;background:transparent;color:#65676b;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease}.cm-soc-action:hover:not(:disabled){background:#f0f2f5}.cm-soc-action--active{color:#e0245e;background:#fff0f3}.cm-soc-action__icon{font-size:18px;line-height:1}.cm-soc-emoji-tray{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;padding:10px 12px;background:#fff;border-radius:14px;border:1px solid #e4e6eb;box-shadow:0 6px 20px #0000001a}.cm-soc-emoji-tray button{width:42px;height:42px;border:none;border-radius:50%;background:#f0f2f5;font-size:22px;cursor:pointer;transition:transform .15s ease,background .15s ease}.cm-soc-emoji-tray button:hover{transform:scale(1.12);background:#e4e6eb}.cm-soc-emoji-tray button.active{background:#dcf8c6;box-shadow:0 0 0 2px #25d366}.cm-staff-panel img.cm-soc-media-el,.cm-soc-feed-wrap img.cm-soc-media-el,.cm-wa-page img.cm-soc-media-el{max-height:min(320px,50vh)!important}.app-wa-shell .dash-main .cm-soc-post{max-width:480px;margin-left:auto;margin-right:auto}.cm-dash-block{display:flex;flex-direction:column;gap:1rem;margin:0 0 1.25rem}.cm-dash-open-all{align-self:flex-start}.cm-online-strip{display:flex;flex-direction:column;gap:10px;padding:12px 14px;background:#fff;border-radius:14px;border:1px solid #e4e6eb;box-shadow:0 2px 8px #0000000a}.cm-online-strip--empty{flex-direction:row;align-items:center;gap:10px;font-size:13px;color:#65676b}.cm-online-strip-head{display:flex;align-items:center;gap:8px;font-size:14px}.cm-online-dot{width:8px;height:8px;border-radius:50%;background:#bcc0c4;flex-shrink:0}.cm-online-dot--live{background:#25d366;box-shadow:0 0 0 3px #25d36640;animation:cm-online-pulse 2s ease-in-out infinite}@keyframes cm-online-pulse{0%,to{opacity:1}50%{opacity:.65}}.cm-online-count{font-size:12px;font-weight:700;color:#128c7e;background:#e8f5e9;padding:2px 8px;border-radius:999px}.cm-online-avatars{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.cm-online-person{display:flex;flex-direction:column;align-items:center;gap:4px;max-width:56px}.cm-online-avatar{width:44px;height:44px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #25d366;background:#f0f2f5}.cm-online-name{font-size:10px;font-weight:600;color:#050505;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.cm-online-more{font-size:12px;font-weight:700;color:#65676b;padding-bottom:6px}.cm-learn-section{padding:0 2px}.cm-learn-head h3{margin:0 0 6px;font-size:1.05rem;color:#075e54}.cm-learn-head p{margin:0 0 12px;font-size:13px;color:#65676b;line-height:1.45}.cm-learn-empty{font-size:13px;color:#65676b;padding:12px;background:#f7f8fa;border-radius:12px}.cm-learn-more{margin-top:10px}.cm-shared-section{padding:12px 14px;background:linear-gradient(135deg,#f8f9ff,#fff);border-radius:14px;border:1px solid #e4e6eb}.cm-shared-head{margin:0 0 4px;font-size:1rem;color:#050505}.cm-shared-sub{margin:0 0 12px;font-size:12px;color:#65676b;line-height:1.4}.cm-shared-cards{display:flex;flex-direction:column;gap:10px}.cm-shared-card{display:flex;gap:12px;text-align:left;padding:10px;border-radius:12px;border:1px solid #e4e6eb;background:#fff;cursor:pointer;transition:box-shadow .15s ease}.cm-shared-card:hover{box-shadow:0 4px 16px #00000014}.cm-shared-card-img{flex:0 0 72px;width:72px;height:72px;border-radius:10px;overflow:hidden;background:#f0f2f5}.cm-shared-card-img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.cm-shared-card-body{flex:1;min-width:0}.cm-shared-by{display:block;font-size:11px;font-weight:700;color:#128c7e;margin-bottom:4px}.cm-shared-caption{margin:0;font-size:13px;color:#050505;line-height:1.4}.cm-soc-action--share{margin-left:auto}.iny-student-wrap,.iny-teacher-wrap{padding:8px 0 24px}.iny-intro{font-size:14px;color:#64748b;line-height:1.5;margin:0 0 20px;max-width:720px}.iny-loading,.iny-empty-state{text-align:center;padding:32px 16px;color:#94a3b8}.iny-empty-icon{font-size:48px;margin-bottom:8px}.iny-student-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}.iny-panel{background:#fff;border-radius:14px;padding:18px 16px;box-shadow:0 2px 12px #00000012;border-top:4px solid #667eea;min-height:280px}.iny-panel--marks{border-top-color:#27ae60}.iny-panel-title{margin:0 0 6px;font-size:16px;font-weight:800;color:#1e293b}.iny-panel-desc{margin:0 0 14px;font-size:12px;color:#94a3b8;line-height:1.4}.iny-upload-box{margin-bottom:14px}.iny-file-input{display:none}.iny-upload-btn{width:100%;font-size:13px}.iny-upload-hint{margin:8px 0 0;font-size:11px;color:#94a3b8}.iny-empty{font-size:13px;color:#94a3b8;margin:12px 0}.iny-doc-view{margin-top:8px}.iny-doc-frame{width:100%;height:220px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc}.iny-doc-image{max-width:100%;max-height:220px;border-radius:8px;border:1px solid #e2e8f0;-o-object-fit:contain;object-fit:contain}.iny-doc-link,.iny-download-btn{display:inline-block;margin-top:8px;font-size:12px}.iny-doc-filename{font-size:13px;font-weight:600;color:#334155}.iny-delete-btn{margin-top:10px;background:none;border:none;color:#dc2626;font-size:12px;cursor:pointer;padding:0;text-decoration:underline}.iny-report-list{list-style:none;margin:0 0 12px;padding:0}.iny-report-item{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #f1f5f9;font-size:13px}.iny-report-link{flex:1;min-width:120px;color:#2563eb;font-weight:600;text-decoration:none}.iny-report-link:hover{text-decoration:underline}.iny-report-date{font-size:11px;color:#94a3b8}.iny-report-preview{margin-top:12px;padding-top:12px;border-top:1px dashed #e2e8f0}.iny-quiz-table-wrap{overflow-x:auto}.iny-quiz-table{width:100%;border-collapse:collapse;font-size:13px}.iny-quiz-table th,.iny-quiz-table td{padding:10px 8px;text-align:left;border-bottom:1px solid #f1f5f9}.iny-quiz-table th{font-size:11px;text-transform:uppercase;color:#64748b;letter-spacing:.4px}.iny-quiz-pending td{color:#94a3b8}.iny-quiz-pct{display:inline-block;padding:2px 8px;border-radius:999px;background:#dcfce7;color:#166534;font-weight:700;font-size:12px}.iny-teacher-list{display:flex;flex-direction:column;gap:12px}.iny-teacher-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 10px #0000000f}.iny-teacher-card h4{margin:0 0 10px;font-size:15px;color:#1e293b}.iny-teacher-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;font-size:13px}.iny-teacher-grid strong{display:block;margin-bottom:6px;color:#64748b;font-size:11px;text-transform:uppercase}.iny-teacher-link{display:block;color:#2563eb;margin-bottom:4px;text-decoration:none}.iny-muted{color:#cbd5e1}@media (max-width: 960px){.iny-student-grid{grid-template-columns:1fr}.iny-panel{min-height:auto}}@media (max-width: 600px){.iny-teacher-grid{grid-template-columns:1fr}}.iny-dash{margin-bottom:24px}.iny-dash-header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;margin-bottom:16px}.iny-dash-title{margin:0 0 6px;font-size:1.25rem;color:#075e54}.iny-dash-sub{margin:0;font-size:14px;color:#64748b;line-height:1.5;max-width:560px}.iny-dash-stats{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:#475569}.iny-dash-stats strong{color:#075e54}.iny-dash-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.iny-dash-select,.iny-dash-search{border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;font-size:14px;background:#fff}.iny-dash-select{min-width:200px}.iny-dash-search{flex:1;min-width:180px}.iny-dash-empty{text-align:center;padding:32px 16px;color:#94a3b8;background:#f8fafc;border-radius:12px}.iny-dash-class{margin-bottom:24px}.iny-dash-class-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #ecfdf5}.iny-dash-class-head h3{margin:0 0 4px;font-size:17px;color:#1e293b}.iny-dash-subject{display:inline-block;margin-right:8px;font-size:12px;color:#64748b;background:#f1f5f9;border-radius:999px;padding:2px 10px}.iny-dash-code{font-size:12px;color:#94a3b8}.iny-dash-class-link{font-size:13px;font-weight:600;color:#2563eb;text-decoration:none;white-space:nowrap}.iny-dash-student-list{display:flex;flex-direction:column;gap:8px}.iny-dash-student{background:#fff;border-radius:12px;box-shadow:0 1px 8px #0000000f;overflow:hidden}.iny-dash-student-toggle{width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:14px 16px;border:none;background:#fff;cursor:pointer;text-align:left}.iny-dash-student-name{font-weight:700;font-size:15px;color:#1e293b;min-width:120px}.iny-dash-badges{display:flex;flex-wrap:wrap;gap:6px;flex:1}.iny-dash-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;background:#f1f5f9;color:#64748b}.iny-dash-badge.ok{background:#ecfdf5;color:#047857}.iny-dash-badge.missing{background:#fff7ed;color:#c2410c}.iny-dash-chevron{font-size:11px;color:#94a3b8}.iny-dash-student-body{padding:0 16px 16px;border-top:1px solid #f1f5f9}.iny-dash-student-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding-top:14px}.iny-doc-frame--compact{height:160px}.iny-doc-image--compact{max-height:160px}@media (max-width: 960px){.iny-dash-student-grid{grid-template-columns:1fr}}@media (max-width: 600px){.iny-dash-student-toggle{flex-direction:column;align-items:flex-start}.iny-dash-chevron{align-self:flex-end}}.qr-wizard-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:6000;background:linear-gradient(145deg,#6366f159,#ec489947);display:flex;align-items:flex-end;justify-content:center;padding:12px;animation:qrFadeIn .35s ease}@keyframes qrFadeIn{0%{opacity:0}to{opacity:1}}.qr-wizard{width:100%;max-width:520px;max-height:92vh;overflow-y:auto;border-radius:28px 28px 20px 20px;background:linear-gradient(180deg,#fff,#fdf4ff);box-shadow:0 24px 80px #4f46e559;animation:qrSlideUp .4s cubic-bezier(.34,1.4,.64,1)}@keyframes qrSlideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.qr-hero{padding:24px 22px 18px;background:linear-gradient(135deg,#4f46e5,#7c3aed 45%,#ec4899);color:#fff;border-radius:28px 28px 0 0;text-align:center}.qr-hero-emoji{font-size:42px;line-height:1;margin-bottom:8px}.qr-hero h2{margin:0 0 6px;font-size:22px;font-weight:800}.qr-hero p{margin:0;font-size:14px;opacity:.92}.qr-score-pill{display:inline-block;margin-top:12px;padding:6px 16px;border-radius:999px;background:#ffffff38;font-weight:700;font-size:15px}.qr-body{padding:20px 18px 24px}.qr-section{margin-bottom:22px}.qr-section-title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#6366f1;margin:0 0 10px;display:flex;align-items:center;gap:8px}.qr-subject-chip{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:14px;background:linear-gradient(135deg,#eef2ff,#fce7f3);color:#4338ca;font-weight:700;font-size:14px;margin-bottom:14px}.qr-member-card{border:2px solid #e9d5ff;border-radius:18px;padding:14px;margin-bottom:12px;background:#fff;transition:border-color .2s,box-shadow .2s}.qr-member-card--weak{border-color:#fbbf24;background:linear-gradient(180deg,#fffbeb,#fff);box-shadow:0 4px 16px #fbbf2426}.qr-member-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.qr-member-name{font-weight:800;font-size:16px;color:#1e293b}.qr-member-leader{font-size:11px;color:#7c3aed;font-weight:700}.qr-grade-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.qr-grade-btn{border:2px solid #e2e8f0;background:#f8fafc;border-radius:12px;padding:8px 12px;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s}.qr-grade-btn--active{border-color:#8b5cf6;background:linear-gradient(135deg,#ede9fe,#fce7f3);color:#5b21b6;transform:scale(1.03)}.qr-weak-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:#b45309;font-weight:600;margin-bottom:8px;cursor:pointer}.qr-textarea,.qr-input{width:100%;border:2px solid #e2e8f0;border-radius:12px;padding:12px 14px;font-size:14px;font-family:inherit;resize:vertical;min-height:72px;box-sizing:border-box}.qr-textarea:focus,.qr-input:focus{outline:none;border-color:#a78bfa;box-shadow:0 0 0 3px #a78bfa40}.qr-crown-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.qr-crown-btn{border:2px solid #e2e8f0;border-radius:14px;padding:12px;text-align:left;background:#fff;cursor:pointer}.qr-crown-btn--active{border-color:#ec4899;background:linear-gradient(135deg,#fdf2f8,#ede9fe)}.qr-wear-btn{width:100%;border:none;border-radius:16px;padding:16px 20px;font-size:17px;font-weight:800;color:#fff;cursor:pointer;background:linear-gradient(135deg,#6366f1,#a855f7,#ec4899);box-shadow:0 8px 28px #6366f173;margin-top:8px}.qr-wear-btn:disabled{opacity:.65;cursor:not-allowed}.qr-skip{display:block;width:100%;margin-top:10px;background:none;border:none;color:#64748b;font-size:13px;cursor:pointer;text-decoration:underline}.qr-popup-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:7000;background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:20px}.qr-teacher-popup{max-width:420px;width:100%;border-radius:24px;background:linear-gradient(180deg,#fff,#f0fdf4);padding:26px 22px;box-shadow:0 20px 60px #10b98140;text-align:center}.qr-teacher-popup h3{margin:0 0 8px;font-size:20px;color:#065f46}.qr-teacher-bubble{text-align:left;margin:16px 0;padding:16px;border-radius:16px;background:#fff;border-left:5px solid #10b981;font-size:15px;line-height:1.55;color:#334155}.qr-report-list{display:flex;flex-direction:column;gap:14px}.qr-report-card{border-radius:18px;padding:16px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 12px #0000000a}.qr-report-card--unread{border-color:#86efac;background:linear-gradient(180deg,#f0fdf4,#fff)}.qr-teacher-panel-card{border-radius:16px;border:1px solid #e2e8f0;padding:16px;margin-bottom:14px;background:#fff}.qr-teacher-reply-box{margin-top:12px}.ach-celebrate-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:6000;background:#0f172aa6;display:flex;align-items:center;justify-content:center;padding:16px}.ach-celebrate-modal{width:100%;max-width:420px;background:linear-gradient(160deg,#1e1b4b,#312e81 40%,#4f46e5);color:#fff;border-radius:20px;padding:24px 20px;text-align:center;box-shadow:0 24px 80px #4f46e573;animation:ach-pop .35s ease}@keyframes ach-pop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.ach-celebrate-confetti{font-size:28px;margin-bottom:8px}.ach-celebrate-modal h2{margin:0 0 8px;font-size:22px}.ach-celebrate-score{margin:0 0 12px;font-size:15px;opacity:.95}.ach-celebrate-hint{margin:0 0 16px;font-size:13px;line-height:1.5;opacity:.88}.ach-title-pick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.ach-title-pick{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px;border-radius:14px;border:2px solid rgba(255,255,255,.25);background:#ffffff1a;color:#fff;cursor:pointer;transition:transform .15s,border-color .15s,background .15s}.ach-title-pick:hover{transform:translateY(-2px);background:#ffffff2e}.ach-title-pick--active{background:#ffffff38;transform:scale(1.03)}.ach-title-pick-emoji{font-size:32px}.ach-title-pick-label{font-size:11px;font-weight:700;line-height:1.2}.ach-celebrate-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.ach-celebrate-foot{margin:14px 0 0;font-size:11px;opacity:.75}.ach-displayed-crown{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;padding:2px 8px;border-radius:999px;background:#fef3c7;color:#92400e;white-space:nowrap}.lb-wrapper{padding:20px 0}.lb-hero{text-align:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;padding:32px 24px;margin-bottom:28px;box-shadow:0 8px 30px #667eea4d}.lb-trophy{font-size:64px;line-height:1;margin-bottom:10px}.lb-winner-name{font-size:28px;font-weight:800;margin-bottom:4px;letter-spacing:.5px}.lb-winner-score{font-size:18px;opacity:.9;margin-bottom:16px}.lb-kinyarwanda{background:#ffffff2e;border-radius:10px;padding:12px 20px;font-size:16px;line-height:1.5;margin-bottom:16px}.lb-badge-row{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-top:8px}.lb-badge{display:inline-flex;align-items:center;gap:5px;padding:5px 14px;border-radius:20px;border:2px solid white;background:#fff3;font-size:13px;font-weight:600;color:#fff}.lb-table-wrap{overflow-x:auto;border-radius:12px;box-shadow:0 2px 10px #00000014}.lb-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden}.lb-table thead tr{background:#f5f6fa}.lb-table th,.lb-table td{padding:13px 16px;text-align:left;font-size:14px;border-bottom:1px solid #f0f0f0}.lb-table th{font-weight:700;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.lb-top-row td{font-weight:700;background:#fffdf0}.lb-self-row td{font-weight:600;background:#f0fdf4}.lb-pct{display:inline-block;padding:3px 10px;border-radius:20px;color:#fff;font-weight:700;font-size:13px}.lb-loading,.lb-empty{text-align:center;padding:40px;color:#aaa;font-size:15px}.lb-comp-winner-card{margin-top:10px;background:linear-gradient(135deg,#0ea5e9,#0284c7);color:#fff;border-radius:14px;padding:16px 18px;box-shadow:0 8px 24px #0284c747}.lb-comp-winner-top{font-size:12px;text-transform:uppercase;letter-spacing:.8px;opacity:.9}.lb-comp-winner-name{font-size:24px;font-weight:800;margin-top:6px}.lb-comp-winner-meta{margin-top:4px;font-size:14px;opacity:.95}.lb-comp-winner-reward{margin-top:10px;font-weight:700;font-size:13px;background:#ffffff2e;border-radius:999px;display:inline-block;padding:6px 12px}.lb-reward-pill{display:inline-block;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:700}.lb-reward-on{background:#dcfce7;color:#166534}.lb-reward-off{background:#fee2e2;color:#991b1b}.lb-section-title{font-size:15px;font-weight:700;color:#444;margin-bottom:14px;padding-bottom:6px;border-bottom:2px solid #f0f0f0}.lb-per-quiz{margin-bottom:8px}.lb-quiz-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:8px}.lb-quiz-card{background:#fff;border-radius:12px;padding:14px 16px;box-shadow:0 2px 10px #00000014;border-top:4px solid #f39c12;display:flex;flex-direction:column;gap:6px}.lb-quiz-card-title{font-size:12px;color:#888;font-weight:600;text-transform:uppercase;letter-spacing:.3px;line-height:1.3}.lb-quiz-card-winner{display:flex;align-items:center;gap:6px}.lb-quiz-trophy{font-size:20px}.lb-quiz-name{font-size:15px;font-weight:800;color:#1a1a2e}.lb-quiz-score{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;color:#555}.lb-quiz-pct{display:inline-block;padding:2px 9px;border-radius:20px;color:#fff;font-weight:700;font-size:12px}@media (max-width: 600px){.lb-hero{padding:22px 14px;border-radius:12px}.lb-trophy{font-size:44px}.lb-winner-name{font-size:20px}.lb-winner-score{font-size:15px}.lb-kinyarwanda{font-size:13px;padding:10px 12px}.lb-quiz-cards{grid-template-columns:1fr 1fr;gap:8px}.lb-quiz-card{padding:10px 12px}.lb-quiz-card-title{font-size:11px}.lb-quiz-name{font-size:13px}.lb-table th,.lb-table td{padding:10px;font-size:12px}.lb-section-title{font-size:13px}.lb-comp-winner-name{font-size:18px}.lb-comp-winner-meta{font-size:12px}}@media (max-width: 380px){.lb-quiz-cards{grid-template-columns:1fr}}.lb-tabs{display:flex;justify-content:center;margin-bottom:20px;gap:10px}.lb-tab{padding:10px 20px;border:none;background:#f0f0f0;color:#666;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.lb-tab.active{background:#667eea;color:#fff}.lb-tab:hover{background:#e0e0e0}.lb-tab.active:hover{background:#5a6fd8}.lb-composition-list{display:flex;flex-direction:column;gap:12px}.lb-composition-item{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 10px #00000014;display:flex;align-items:center;gap:16px}.lb-comp-rank{font-size:24px;font-weight:700;color:#666;min-width:40px;text-align:center}.lb-comp-content{flex:1}.lb-comp-title{font-size:18px;font-weight:700;color:#1a1a2e;margin-bottom:4px}.lb-comp-author{font-size:14px;color:#888;margin-bottom:4px}.lb-comp-score{font-size:14px;font-weight:600;color:#27ae60;margin-bottom:4px}.lb-comp-date{font-size:12px;color:#aaa}.classroom-feed{margin-top:.5rem}.feed-composer{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem;margin-bottom:1.25rem}.feed-type-row{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.75rem}.feed-type-btn{border:1px solid #cbd5e1;background:#fff;border-radius:20px;padding:.35rem .75rem;font-size:.8rem;cursor:pointer}.feed-type-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.feed-textarea,.feed-input{width:100%;border:1px solid #cbd5e1;border-radius:8px;padding:.6rem;margin-bottom:.5rem;font-family:inherit}.feed-photo-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.feed-file-name{font-size:.85rem;color:#166534;font-weight:600}.feed-composer-actions{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.feed-readonly-hint{color:#64748b;font-size:.9rem;margin-bottom:1rem}.feed-empty{color:#94a3b8;text-align:center;padding:2rem}.feed-list{display:flex;flex-direction:column;gap:1rem}.feed-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1rem}.feed-card-head{margin-bottom:.5rem}.feed-meta{display:block;font-size:.75rem;color:#64748b;font-weight:400}.feed-summary{background:#eff6ff;padding:.5rem .75rem;border-radius:8px;font-size:.9rem}.feed-body{white-space:pre-wrap;line-height:1.5}.feed-body-preview{color:#374151}.feed-read-toggle{background:none;border:none;color:#2563eb;cursor:pointer;font-size:.85rem;font-weight:600;padding:0;margin-left:6px}.feed-read-toggle:hover{text-decoration:underline}.feed-media-img{max-width:100%;border-radius:8px;margin-top:.5rem}.feed-audio{width:100%;margin-top:.5rem}.feed-doc-link{display:inline-block;margin-top:.5rem;color:#2563eb}.feed-card-foot{display:flex;gap:1rem;margin-top:.75rem;padding-top:.5rem;border-top:1px solid #f1f5f9}.feed-action{background:none;border:none;cursor:pointer;font-size:.9rem}.feed-comments{margin-top:.75rem;padding-top:.5rem;border-top:1px dashed #e2e8f0}.feed-comment{font-size:.9rem;margin-bottom:.35rem}.feed-comment-form{display:flex;gap:.5rem;margin-top:.5rem}.feed-comment-form input{flex:1;border:1px solid #cbd5e1;border-radius:8px;padding:.4rem .6rem}.whiteboard-wrap{margin:.75rem 0}.whiteboard-tools{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.wb-color{width:28px;height:28px;border-radius:50%;border:2px solid #e2e8f0;cursor:pointer}.wb-color.active{border-color:#111827;transform:scale(1.1)}.whiteboard-canvas{width:100%;height:280px;border:2px solid #cbd5e1;border-radius:8px;touch-action:none;cursor:crosshair}.whiteboard-actions{display:flex;gap:.5rem;margin-top:.5rem}.whiteboard-tabs{display:flex;gap:.5rem;margin-bottom:.5rem}.whiteboard-tabs button{border:1px solid #cbd5e1;background:#fff;padding:.35rem .75rem;border-radius:8px;cursor:pointer}.whiteboard-tabs button.active{background:#2563eb;color:#fff;border-color:#2563eb}.wb-graph-panel{display:grid;gap:.5rem;margin-bottom:.75rem;padding:.75rem;background:#f0f9ff;border-radius:8px;border:1px solid #bae6fd}.wb-graph-panel label{font-size:.8rem;font-weight:600;display:block}.wb-graph-panel select,.wb-graph-panel textarea{width:100%;margin-top:.25rem;padding:.4rem;border-radius:6px;border:1px solid #cbd5e1}.cat-cell-input{width:3rem;padding:.25rem;text-align:center;border:2px solid #2563eb;border-radius:4px;font-size:.85rem}.cat-cell-clickable{cursor:pointer;min-width:2.5rem;text-align:center}.cat-cell-clickable:hover{background:#eff6ff}.feed-own-actions{display:flex;gap:.5rem;margin-top:.5rem}.class-dean-help-btn{border:1px solid #c7d2fe;background:linear-gradient(135deg,#eef2ff,#faf5ff);color:#4338ca;border-radius:20px;padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;white-space:nowrap;box-shadow:0 2px 8px #4f46e51f}.class-dean-help-btn:hover{background:#e0e7ff}.class-dean-help-btn--header{padding:6px 10px;font-size:11px;border-color:#ffffff59;background:#fff3;color:#fff;box-shadow:none}.wa-class-header .class-dean-help-btn--header:hover{background:#ffffff52}.class-hero .class-dean-help-wrap{margin-top:10px;width:100%}@media (min-width: 769px){.class-hero{flex-wrap:wrap;gap:12px}.class-hero .class-dean-help-wrap{margin-top:0;margin-left:auto;width:auto}}.teacher-groups-panel{width:100%}.tg-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}@media (max-width: 640px){.tg-stats-bar{grid-template-columns:repeat(2,1fr)}}.tg-stat{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px 14px;text-align:center;box-shadow:0 2px 8px #0f172a0a}.tg-stat--highlight{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);border-color:#86efac}.tg-stat-num{display:block;font-size:22px;font-weight:800;color:#0f172a;line-height:1.1}.tg-stat-label{display:block;font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.04em;margin-top:4px}.tg-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.tg-card{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden;box-shadow:0 4px 20px #0f172a0f;transition:transform .15s,box-shadow .15s}.tg-card:hover{transform:translateY(-2px);box-shadow:0 12px 28px #0f172a1a}.tg-card-hero{padding:16px;background:linear-gradient(145deg,color-mix(in srgb,var(--tg-accent, #6366f1) 12%,#fff),#fff);border-bottom:1px solid #f1f5f9}.tg-card-hero-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}.tg-card-emoji{font-size:28px;line-height:1;flex-shrink:0}.tg-card-titles{flex:1;min-width:0}.tg-card-name{margin:0;font-size:17px;font-weight:800;color:#0f172a;line-height:1.25}.tg-card-leader{display:block;margin-top:4px;font-size:12px;font-weight:700;color:#b45309}.tg-card-points{flex-shrink:0;font-size:12px;font-weight:800;padding:6px 10px;border-radius:999px;background:#fef3c7;color:#b45309}.tg-member-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.tg-member-chip{width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;color:#fff;border:2px solid #fff;box-shadow:0 2px 6px #0000001f}.tg-member-more{font-size:12px;font-weight:700;color:#64748b;padding:4px 8px;background:#f1f5f9;border-radius:999px}.tg-no-members{font-size:12px;color:#dc2626;font-weight:600}.tg-member-names{margin:10px 0 0;font-size:12px;color:#64748b;line-height:1.4}.tg-quiz-strip{padding:12px 16px;background:#f8fafc;border-bottom:1px solid #f1f5f9}.tg-quiz-strip-label{display:block;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;margin-bottom:8px}.tg-quiz-chips{display:flex;flex-direction:column;gap:8px}.tg-quiz-chip-row{display:flex;flex-direction:column;gap:6px}.tg-quiz-chip-actions{display:flex;flex-wrap:wrap;gap:6px;padding-left:2px}.tg-quiz-chip-actions .btn-sm{font-size:10px;padding:3px 8px}.tg-quiz-chip{font-size:11px;font-weight:700;padding:6px 10px;border-radius:8px;line-height:1.35}.tg-quiz-chip--released{background:#e0f2fe;color:#0369a1}.tg-quiz-chip--active{background:#fef3c7;color:#b45309}.tg-quiz-chip--done{background:#dcfce7;color:#166534}.tg-card-actions{display:flex;flex-wrap:wrap;gap:8px;padding:14px 16px}.tg-btn-assign{flex:1 1 100%;min-height:40px;font-weight:700!important}.tg-btn-delete{color:#b91c1c!important;border-color:#fecaca!important}.tg-empty{text-align:center;padding:48px 24px;background:linear-gradient(135deg,#f8fafc,#f0f9ff);border-radius:16px;border:2px dashed #cbd5e1}.tg-empty-icon{font-size:48px;margin-bottom:12px}.tg-empty h3{margin:0 0 8px;color:#0f172a}.tg-empty p{color:#64748b;font-size:14px;max-width:320px;margin:0 auto 16px}.tg-footer-hint{margin:16px 0 0;font-size:13px;color:#64748b;text-align:center}.tg-link-btn{padding:0!important;font-weight:700!important;vertical-align:baseline}.gah-loading{font-size:13px;color:#64748b;padding:12px 0}.gah-hub{padding:16px;border-radius:16px;background:linear-gradient(180deg,#faf5ff,#fff);border:2px solid #e9d5ff}.gah-header h4{margin:0 0 4px;font-size:16px;color:#5b21b6}.gah-header p{margin:0 0 14px;font-size:12px;color:#7c3aed}.gah-hof-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.gah-hof-card{flex:1;min-width:140px;padding:12px;border-radius:12px;background:#fff;border:1px solid #e9d5ff}.gah-hof-card--month{border-color:#fcd34d;background:#fffbeb}.gah-hof-card h5{margin:0 0 8px;font-size:13px}.gah-hof-card ul{list-style:none;margin:0;padding:0;font-size:12px}.gah-hof-card li{display:flex;gap:6px;padding:4px 0}.gah-feed h5{margin:0 0 10px;font-size:14px}.gah-feed-empty{margin:0;font-size:13px;color:#94a3b8}.gah-feed-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.gah-feed-item{display:flex;flex-direction:column;gap:8px}.gah-feed-bubble{padding:12px 14px;border-radius:14px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000a}.gah-feed-emoji{font-size:24px;display:block;margin-bottom:4px}.gah-feed-headline{margin:0;font-size:13px;line-height:1.45;color:#334155}.gah-reactions{display:flex;gap:8px;flex-wrap:wrap}.gah-react-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:999px;border:1px solid #e2e8f0;background:#f8fafc;font-size:16px;cursor:pointer}.gah-react-btn--on{border-color:#a78bfa;background:#ede9fe}.gah-react-count{font-size:11px;font-weight:700;color:#64748b}.sg-loading,.sg-empty-hint,.sg-list-hint{font-size:13px;color:#64748b}.sg-loading{text-align:center;padding:32px}.sg-empty{text-align:center;padding:40px 16px;color:#64748b}.sg-empty-icon{font-size:48px;margin:0 0 12px}.sg-list{display:flex;flex-direction:column;gap:12px}.sg-list-hint{margin:0 0 8px}.sg-list-card{width:100%;text-align:left;padding:16px;border:2px solid #c7d2fe;border-radius:16px;background:linear-gradient(135deg,#fff,#f8f9ff);cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s}.sg-list-card:hover{border-color:#6366f1;transform:translateY(-1px);box-shadow:0 8px 24px #6366f11f}.sg-list-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}.sg-list-name{display:block;font-size:16px;color:#1e1b4b}.sg-list-leader{display:block;font-size:12px;font-weight:600;color:#b45309;margin-top:4px}.sg-list-badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:linear-gradient(135deg,#f59e0b,#ea580c);color:#fff;white-space:nowrap}.sg-list-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.sg-list-rank,.sg-list-stickers,.sg-list-quiz{font-size:12px;font-weight:600;padding:4px 10px;border-radius:8px;background:#f1f5f9;color:#475569}.sg-list-stickers{background:#fef3c7;color:#92400e}.sg-list-open{display:block;font-size:13px;font-weight:700;color:#4338ca}.sg-detail{display:flex;flex-direction:column;gap:14px}.sg-back{align-self:flex-start}.sg-detail-hero{position:relative;padding:20px 16px 16px;border-radius:18px;overflow:hidden;background:linear-gradient(145deg,#312e81,#4338ca 45%,#6366f1);color:#fff}.sg-detail-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 90% 10%,rgba(255,255,255,.15),transparent 50%);pointer-events:none}.sg-detail-title{position:relative;margin:0 0 4px;font-size:22px;font-weight:800}.sg-detail-sub{position:relative;margin:0 0 14px;font-size:13px;opacity:.9}.sg-rank-banner{position:relative;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.sg-rank-pill{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:6px 12px;border-radius:999px;background:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.sg-rank-pill--quiz{background:#10b98159}.sg-rank-medal{font-size:16px}.sg-detail-scores{position:relative;display:flex;gap:10px}.sg-score-card{flex:1;padding:12px;border-radius:12px;background:#ffffff26;text-align:center}.sg-score-card--points{background:#fbbf2459}.sg-score-val{display:block;font-size:28px;font-weight:800;line-height:1.1}.sg-score-lbl{display:block;font-size:11px;font-weight:600;opacity:.9;margin-top:4px}.sg-roster{padding:14px;border-radius:14px;border:1px solid #e2e8f0;background:#fff}.sg-roster-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:12px}.sg-roster-head h4{margin:0;font-size:15px}.sg-leader-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;background:#fef3c7;color:#92400e}.sg-claim-leader{font-size:11px!important}.sg-member-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.sg-member{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;background:#f8fafc}.sg-member--leader{background:linear-gradient(90deg,#fffbeb,#fef3c7);border:1px solid #fcd34d}.sg-member-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;background:#e0e7ff}.sg-member-info strong{display:block;font-size:14px}.sg-member-role{font-size:11px;font-weight:600;color:#6366f1}.sg-my-role{margin-top:12px}.sg-role-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.sg-leader-hint{margin:10px 0 0;font-size:12px;color:#b45309;font-weight:600}.sg-earned-section{padding:16px;border-radius:16px;background:linear-gradient(180deg,#fffbeb,#fff);border:2px solid #fcd34d}.sg-earned-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sg-earned-header h4{margin:0;font-size:16px;color:#92400e}.sg-earned-total{font-size:14px;font-weight:800;color:#b45309;padding:4px 12px;border-radius:999px;background:#fef3c7}.sg-earned-empty{margin:0;font-size:13px;color:#78716c;line-height:1.5}.sg-sticker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px;margin-bottom:14px}.sg-sticker{display:flex;flex-direction:column;align-items:center;padding:12px 8px;border-radius:14px;background:#fff;border:2px solid #fde68a;box-shadow:0 4px 12px #f59e0b26;animation:sg-pop .4s ease}@keyframes sg-pop{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.sg-sticker-emoji{font-size:28px;line-height:1}.sg-sticker-count{font-size:16px;font-weight:800;color:#b45309;margin-top:4px}.sg-sticker-label{font-size:9px;font-weight:700;color:#78716c;text-align:center;margin-top:2px;text-transform:uppercase;letter-spacing:.02em}.sg-earned-feed{list-style:none;margin:0;padding:10px 0 0;border-top:1px dashed #fde68a}.sg-earned-feed li{display:flex;align-items:center;gap:8px;font-size:13px;padding:6px 0;color:#44403c}.sg-earned-feed-emoji{font-size:18px}.sg-earned-feed-skill{color:#78716c}.sg-dean-wrap{margin:4px 0}.sg-quizzes-section{padding:4px 0}.sg-quizzes-heading-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:12px}.sg-quizzes-heading{margin:0;font-size:16px;font-weight:800;color:#312e81}.sg-quizzes-sparkle{font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;background:linear-gradient(135deg,#fef3c7,#fce7f3);color:#9d174d}.sg-quizzes-empty{font-size:13px;color:#94a3b8;margin:0;padding:16px;border-radius:14px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px dashed #cbd5e1;text-align:center}.sg-quiz-list{display:flex;flex-direction:column;gap:12px}.sg-quiz-card{position:relative;overflow:hidden;padding:16px;border-radius:18px;border:2px solid transparent;background:linear-gradient(135deg,#fff,#f5f3ff);box-shadow:0 8px 24px #6366f11f;transition:transform .15s ease,box-shadow .15s ease}.sg-quiz-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px #6366f12e}.sg-quiz-card--new{border-color:#6ee7b7;background:linear-gradient(135deg,#ecfdf5,#fff 55%,#f0fdf4)}.sg-quiz-card--active{border-color:#fcd34d;background:linear-gradient(135deg,#fffbeb,#fff 55%,#fef3c7)}.sg-quiz-card--done{border-color:#a7f3d0;background:linear-gradient(135deg,#f0fdf4,#fff,#ecfdf5)}.sg-quiz-card-sparkle{position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;background:radial-gradient(circle,rgba(167,139,250,.25) 0%,transparent 70%);pointer-events:none}.sg-quiz-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px;position:relative;z-index:1}.sg-quiz-title{font-weight:800;font-size:15px;color:#1e1b4b;line-height:1.3}.sg-quiz-emoji{margin-right:4px}.sg-quiz-status{font-size:11px;font-weight:800;white-space:nowrap;padding:4px 8px;border-radius:999px;background:#ffffffd9}.sg-quiz-submitter{margin:0 0 6px;font-size:12px;font-weight:600;color:#047857}.sg-quiz-desc{margin:0 0 12px;font-size:13px;color:#64748b;line-height:1.45}.sg-quiz-btn{width:100%;font-weight:800;border:none;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:12px;border-radius:12px;box-shadow:0 4px 14px #4f46e559}.sg-quiz-btn--done{background:linear-gradient(135deg,#059669,#10b981);box-shadow:0 4px 14px #05966959}.sg-crown-picker{padding:14px 16px;border-radius:14px;background:linear-gradient(135deg,#fef3c7,#fff);border:2px solid #fcd34d}.sg-crown-picker-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:6px}.sg-crown-picker-head h4{margin:0;font-size:15px;color:#92400e}.sg-crown-none{font-size:12px;color:#b45309;font-weight:600}.sg-crown-hint{margin:0 0 10px;font-size:12px;color:#78716c;line-height:1.4}.sg-member-crown{display:block;margin-top:4px}.gqr-page{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.gqr-hero{position:relative;overflow:hidden;padding:28px 20px 24px;border-radius:24px;background:linear-gradient(145deg,#4f46e5,#7c3aed 42%,#ec4899);color:#fff;text-align:center;box-shadow:0 20px 50px #4f46e559}.gqr-hero-glow{position:absolute;top:-40px;right:-30px;width:140px;height:140px;border-radius:50%;background:#ffffff1f;pointer-events:none}.gqr-hero-eyebrow{margin:0 0 6px;font-size:13px;font-weight:700;opacity:.92}.gqr-hero-title{margin:0 0 16px;font-size:18px;font-weight:800;line-height:1.3}.gqr-score-ring{display:inline-flex;align-items:baseline;justify-content:center;gap:4px;padding:12px 28px;border-radius:999px;background:#ffffff2e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.gqr-score-big{font-size:42px;font-weight:900;line-height:1}.gqr-score-of{font-size:20px;font-weight:700;opacity:.9}.gqr-score-pct{margin:12px 0 0;font-size:15px;font-weight:700}.gqr-submitted-by{margin:8px 0 0;font-size:12px;opacity:.88}.gqr-ranks{display:grid;grid-template-columns:1fr 1fr;gap:10px}@media (max-width: 400px){.gqr-ranks{grid-template-columns:1fr}}.gqr-rank-card{display:flex;align-items:center;gap:12px;padding:14px;border-radius:16px;border:2px solid transparent}.gqr-rank-card strong{display:block;font-size:13px}.gqr-rank-card span{font-size:12px;color:#64748b}.gqr-rank-card--quiz{background:linear-gradient(135deg,#ecfdf5,#fff);border-color:#6ee7b7}.gqr-rank-card--points{background:linear-gradient(135deg,#fffbeb,#fff);border-color:#fcd34d}.gqr-rank-medal{font-size:28px;line-height:1}.gqr-teacher-card{padding:18px;border-radius:18px;background:linear-gradient(135deg,#f0fdf4,#fff 60%);border:2px solid #86efac;box-shadow:0 8px 24px #10b9811f}.gqr-teacher-card--pending{display:flex;align-items:flex-start;gap:12px;background:linear-gradient(135deg,#fef3c7,#fff);border-color:#fcd34d}.gqr-teacher-card--pending p{margin:0;font-size:14px;color:#78350f;line-height:1.45}.gqr-teacher-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}.gqr-teacher-icon{font-size:28px}.gqr-teacher-head strong{display:block;color:#065f46;font-size:15px}.gqr-teacher-name{display:block;font-size:12px;color:#047857;font-weight:600}.gqr-teacher-body{margin:0;font-size:15px;line-height:1.55;color:#134e4a;white-space:pre-wrap}.gqr-teacher-time{display:block;margin-top:10px;font-size:11px;color:#6b7280}.gqr-roster-title{margin:0 0 12px;font-size:16px;font-weight:800;color:#312e81}.gqr-roster-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.gqr-member{display:flex;gap:12px;padding:14px;border-radius:16px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 4px 14px #0f172a0f}.gqr-member--leader{border-color:#fcd34d;background:linear-gradient(135deg,#fffbeb,#fff)}.gqr-member-avatar{font-size:26px;line-height:1;flex-shrink:0}.gqr-member-body strong{display:block;font-size:15px;color:#1e1b4b}.gqr-member-role{display:block;font-size:11px;font-weight:700;color:#6366f1;margin-top:2px}.gqr-member-grade{display:inline-block;margin-top:6px;font-size:12px;font-weight:700;padding:4px 10px;border-radius:999px;background:#fef3c7;color:#92400e}.gqr-member-note,.gqr-member-weak,.gqr-member-help{margin:6px 0 0;font-size:12px;line-height:1.4;color:#475569}.gqr-reflection-notes{padding:16px;border-radius:16px;background:#f8fafc;border:1px dashed #cbd5e1}.gqr-reflection-notes h3{margin:0 0 10px;font-size:15px}.gqr-reflection-notes p{margin:0 0 8px;font-size:13px;line-height:1.45;color:#334155}.gqr-back-btn{margin-top:8px;font-weight:800;border-radius:14px;padding:14px}.install-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:flex-end;justify-content:center;z-index:9999;padding-bottom:24px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.install-popup{background:#fff;border-radius:20px;padding:28px 32px 24px;text-align:center;width:300px;position:relative;box-shadow:0 8px 40px #00000040;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}.install-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:16px;color:#999;cursor:pointer;line-height:1;padding:4px}.install-close:hover{color:#333}.install-icon{font-size:56px;line-height:1;margin-bottom:6px}.install-name{font-size:20px;font-weight:700;color:#333;margin-bottom:20px}.install-btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;letter-spacing:.5px;cursor:pointer;transition:opacity .2s}.install-btn:hover{opacity:.9}.admin-layout{display:flex;height:100vh;background:#f1f5f9;font-family:Inter,-apple-system,sans-serif}.admin-sidebar{background:#1e293b;color:#fff;display:flex;flex-direction:column;transition:width .25s ease;overflow:hidden;flex-shrink:0}.admin-sidebar.open{width:240px}.admin-sidebar.closed{width:64px}.admin-sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.1);min-height:64px}.admin-logo{font-size:1.5rem;flex-shrink:0}.admin-brand-text{font-weight:700;font-size:1rem;white-space:nowrap}.admin-nav{flex:1;padding:.75rem 0;overflow-y:auto}.admin-nav-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:#94a3b8;cursor:pointer;transition:all .15s;text-align:left;white-space:nowrap}.admin-nav-item:hover{background:#ffffff14;color:#fff}.admin-nav-item.active{background:#6366f133;color:#818cf8;border-right:3px solid #818cf8}.admin-nav-icon{font-size:1.2rem;flex-shrink:0}.admin-nav-label{font-size:.9rem;font-weight:500}.admin-sidebar-footer{border-top:1px solid rgba(255,255,255,.1);padding:.5rem 0}.admin-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.admin-topbar{background:#fff;border-bottom:1px solid #e2e8f0;display:flex;align-items:center;gap:1rem;padding:0 1.5rem;height:64px;flex-shrink:0}.admin-toggle{background:none;border:none;font-size:1.3rem;cursor:pointer;color:#64748b;padding:.25rem}.admin-page-title{flex:1;font-size:1.2rem;font-weight:700;color:#1e293b;margin:0}.admin-user-info{display:flex;align-items:center;gap:.5rem;color:#475569;font-size:.9rem}.admin-badge{background:#6366f1;color:#fff;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.admin-content{flex:1;overflow-y:auto;padding:1.5rem}.admin-dashboard{display:flex;flex-direction:column;gap:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.stat-card{background:#fff;border-radius:16px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #00000012;border-left:4px solid var(--accent)}.stat-icon{font-size:2rem}.stat-value{font-size:1.8rem;font-weight:800;color:#1e293b;line-height:1}.stat-label{font-size:.8rem;color:#64748b;margin-top:.25rem;font-weight:500}.admin-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 1px 3px #00000012}.admin-card-title{font-size:1rem;font-weight:700;color:#1e293b;margin:0 0 1.25rem}.activity-chart{display:flex;align-items:flex-end;gap:.5rem;height:160px;padding-bottom:1.5rem}.chart-bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;gap:.25rem}.chart-bar{width:100%;background:linear-gradient(180deg,#6366f1,#818cf8);border-radius:4px 4px 0 0;min-height:4px;transition:height .3s}.chart-label{font-size:.65rem;color:#94a3b8;text-align:center;white-space:nowrap;overflow:hidden}.admin-table-wrap{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-table th{background:#f8fafc;color:#64748b;font-weight:600;padding:.75rem 1rem;text-align:left;border-bottom:1px solid #e2e8f0;white-space:nowrap}.admin-table td{padding:.875rem 1rem;border-bottom:1px solid #f1f5f9;color:#334155;vertical-align:middle;white-space:normal;word-break:break-word;overflow-wrap:anywhere}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#f8fafc}.badge{padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.badge-green{background:#dcfce7;color:#16a34a}.badge-red{background:#fee2e2;color:#dc2626}.badge-blue{background:#dbeafe;color:#2563eb}.badge-yellow{background:#fef3c7;color:#d97706}.btn-sm{padding:.35rem .75rem;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:opacity .15s}.btn-sm:hover{opacity:.85}.btn-danger{background:#fee2e2;color:#dc2626}.btn-warning{background:#fef3c7;color:#d97706}.btn-success{background:#dcfce7;color:#16a34a}.btn-primary{background:#6366f1;color:#fff}.btn-outline{background:#fff;border:1px solid #e2e8f0;color:#475569}.empty-text{color:#94a3b8;text-align:center;padding:2rem 0}.admin-form-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.admin-input{padding:.6rem .875rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;outline:none;transition:border-color .15s;flex:1;min-width:140px}.admin-input:focus{border-color:#6366f1}.admin-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;flex-wrap:wrap;gap:.75rem}.admin-section-title{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0}@media (max-width: 980px){.admin-layout{height:auto;min-height:100vh;flex-direction:column}.admin-sidebar,.admin-sidebar.open,.admin-sidebar.closed{width:100%}.admin-sidebar{max-height:52vh}.admin-sidebar-brand{padding:.85rem 1rem}.admin-nav{max-height:calc(52vh - 64px)}.admin-main{overflow:visible;min-height:0}.admin-topbar{padding:.5rem .9rem;height:auto;min-height:64px;align-items:flex-start;flex-wrap:wrap;gap:.6rem}.admin-page-title{font-size:1rem;min-width:0}.admin-user-info{width:100%;justify-content:flex-start;flex-wrap:wrap;gap:.4rem}.admin-content{padding:.9rem}.admin-card{padding:1rem;border-radius:12px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(145px,1fr));gap:.75rem}.stat-card{padding:.95rem;gap:.75rem}.stat-value{font-size:1.35rem}.admin-form-row{flex-direction:column;align-items:stretch}.admin-input,.admin-form-row .btn-sm,.admin-form-row button,.admin-form-row select,.admin-form-row textarea{width:100%;min-width:0}.admin-table{font-size:.8rem}.admin-table th,.admin-table td{padding:.62rem .55rem}}@media (max-width: 560px){.admin-nav-item{padding:.68rem .85rem}.admin-nav-icon{font-size:1.05rem}.admin-badge{font-size:.7rem;padding:.15rem .5rem}.btn-sm{width:100%;justify-content:center;text-align:center}.activity-chart{height:140px;gap:.35rem}.chart-label{font-size:.58rem}}.join-card{max-width:420px;width:100%}.join-class-banner{display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;padding:18px 20px;margin-bottom:16px;color:#fff}.join-class-icon{font-size:36px;flex-shrink:0}.join-class-name{font-size:20px;font-weight:700;margin:0 0 4px;color:#fff}.join-class-subject{font-size:13px;margin:0 0 4px;opacity:.85}.join-class-teacher{font-size:13px;margin:0;opacity:.8}.join-code-badge{text-align:center;font-size:13px;color:#888;background:#f3f4f6;border-radius:8px;padding:6px 12px;margin-bottom:20px;letter-spacing:1px}.join-code-badge strong{color:#667eea;font-family:monospace;font-size:15px}.join-toggle{display:flex;border:2px solid #e5e7eb;border-radius:12px;overflow:hidden;margin-bottom:20px}.join-toggle-btn{flex:1;padding:10px;border:none;background:transparent;cursor:pointer;font-size:14px;font-weight:500;color:#888;transition:all .2s}.join-toggle-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:700}.join-submit-btn{margin-top:8px;background:linear-gradient(135deg,#667eea,#764ba2);font-size:16px;padding:14px}.join-back{text-align:center;margin-top:16px;font-size:14px;color:#888}.join-error-card{text-align:center;max-width:360px}.spinner{width:36px;height:36px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}@keyframes spin{to{transform:rotate(360deg)}}.sn-page{max-width:none;width:100%;margin:0;padding:24px 16px 60px;min-height:100vh;box-sizing:border-box}.sn-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:28px}.sn-header-left{display:flex;align-items:center;gap:14px}.sn-title{font-size:26px;font-weight:700;color:#333}.sn-header-right{display:flex;align-items:center;gap:10px}.sn-search{padding:8px 14px;border:2px solid #e0e0e0;border-radius:20px;font-size:14px;width:200px;outline:none;transition:border-color .2s}.sn-search:focus{border-color:#667eea}.sn-section-label{font-size:13px;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;margin:20px 0 10px}.sn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px}.sn-note{border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;position:relative;transition:transform .15s,box-shadow .15s;min-height:140px;display:flex;flex-direction:column;justify-content:space-between}.sn-note:hover{transform:translateY(-3px);box-shadow:0 6px 20px #00000021}.sn-pin-indicator{position:absolute;top:10px;right:10px;font-size:14px}.sn-note-title{font-size:15px;font-weight:700;color:#222;margin-bottom:8px;word-break:break-word}.sn-note-body{font-size:13px;color:#444;line-height:1.5;flex:1;overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;word-break:break-word}.sn-note-footer{display:flex;align-items:center;justify-content:space-between;margin-top:10px}.sn-note-date{font-size:11px;color:#888}.sn-note-actions{display:flex;gap:4px}.sn-note-actions button{background:none;border:none;cursor:pointer;font-size:16px;padding:2px 4px;border-radius:4px;transition:background .1s}.sn-note-actions button:hover{background:#00000014}.sn-empty{text-align:center;padding:60px 20px;color:#aaa}.sn-empty-icon{font-size:60px;margin-bottom:16px}.sn-empty p{font-size:16px;line-height:1.6}.sn-loading{text-align:center;padding:60px;color:#888;font-size:16px}.sn-badges-section{margin-bottom:24px;background:#fff;border-radius:14px;padding:18px 20px;box-shadow:0 2px 8px #0000000f}.sn-badges{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.sn-badge{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;border:2px solid #ccc;background:#fafafa;font-size:13px}.sn-badge-icon{font-size:18px}.sn-badge-label{font-weight:700}.sn-badge-quiz{color:#888;font-size:11px;margin-left:4px}.sn-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px}.sn-modal{background:#fff;border-radius:16px;padding:28px;width:100%;max-width:480px;box-shadow:0 20px 60px #00000040}.sn-modal h2{margin-bottom:20px;font-size:20px;color:#333}.sn-color-picker{display:flex;flex-wrap:wrap;gap:8px}.sn-color-swatch{width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s;box-shadow:0 1px 4px #00000026}.sn-color-swatch.selected{border-color:#667eea;transform:scale(1.2)}.sn-modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}@media (max-width: 600px){.sn-page{padding:16px 12px 80px}.sn-header{flex-direction:column;align-items:stretch}.sn-header-left{margin-bottom:4px}.sn-header-right{flex-direction:column;align-items:stretch;gap:8px}.sn-search{width:100%;box-sizing:border-box}.sn-title{font-size:20px}.sn-grid{grid-template-columns:1fr 1fr;gap:10px}.sn-note{padding:12px;min-height:120px}.sn-note-title{font-size:13px}.sn-note-body{font-size:12px;-webkit-line-clamp:4}.sn-badges{gap:6px}.sn-badge{padding:4px 10px;font-size:11px}.sn-badge-quiz{display:none}.sn-modal{padding:20px 16px;border-radius:14px 14px 0 0;max-height:90vh;overflow-y:auto}.sn-overlay{align-items:flex-end;padding:0}}@media (max-width: 380px){.sn-grid{grid-template-columns:1fr}}.share-moment-page{min-height:100vh;background:linear-gradient(180deg,#e8f5e9,#f0f2f5 35%);padding:1rem 1rem 3rem;max-width:none;width:100%;margin:0;box-sizing:border-box}.share-moment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.share-moment-brand{font-weight:800;font-size:1.25rem;color:#075e54;text-decoration:none}.share-moment-tag{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#128c7e;background:#128c7e1f;padding:4px 10px;border-radius:999px}.share-moment-card{background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000014;padding:1rem;border:1px solid #e4e6eb}.share-moment-card--error{text-align:center}.share-moment-shared-by{font-size:12px;color:#65676b}.share-moment-cta-text{font-size:14px;color:#65676b;line-height:1.5;margin:12px 0}.share-moment-actions{display:flex;gap:10px;flex-wrap:wrap}.share-moment-footer{margin-top:2rem;font-size:11px;color:#8a8d91;text-align:center}.share-moment-muted{text-align:center;color:#65676b}.quiz-share-landing{min-height:100vh;background:linear-gradient(160deg,#ecfdf5,#f8fafc 45%,#eef2ff);padding:16px}.quiz-share-landing__head{max-width:560px;margin:0 auto 16px}.quiz-share-landing__brand{font-weight:800;font-size:1.25rem;color:#128c7e;text-decoration:none}.quiz-share-landing__card{max-width:560px;margin:0 auto;background:#fff;border-radius:16px;padding:24px;box-shadow:0 8px 32px #0f172a14}.quiz-share-landing__card--error{text-align:center}.quiz-share-landing__eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#128c7e;margin:0 0 8px}.quiz-share-landing__card h1{margin:0 0 8px;font-size:1.5rem;color:#0f172a}.quiz-share-landing__meta{color:#64748b;margin:0 0 12px}.quiz-share-landing__desc{color:#334155;line-height:1.5;margin:0 0 12px}.quiz-share-landing__hint{font-size:13px;color:#64748b;background:#f1f5f9;padding:10px 12px;border-radius:8px;margin:0 0 20px;line-height:1.45}.quiz-share-landing__section{border-top:1px solid #e2e8f0;padding-top:18px;margin-top:18px}.quiz-share-landing__section h2{margin:0 0 8px;font-size:1.05rem}.quiz-share-landing__sub{font-size:13px;color:#64748b;margin:0 0 12px}.quiz-share-landing__form label{display:block;font-size:13px;font-weight:600;margin-bottom:12px}.quiz-share-landing__form input{width:100%;margin-top:4px;padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;box-sizing:border-box}.quiz-share-landing__role-grid{display:flex;flex-direction:column;gap:8px}.quiz-share-landing__login{text-align:center;margin-top:16px;font-size:14px}.quiz-share-landing__muted{text-align:center;color:#64748b}.guest-shell{display:flex;flex-direction:column;min-height:100vh;background:#f0f2f5}.guest-shell__main{flex:1;padding:16px 16px 88px;max-width:none;margin:0;width:100%;box-sizing:border-box}.guest-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background:#fff;border-top:1px solid #e2e8f0;padding:8px 8px calc(8px + env(safe-area-inset-bottom));z-index:50;max-width:none;margin:0}.guest-nav__btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 4px;border:none;background:none;color:#64748b;font-size:11px;font-weight:600;cursor:pointer;text-decoration:none}.guest-nav__btn--active{color:#128c7e}.guest-nav__btn span:first-child{font-size:20px}.guest-class-grid{display:grid;gap:12px}.guest-class-card{background:#fff;border-radius:14px;padding:14px 16px;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000a}.guest-class-card h3{margin:0 0 4px;font-size:16px}.guest-pill-row{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.guest-pill{font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;background:#ecfdf5;color:#047857}.guest-quiz-section--cards{margin-top:0;margin-bottom:8px}.guest-quiz-section__hint{margin:0 0 14px;font-size:13px;color:#64748b;line-height:1.45}.guest-class-quizzes{margin-bottom:20px}.guest-class-quizzes__title{margin:0 0 10px;font-size:14px;font-weight:700;color:#0f172a}.guest-class-quizzes__teacher{display:block;margin-top:2px;font-size:12px;font-weight:600;color:#64748b}.guest-quiz-card-list{display:flex;flex-direction:column;gap:0}.guest-quiz-card{margin-bottom:12px}.guest-quiz-subsection{margin-bottom:16px}.guest-quiz-subsection__title{margin:0 0 8px;font-size:13px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.04em}.guest-quiz-status--done{color:#059669;font-weight:600}.guest-quiz-status--pending{color:#b45309;font-weight:600}.guest-quiz-score{color:#0f766e;font-weight:600}.guest-readonly-tag{font-size:11px;color:#b45309;background:#fffbeb;padding:2px 8px;border-radius:6px;font-weight:600}.guest-header-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:flex-start}.guest-header-donate-desktop{display:flex;align-items:center}.guest-donate-fab{display:none;position:fixed;z-index:9200;bottom:calc(56px + env(safe-area-inset-bottom,0px));right:14px}@media (max-width: 768px){.guest-header-donate-desktop{display:none}.guest-donate-fab{display:block}}.guest-upgrade-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10060;display:flex;align-items:center;justify-content:center;padding:16px}.guest-upgrade-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172aa6}.guest-upgrade-modal__panel{position:relative;width:min(440px,100%);max-height:90vh;overflow-y:auto;background:#fff;border-radius:16px;padding:24px 20px 20px;box-shadow:0 20px 50px #0003}.guest-upgrade-modal__close{position:absolute;top:12px;right:12px;border:none;background:#f1f5f9;width:32px;height:32px;border-radius:50%;cursor:pointer}.guest-upgrade-modal h2{margin:0 0 8px;font-size:1.25rem;color:#0f172a}.guest-upgrade-modal__lead{margin:0 0 16px;font-size:.9rem;color:#475569;line-height:1.5}.guest-upgrade-modal__question{font-weight:700;color:#312e81;margin:0 0 12px}.guest-upgrade-modal__choices{display:grid;gap:10px}.guest-upgrade-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;text-align:left;padding:14px 16px;border:2px solid #c7d2fe;border-radius:12px;background:linear-gradient(135deg,#eef2ff,#faf5ff);cursor:pointer;transition:border-color .15s,transform .15s}.guest-upgrade-card:hover{border-color:#6366f1;transform:translateY(-1px)}.guest-upgrade-card__icon{font-size:1.5rem}.guest-upgrade-card strong{font-size:1rem;color:#1e1b4b}.guest-upgrade-card small{font-size:.8rem;color:#64748b;line-height:1.4}.guest-upgrade-form{display:flex;flex-direction:column;gap:12px}.guest-upgrade-form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;font-weight:600;color:#334155}.guest-upgrade-form input{padding:10px 12px;border:1px solid #cbd5e1;border-radius:10px;font-size:.95rem}.guest-upgrade-email-row{display:flex;align-items:center;gap:6px}.guest-upgrade-email-row input{flex:1}.guest-upgrade-email-row span{font-size:.8rem;color:#64748b;white-space:nowrap}.guest-upgrade-preview{font-size:.85rem;color:#4338ca;margin:0}.guest-limits-banner{background:#fffbeb;border:1px solid #fde68a;border-radius:12px;padding:12px 14px;margin-bottom:16px;font-size:13px;color:#92400e;line-height:1.5}.guest-limits-banner ul{margin:8px 0 0;padding-left:18px}.guest-quiz-section{margin-top:24px}.guest-quiz-section h2{font-size:17px;margin-bottom:10px;color:#0f172a}.guest-quiz-list{display:grid;gap:8px}.guest-quiz-row{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:12px 14px}.guest-quiz-row__meta{min-width:0}.guest-quiz-row__meta strong{display:block;font-size:14px}.guest-quiz-row__meta small{color:#64748b;font-size:12px}.guest-upgrade-cta{margin:20px 0;padding:16px;border-radius:14px;background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;text-align:center}.guest-upgrade-cta p{margin:0 0 12px;font-size:14px;line-height:1.45;opacity:.95}.guest-upgrade-cta .btn{background:#fff;color:#4338ca;font-weight:700}.profile-page{max-width:none;width:100%;margin:0;padding:24px 16px 60px;color:#111b21;box-sizing:border-box}.app-wa-shell .profile-page .profile-header h1,.app-wa-shell .profile-page .profile-name,.app-wa-shell .profile-page .profile-email,.app-wa-shell .profile-page .profile-view-row,.app-wa-shell .profile-page .profile-view-text{color:inherit}.app-wa-shell .profile-page .profile-email{color:#64748b}.profile-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.profile-header h1{font-size:22px;font-weight:700;color:#333;flex:1}.profile-view-card{background:#fff;border-radius:20px;box-shadow:0 4px 20px #6366f11a;padding:28px 20px 24px;display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:20px}.profile-view-avatar-wrap{position:relative;margin-bottom:8px}.profile-view-avatar{width:100px;height:100px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:4px solid #e8eaf6;box-shadow:0 4px 18px #6366f12e}.avatar-edit-btn-overlay{position:absolute;bottom:2px;right:2px;background:#667eea;color:#fff;border:none;border-radius:50%;width:28px;height:28px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003}.profile-view-name-row{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;margin-top:4px}.profile-view-section{width:100%;border-top:1px solid #f1f5f9;padding-top:14px;margin-top:8px}.profile-view-section-title{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.6px;color:#667eea;margin-bottom:10px}.profile-view-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:8px;font-size:14px;color:#374151}.profile-view-block{margin-bottom:12px}.profile-view-label{font-size:12px;font-weight:700;color:#94a3b8;margin-bottom:5px}.profile-view-text{margin:0;font-size:14px;color:#374151;line-height:1.55}.profile-view-tags{display:flex;flex-wrap:wrap;gap:6px}.profile-view-tag{background:#e0e7ff;color:#3730a3;border-radius:20px;padding:4px 13px;font-size:12px;font-weight:600}.profile-view-empty{text-align:center;padding:20px 0 8px;color:#aaa;font-size:14px;display:flex;flex-direction:column;gap:12px;align-items:center}.profile-avatar-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:12px}.profile-avatar{width:110px;height:110px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:4px solid #667eea;cursor:pointer;transition:opacity .2s;box-shadow:0 4px 16px #667eea40}.profile-avatar:hover{opacity:.85}.avatar-edit-btn{background:#f0f2ff;color:#667eea;border:none;border-radius:8px;padding:6px 14px;font-size:13px;font-weight:600;cursor:pointer}.avatar-edit-btn:hover{background:#e0e4ff}.profile-stats-bar{display:flex;align-items:center;justify-content:center;gap:0;background:#f4f6ff;border-radius:14px;padding:12px 20px;margin:0 0 14px}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:2px;flex:1}.profile-stat strong{font-size:22px;font-weight:800;color:#5c6bc0;line-height:1}.profile-stat span{font-size:12px;color:#888;font-weight:500}.profile-stat-divider{width:1px;height:36px;background:#dde2f0;margin:0 8px}.profile-name-row{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:4px}.profile-name{font-size:20px;font-weight:700;color:#222}.profile-role-badge{background:#667eea;color:#fff;border-radius:20px;padding:2px 12px;font-size:12px;font-weight:600;text-transform:capitalize}.profile-email{text-align:center;color:#777;font-size:14px;margin-bottom:24px}.profile-form{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 16px #00000012}.profile-section-title{font-size:14px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin:24px 0 12px;padding-bottom:6px;border-bottom:2px solid #f0f2ff}.tag-input-row{display:flex;gap:8px;margin-bottom:8px}.tag-input-row input{flex:1}.tags{display:flex;flex-wrap:wrap;gap:6px}.tag{background:#f0f2ff;color:#667eea;border-radius:20px;padding:4px 10px;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px}.tag button{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;line-height:1;padding:0}.profile-msg{margin:12px 0;padding:10px 14px;border-radius:8px;font-size:14px;font-weight:500}.profile-msg.success{background:#d1fae5;color:#065f46}.profile-msg.error{background:#fee2e2;color:#991b1b}.profile-share-section{margin:32px 0 8px;padding:24px 16px;background:#f8fafc;border-radius:16px;border:1px solid #e2e8f0}.profile-teacher-section{margin:32px 0 8px;padding:24px 16px;background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 2px 10px #0000000d}.umunsimedia-promo{margin-top:32px;border-radius:16px;overflow:hidden}.umunsimedia-link{text-decoration:none;display:block}.umunsimedia-inner{background:linear-gradient(135deg,#f59e0b,#f97316);padding:20px 24px;display:flex;align-items:center;gap:16px;border-radius:16px;transition:opacity .2s}.umunsimedia-inner:hover{opacity:.92}.umunsimedia-logo{width:52px;height:52px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:3px solid rgba(255,255,255,.5);flex-shrink:0}.umunsimedia-text{display:flex;flex-direction:column;gap:4px}.umunsimedia-tagline{color:#ffffffe6;font-size:13px;font-weight:500}.umunsimedia-cta{color:#fff;font-size:16px;font-weight:800;letter-spacing:.2px}.profile-view{display:flex;flex-direction:column;align-items:center}.pv-card{width:100%;background:#fff;border-radius:16px;padding:20px 24px;box-shadow:0 2px 16px #00000012;margin-bottom:16px}.pv-section{font-size:13px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid #f0f2ff}.pv-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px;font-size:14px;color:#374151}.pv-label{font-weight:600;color:#6b7280;min-width:110px;flex-shrink:0}.pv-block{margin-bottom:14px}.pv-block p{margin:6px 0 0;font-size:14px;color:#374151;line-height:1.5}.pv-empty{color:#d1d5db;font-style:italic;font-size:13px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:#555}.form-group input,.form-group textarea{width:100%;padding:10px 14px;border:2px solid #e8e8e8;border-radius:8px;font-size:14px;transition:border-color .2s;background:#fff;font-family:inherit}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.form-group textarea{resize:vertical;min-height:80px}.sf-feed{max-width:none;width:100%;margin:0}.sf-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.sf-tab{padding:7px 16px;border-radius:20px;border:2px solid #e2e8f0;background:#fff;font-size:13px;font-weight:600;cursor:pointer;color:#475569;transition:all .15s;white-space:nowrap}.sf-tab:hover{background:#f8fafc;border-color:#94a3b8}.sf-tab--active{box-shadow:0 2px 10px #00000021}.sf-composer{background:#fff;border-radius:14px;box-shadow:0 1px 10px #00000014;border:1px solid #e2e8f0;padding:16px;margin-bottom:18px}.sf-composer-row{display:flex;gap:12px;align-items:flex-start}.sf-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:.5px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sf-composer-right{flex:1;display:flex;flex-direction:column;gap:8px}.sf-composer-input{width:100%;box-sizing:border-box;border:1.5px solid #e2e8f0;border-radius:10px;background:#f8fafc;padding:10px 14px;font-size:14.5px;line-height:1.55;color:#1e293b;resize:vertical;outline:none;font-family:inherit;transition:border-color .15s}.sf-composer-input:focus{border-color:#94a3b8;background:#fff}.sf-composer-actions{display:flex;justify-content:space-between;align-items:center;padding-top:4px}.sf-char-count{font-size:11px;color:#cbd5e1}.sf-post-btn{color:#fff;font-weight:700;border:none;border-radius:8px;padding:8px 22px;font-size:14px;cursor:pointer;transition:opacity .15s,transform .1s}.sf-post-btn:disabled{background:#e2e8f0!important;color:#94a3b8;cursor:not-allowed;transform:none}.sf-post{background:#fff;border-radius:14px;box-shadow:0 1px 8px #00000012;border:1px solid #f1f5f9;overflow:hidden;transition:box-shadow .18s}.sf-post:hover{box-shadow:0 4px 18px #0000001c}.sf-post-head{display:flex;align-items:center;gap:11px;padding:13px 14px 11px;background:#f8fafc}.sf-post-badge{font-size:11.5px;font-weight:700;padding:2px 9px;border-radius:20px;white-space:nowrap}.sf-del-btn{background:none;border:none;color:#cbd5e1;font-size:14px;cursor:pointer;padding:4px 7px;border-radius:6px;line-height:1;transition:background .15s,color .15s;flex-shrink:0}.sf-post-body{padding:14px 18px;font-size:15px;color:#1e293b;line-height:1.7;white-space:pre-wrap;word-break:break-word}.sf-post-foot{padding:10px 14px 11px;display:flex;gap:10px;border-top:1px solid #f1f5f9}.sf-like-btn{display:flex;align-items:center;gap:5px;background:none;border:1.5px solid #e2e8f0;border-radius:20px;padding:5px 14px;font-size:13.5px;color:#64748b;font-weight:600;cursor:pointer;transition:all .15s}.sf-like-btn:hover{background:#fff1f2;border-color:#fda4af;color:#e11d48}.sf-like-btn--on{color:#e11d48;border-color:#fda4af;background:#fff1f2}.sf-like-btn:disabled{opacity:.6;cursor:not-allowed}.sf-cstatus-btn{display:flex;align-items:center;gap:5px;border:none;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;color:#fff;background:linear-gradient(135deg,#25d366,#128c7e);box-shadow:0 3px 12px #25d36659}.sf-cstatus-btn:hover{filter:brightness(1.05)}.sf-state{display:flex;flex-direction:column;align-items:center;gap:6px;padding:40px 0;color:#94a3b8;font-size:15px}.sf-empty-icon{font-size:42px;margin-bottom:4px}.sf-spinner{width:22px;height:22px;border:3px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;animation:sf-spin .7s linear infinite;margin-bottom:6px}@keyframes sf-spin{to{transform:rotate(360deg)}}.sf-comp-form{display:flex;flex-direction:column;gap:14px}.sf-comp-rules{background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;padding:12px 16px;font-size:13px;color:#475569}.sf-comp-rules span{font-weight:700;font-size:14px;display:block;margin-bottom:6px}.sf-comp-rules ul{margin:0;padding-left:18px}.sf-comp-rules li{margin-bottom:3px}.sf-comp-field{display:flex;flex-direction:column;gap:5px}.sf-comp-field label{font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:4px}.sf-req{color:#e11d48;font-size:15px}.sf-comp-input{border:1.5px solid #e2e8f0;border-radius:8px;padding:9px 13px;font-size:14.5px;font-family:inherit;color:#1e293b;outline:none;transition:border-color .15s}.sf-comp-input:focus{border-color:#0891b2}.sf-comp-textarea{border:1.5px solid #e2e8f0;border-radius:8px;padding:9px 13px;font-size:14.5px;font-family:inherit;color:#1e293b;resize:vertical;outline:none;line-height:1.6;transition:border-color .15s}.sf-comp-textarea:focus{border-color:#0891b2}.sf-comp-submit{width:100%;padding:11px;font-size:15px;border-radius:10px;margin-top:4px}.sf-post-comp-title{font-size:17px;font-weight:800;color:#0891b2;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #cffafe}.sf-post-comp-section{margin-bottom:12px}.sf-post-comp-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:#64748b;margin-bottom:4px}.sf-read-more{border:none;background:none;color:#0891b2;font-weight:600;font-size:13px;padding:0 0 8px;cursor:pointer}.sf-post-comp-text{font-size:14.5px;color:#1e293b;line-height:1.7;white-space:pre-wrap}.sf-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.sf-tab{display:flex;align-items:center;gap:6px;padding:8px 18px;border-radius:24px;border:2px solid #e2e8f0;background:#fff;font-size:14px;font-weight:600;cursor:pointer;color:#475569;transition:all .18s}.sf-tab:hover{border-color:#94a3b8;background:#f8fafc}.sf-tab--active{box-shadow:0 2px 8px #0000001f}.sf-composer{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000014;padding:16px 18px 14px;margin-bottom:20px;border:1px solid #e2e8f0}.sf-composer-top{display:flex;gap:12px;align-items:flex-start;margin-bottom:10px}.sf-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.5px}.sf-composer-input{flex:1;border:none;outline:none;font-size:15px;resize:none;background:#f1f5f9;border-radius:10px;padding:10px 14px;line-height:1.5;color:#1e293b;width:100%}.sf-composer-input::-moz-placeholder{color:#94a3b8}.sf-composer-input::placeholder{color:#94a3b8}.sf-composer-footer{display:flex;justify-content:space-between;align-items:center;padding-top:10px;border-top:1px solid #f1f5f9;margin-top:4px}.sf-char-count{font-size:12px;color:#94a3b8}.sf-post-btn{color:#fff;font-weight:700;border:none;border-radius:8px;padding:8px 24px;font-size:14px;cursor:pointer;transition:opacity .15s,transform .1s;letter-spacing:.2px}.sf-post-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.sf-post-btn:disabled{background:#cbd5e1!important;color:#94a3b8;cursor:not-allowed}.sf-error{color:#e11d48;font-size:13px;margin-top:8px}.sf-posts{display:flex;flex-direction:column;gap:14px}.sf-post{background:#fff;border-radius:14px;box-shadow:0 2px 12px #00000012;border:1px solid #e2e8f0;overflow:hidden;transition:box-shadow .18s}.sf-post:hover{box-shadow:0 4px 20px #0000001c}.sf-post-header{display:flex;align-items:center;gap:10px;padding:14px 16px 10px;background:var(--cat-bg, #f8fafc);border-bottom:1px solid #f1f5f9}.sf-post-meta{flex:1;display:flex;flex-direction:column;gap:2px}.sf-post-author{font-weight:700;font-size:15px;color:#1e293b}.sf-post-time{font-size:12px;color:#94a3b8}.sf-post-badge{font-size:12px;font-weight:700;padding:4px 10px;border-radius:20px;white-space:nowrap}.sf-delete-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 6px;border-radius:6px;color:#94a3b8;transition:background .15s,color .15s;line-height:1}.sf-delete-btn:hover{background:#fee2e2;color:#e11d48}.sf-cat-select{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.sf-cat-btn{padding:7px 18px;border-radius:24px;border:2px solid #e2e8f0;background:#f8fafc;font-size:13.5px;font-weight:700;cursor:pointer;color:#475569;transition:all .15s;white-space:nowrap}.sf-cat-btn:hover{border-color:#94a3b8;background:#f1f5f9}.sf-cat-btn--active{box-shadow:0 2px 10px #00000021}.sf-comp-divider{text-align:center;font-size:13px;font-weight:700;color:#64748b;background:#f1f5f9;border-radius:8px;padding:8px 12px;margin:4px 0;letter-spacing:.3px}.sf-comp-row3{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}@media (max-width: 520px){.sf-comp-row3{grid-template-columns:1fr}}.sf-filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:16px;padding:10px 14px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.sf-filter-label{font-size:12.5px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-right:4px}.sf-post-school{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.sf-post-school span{font-size:11.5px;color:#64748b;background:#f1f5f9;padding:2px 8px;border-radius:12px;font-weight:600}.sf-post-head{display:flex;align-items:flex-start;gap:11px;padding:13px 14px 11px;background:#f8fafc}.sf-post-info{flex:1;min-width:0}.sf-post-name{display:block;font-weight:700;font-size:14.5px;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sf-post-sub{display:flex;align-items:center;gap:6px;margin-top:3px;flex-wrap:wrap}.sf-post-time{font-size:11.5px;color:#94a3b8}.sf-del-btn{background:none;border:none;color:#cbd5e1;font-size:14px;cursor:pointer;padding:4px 7px;border-radius:6px;line-height:1;transition:background .15s,color .15s;flex-shrink:0;margin-left:auto}.sf-del-btn:hover{background:#fee2e2;color:#e11d48}.sf-post-body{padding:14px 18px 16px;font-size:15px;color:#1e293b;line-height:1.65;white-space:pre-line;word-break:break-word}.sf-state{text-align:center;color:#94a3b8;font-size:15px;padding:36px 0}.sf-empty-icon{font-size:40px;margin-bottom:10px}.app-footer{background:#1a1a2e;color:#ccc;padding:0;margin-top:auto;width:100%}.footer-inner{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:32px;max-width:none;width:100%;margin:0;padding:32px 24px 20px;box-sizing:border-box}.footer-brands-title,.footer-contact-title{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:#888;margin-bottom:14px;font-weight:600}.footer-brands-list{display:flex;flex-wrap:wrap;gap:20px;align-items:center}.footer-brand-item{display:flex;flex-direction:column;align-items:center;gap:6px;text-decoration:none;color:#ddd;font-size:13px;font-weight:500;transition:opacity .2s}.footer-brand-item:hover{opacity:.8}.footer-brand-logo{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #333}.footer-brand-uclass{cursor:default}.footer-uclass-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#6c63ff,#4ecdc4);display:flex;align-items:center;justify-content:center;font-size:22px;border:2px solid #333}.footer-contact-num{color:#ddd;text-decoration:none;font-size:15px;font-weight:500;display:block}.footer-contact-num:hover{color:#fff}.footer-dpo-trust{border-top:1px solid #2a2a3e;padding:20px 24px;background:linear-gradient(180deg,#12122a,#0f1729)}.footer-dpo-trust__link{display:flex;align-items:center;gap:16px;max-width:520px;margin:0 auto;text-decoration:none;color:#e2e8f0;padding:12px 16px;border-radius:12px;border:1px solid rgba(74,159,212,.35);background:#1e5a9e1f;transition:background .2s,border-color .2s}.footer-dpo-trust__link:hover{background:#1e5a9e38;border-color:#7ec8f780}.footer-dpo-trust__logo{height:44px;width:auto;flex-shrink:0}.footer-dpo-trust__text{display:flex;flex-direction:column;gap:2px;line-height:1.35}.footer-dpo-trust__badge{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;font-weight:600}.footer-dpo-trust__text strong{font-size:15px;color:#7ec8f7;font-weight:700}.footer-dpo-trust__sub{font-size:12px;color:#cbd5e1;font-weight:500}@media (max-width: 480px){.footer-dpo-trust__link{flex-direction:column;text-align:center;gap:10px}}.footer-powered{border-top:1px solid #2a2a3e;padding:14px 24px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:13px;color:#888}.footer-powered-logo{width:24px;height:24px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.footer-powered a{color:#f0a500;text-decoration:none;font-weight:600}.footer-powered a:hover{text-decoration:underline}.footer-install-btn{margin-top:16px;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;padding:10px 18px;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s;letter-spacing:.3px}.footer-install-btn:hover{opacity:.88;transform:translateY(-1px)}.footer-install-icon{font-size:18px;line-height:1}.footer-umunsimedia{border-top:1px solid #2a2a3e;padding:14px 24px;background:#112}.footer-umunsimedia-link{display:flex;align-items:center;gap:12px;text-decoration:none;max-width:none;margin:0;color:#f59e0b;font-size:13px;transition:opacity .2s}.footer-umunsimedia-link:hover{opacity:.85}.footer-umunsimedia-logo{width:36px;height:36px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #f59e0b;flex-shrink:0}.footer-umunsimedia-link strong{color:#fbbf24}.app-wa-shell{--wa-green: #25d366;--wa-green-dark: #128c7e;--wa-chat-bg: #e5ddd5;--wa-text: #111b21;--wa-muted: #667781}.app-wa-shell .dashboard,.app-wa-shell .phub-page,.app-wa-shell .class-page{font-family:Segoe UI,system-ui,-apple-system,sans-serif}.app-wa-shell .staff-hub-page .dash-main,.app-wa-shell .student-wa-dashboard .dash-main{background:var(--wa-chat-bg)}.app-wa-shell .phub-card,.app-wa-shell .empty-state,.app-wa-shell .discussion-msg,.app-wa-shell .item-card{background:#fff;border-radius:8px;box-shadow:0 1px 2px #0000000f}.app-wa-shell .tabs{background:#f0f2f5;padding:6px;border-radius:12px;gap:4px}.app-wa-shell .tab{border-radius:20px;border:none;background:transparent;color:var(--wa-muted)}.app-wa-shell .tab.active{background:#dcf8c6;color:#075e54;font-weight:600}.app-wa-shell .class-hero{background:#fff;color:var(--wa-text, #111b21);border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 1px 2px #0000000f}.app-wa-shell .class-hero h1{color:#111b21}.app-wa-shell .class-hero .subject{color:#667781;opacity:1}.app-wa-shell .class-hero-code{background:#f0f2f5}.app-wa-shell .class-hero-code .code-label{color:#667781;opacity:1}.app-wa-shell .class-hero-code .code-big{color:#075e54}.app-wa-shell .discussion-list{background:var(--wa-chat-bg)}.app-wa-shell .discussion-msg{border-radius:8px;margin-bottom:8px}.app-wa-shell .teacher-msg{background:#dcf8c6}.app-wa-shell .btn-primary{background:var(--wa-green-dark);border-color:var(--wa-green-dark)}.app-wa-shell .alert-error{border-radius:8px}.app-wa-shell{width:100%;max-width:none;min-height:100dvh}.app-wa-shell>div:nth-child(2){flex:1;width:100%;max-width:none;min-height:0}.app-wa-shell .dashboard,.app-wa-shell .phub-page,.app-wa-shell .class-page{width:100%;max-width:none}.app-wa-shell .dash-main,.app-wa-shell .class-main{max-width:none!important;width:100%!important;margin-left:0!important;margin-right:0!important;box-sizing:border-box}.app-wa-shell .staff-hub-page .dash-main,.app-wa-shell .student-dashboard-classic .dash-main{max-width:none!important}.app-wa-shell .phub-panel{max-width:none!important;margin:0!important;width:100%;box-sizing:border-box;padding-left:20px;padding-right:20px}.app-wa-shell .footer-inner{max-width:none;width:100%;padding-left:24px;padding-right:24px}.app-wa-shell--chat-fullscreen .app-footer{display:none!important}
