@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;700;900&family=Inter:wght@400;600&display=swap";code[class*=language-],pre[class*=language-]{color:#ccc;background:none;font-family:Consolas,Monaco,Andale Mono,Ubuntu Mono,monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;hyphens:none}pre[class*=language-]{padding:1em;margin:.5em 0;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background:#2d2d2d}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal}.token.comment,.token.block-comment,.token.prolog,.token.doctype,.token.cdata{color:#999}.token.punctuation{color:#ccc}.token.tag,.token.attr-name,.token.namespace,.token.deleted{color:#e2777a}.token.function-name{color:#6196cc}.token.boolean,.token.number,.token.function{color:#f08d49}.token.property,.token.class-name,.token.constant,.token.symbol{color:#f8c555}.token.selector,.token.important,.token.atrule,.token.keyword,.token.builtin{color:#cc99cd}.token.string,.token.char,.token.attr-value,.token.regex,.token.variable{color:#7ec699}.token.operator,.token.entity,.token.url{color:#67cdcc}.token.important,.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.inserted{color:green}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}body{-webkit-user-select:none;-moz-user-select:none;user-select:none}input,textarea,[contenteditable=true],pre,code,.cm-editor,.monaco-editor,.CodeMirror{-webkit-user-select:text;-moz-user-select:text;user-select:text}.lesson-tabs{display:flex;gap:1rem;padding:1rem 2rem 0;background:var(--color-bg-main);border-bottom:2px solid #e5e7eb}.lesson-tab-btn{padding:.75rem 1.5rem;font-weight:600;color:#6b7280;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:all .2s}.lesson-tab-btn:hover{color:#374151;background-color:#f3f4f6;border-radius:8px 8px 0 0}.lesson-tab-btn.active{color:#4f46e5;border-bottom-color:#4f46e5;background-color:#eff6ff;border-radius:8px 8px 0 0}.lesson-view-wrapper{display:flex;flex-direction:column;height:100%}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.bottom-0{bottom:0}.left-0{left:0}.right-2{right:.5rem}.top-0{top:0}.top-2{top:.5rem}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-1{margin-bottom:.25rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-10{margin-top:2.5rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.flow-root{display:flow-root}.grid{display:grid}.hidden{display:none}.h-2{height:.5rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-\[85vh\]{height:85vh}.h-full{height:100%}.max-h-\[90vh\]{max-height:90vh}.min-h-screen{min-height:100vh}.w-6{width:1.5rem}.w-full{width:100%}.min-w-\[130px\]{min-width:130px}.min-w-\[150px\]{min-width:150px}.min-w-\[180px\]{min-width:180px}.max-w-2xl{max-width:42rem}.max-w-7xl{max-width:80rem}.max-w-lg{max-width:32rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.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))}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.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))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(229 231 235 / var(--tw-divide-opacity, 1))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l-4{border-left-width:4px}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.border-green-500{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.border-orange-500{--tw-border-opacity: 1;border-color:rgb(249 115 22 / var(--tw-border-opacity, 1))}.border-purple-500{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.border-red-300{--tw-border-opacity: 1;border-color:rgb(252 165 165 / var(--tw-border-opacity, 1))}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-gray-400{--tw-bg-opacity: 1;background-color:rgb(156 163 175 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-orange-500{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity, 1))}.bg-purple-600{--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity, 1))}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-opacity-50{--tw-bg-opacity: .5}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.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-4{padding-top:1rem;padding-bottom:1rem}.pb-2{padding-bottom:.5rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-orange-600{--tw-text-opacity: 1;color:rgb(234 88 12 / var(--tw-text-opacity, 1))}.text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.text-yellow-700{--tw-text-opacity: 1;color:rgb(161 98 7 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.opacity-10{opacity:.1}.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-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)}.outline{outline-style:solid}.ring{--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(3px + 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)}.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-sm{--tw-blur: blur(4px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-primary-light: #e0e7ff;--color-secondary: #ec4899;--color-accent: #8b5cf6;--color-success: #10b981;--color-warning: #f59e0b;--color-bg-main: #f8fafc;--color-bg-card: #ffffff;--color-bg-panel: #ffffff;--color-text-main: #1e293b;--color-text-muted: #64748b;--color-text-light: #94a3b8;--font-heading: "Nunito", sans-serif;--font-body: "Inter", sans-serif;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-soft: 0 20px 40px -10px rgba(99, 102, 241, .15);--tech-glow-primary: rgba(99, 102, 241, .4);--tech-glow-accent: rgba(139, 92, 246, .3);--tech-glow-cyan: rgba(34, 211, 238, .25);--tech-gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--tech-gradient-2: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--tech-gradient-3: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;padding:0;background-color:#f0f4f8;background-image:radial-gradient(circle at 1px 1px,rgba(99,102,241,.03) 1px,transparent 1px),radial-gradient(ellipse at 80% 10%,rgba(99,102,241,.12) 0%,transparent 50%),radial-gradient(ellipse at 20% 90%,rgba(139,92,246,.1) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(79,70,229,.05) 0%,transparent 60%),linear-gradient(180deg,#f8fafc,#f0f4f8,#e8eef5);background-size:30px 30px,100% 100%,100% 100%,100% 100%,100% 100%;color:var(--color-text-main);font-family:var(--font-body);-webkit-font-smoothing:antialiased;overflow-x:hidden}.app-container{min-height:100vh;display:flex;flex-direction:column}.site-footer{height:32px;position:relative}.site-footer span{position:absolute;left:12px;top:0;width:140px;height:100%;display:flex;align-items:center;font-size:0;color:transparent;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow:hidden}.site-footer span:hover{font-size:10px;color:#d0d5dc;width:auto}.main-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 3rem;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(226,232,240,.8);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}.header-brand{display:flex;align-items:center;gap:.5rem;text-decoration:none;flex-shrink:0}.header-logo{height:28px;width:auto}.main-header h1{font-family:var(--font-heading);font-weight:900;font-size:1.4rem;margin:0;white-space:nowrap;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 50%,#06b6d4 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.02em}.main-header nav{display:flex;align-items:center;gap:2rem}.main-header nav a{text-decoration:none;font-weight:700;font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;transition:all .3s ease;padding:.55rem 1.1rem;border-radius:999px;position:relative;color:#1e40af;background:linear-gradient(135deg,#3b82f614,#6366f11f);border:1px solid rgba(59,130,246,.2);box-shadow:0 1px 3px #3b82f61a}.main-header nav a:hover{background:linear-gradient(135deg,#3b82f626,#8b5cf633);border-color:#6366f166;color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #6366f140}.lang-toggle{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid #e2e8f0;color:var(--color-text-muted);padding:.5rem 1rem;border-radius:99px;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:var(--shadow-sm)}.lang-toggle:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.disabled-link{color:var(--color-text-muted);cursor:not-allowed;text-decoration:line-through;opacity:.6}.hero-section{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:6rem 2rem;min-height:80vh;background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;overflow:hidden}.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#ffffffd9,#f0fdf4cc,#f0f9ffd9);z-index:1}.hero-content{position:relative;z-index:10;max-width:800px;animation:fadeInUp .8s ease-out}.hero-title{font-family:var(--font-heading);font-size:4.5rem;line-height:1.1;font-weight:900;margin-bottom:1.5rem;color:var(--color-primary);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-subtitle{font-size:1.4rem;color:#475569;margin-bottom:3rem;text-align:center;line-height:1.7;font-weight:500;letter-spacing:.02em;max-width:600px;margin-left:auto;margin-right:auto}.cta-button{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;border:none;padding:1.2rem 3.5rem;font-size:1.2rem;font-weight:800;border-radius:9999px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 10px 25px -5px #6366f166}.cta-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 20px 30px -10px #6366f180}.dashboard{padding:3rem;max-width:1400px;margin:0 auto;width:100%;animation:fadeIn .6s ease-out}.dashboard h2{font-family:var(--font-heading);font-size:2.4rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,#1e293b 0%,var(--color-primary) 50%,var(--color-secondary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em;position:relative}.dashboard h2:after{content:"";position:absolute;bottom:-8px;left:0;width:60px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:2px}.dashboard-welcome{font-size:1.1rem;color:var(--color-text-muted);margin-bottom:2rem}.dashboard-tabs{display:flex;justify-content:center;gap:1rem;margin:2rem 0 3rem;background:#f1f5f9;padding:.5rem;border-radius:999px;width:-moz-fit-content;width:fit-content;margin-left:auto;margin-right:auto}.tab-btn{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:999px;cursor:pointer;transition:all .2s ease;color:var(--color-text-muted);background:transparent}.tab-btn.active{background:#fff;color:var(--color-primary);box-shadow:var(--shadow-sm)}.tab-btn:hover:not(.active){color:var(--color-text-main)}.modules-section h3{font-family:var(--font-heading);font-size:1.6rem;font-weight:800;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#334155 0%,var(--color-primary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.02em;text-transform:uppercase;position:relative;padding-left:16px}.modules-section h3:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:70%;background:linear-gradient(180deg,var(--color-primary),var(--color-secondary));border-radius:2px}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem}.module-card{background:#fff;border-radius:20px;padding:2rem;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;border:1px solid #f1f5f9;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;height:100%;display:flex;flex-direction:column;align-items:center}.module-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-soft);border-color:var(--color-primary-light)}.module-icon{font-size:3.5rem;margin-bottom:1.5rem;transition:transform .3s ease;background:#f8fafc;width:100px;height:100px;display:flex;align-items:center;justify-content:center;border-radius:50%}.module-card:hover .module-icon{transform:scale(1.1) rotate(5deg);background:var(--color-primary-light)}.module-image-container{width:100%;margin-bottom:1.25rem;border-radius:16px;overflow:hidden;background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.module-image-container.learning-image{height:400px;background:linear-gradient(135deg,#f0f4ff,#fff,#f5f0ff)}.learning-image .module-image{-o-object-fit:contain;object-fit:contain}.learning-grid{grid-template-columns:repeat(2,1fr);max-width:1300px;margin:0 auto;gap:3rem}.learning-grid .module-card{padding:1.5rem}.module-image-container.practice-image{height:220px;border-radius:16px;background:linear-gradient(135deg,#e8f4f8,#f0f7fa,#e8f0f8)}.practice-grid .module-card{padding:1.25rem}.practice-image .module-image{-o-object-fit:cover;object-fit:cover;width:100%;height:100%}.practice-grid .module-card:nth-child(2) .module-image,.practice-grid .module-card:nth-child(3) .module-image{transform:scale(1.15)}.module-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.module-card:hover .module-image{transform:scale(1.05)}.module-card h4{font-family:var(--font-heading);font-size:1.3rem;margin-bottom:.75rem;font-weight:800;background:linear-gradient(135deg,#1e293b,#475569);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.01em;transition:all .3s ease}.module-card:hover h4{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;background-clip:text}.module-desc{color:#64748b;font-size:.95rem;margin-bottom:1.5rem;line-height:1.6;flex-grow:1;font-weight:500;letter-spacing:.01em}.module-status{display:inline-flex;align-items:center;background:#f1f5f9;padding:.5rem 1.2rem;border-radius:99px;font-size:.85rem;color:var(--color-text-muted);font-weight:600;margin-top:auto;transition:all .2s}.module-card:hover .module-status{background:var(--color-primary);color:#fff}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-container{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem;background:linear-gradient(135deg,#f0fdf4,#fff,#f0f9ff)}.auth-logo{display:block;max-height:80px;width:auto;margin:0 auto 1.5rem}.auth-card{background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:3rem;width:100%;max-width:450px;box-shadow:var(--shadow-lg);animation:fadeInUp .5s ease-out}.auth-card h2{font-family:var(--font-heading);font-size:2rem;color:var(--color-text-main);margin-bottom:2rem;text-align:center;font-weight:800}.form-group label{color:var(--color-text-main);font-weight:600}.form-group input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;color:var(--color-text-main)}.form-group input:focus{background:#fff;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.auth-button{background:var(--color-primary);border-radius:12px;padding:1.2rem;box-shadow:0 4px 6px -1px #6366f166}.auth-button:hover{background:var(--color-primary-hover);transform:translateY(-2px);box-shadow:0 10px 15px -3px #6366f180}.lesson-view{background:#f8fafc;gap:1.5rem}.lesson-content,.lesson-playground{background:#fff;border:1px solid #e2e8f0;border-radius:20px;box-shadow:var(--shadow-sm)}.lesson-content h2{color:var(--color-text-main)}.concept-badge{background:var(--color-primary-light);color:var(--color-primary)}.code-block{background:#1e293b;border-radius:12px}.example-section{background:#f8fafc;border-left:4px solid var(--color-primary);border-radius:8px}.challenge-section{background:#fff1f2;border-left:4px solid var(--color-secondary)}.lesson-item.completed{border-color:var(--color-success);background:#ecfdf5}.module-page{max-width:1000px;margin:0 auto;padding:2rem}.module-header h1{font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--color-text-main);margin-top:1rem}.back-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:var(--color-text-muted);font-size:.875rem;cursor:pointer;transition:all .2s}.back-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.units-container{display:flex;flex-direction:column;gap:1.5rem}.unit-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:var(--shadow-md);border:1px solid #e2e8f0}.unit-card h2{padding:1.25rem 1.5rem;margin:0;font-family:var(--font-heading);font-size:1.25rem;font-weight:700;color:var(--color-text-main);background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(255,255,255,0) 100%);border-bottom:1px solid #e2e8f0}.lessons-list{display:flex;flex-direction:column}.lesson-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:all .2s ease}.lesson-item:last-child{border-bottom:none}.lesson-item:hover{background:var(--color-primary-light);transform:translate(4px)}.lesson-item.completed{background:#ecfdf5}.lesson-item.completed .lesson-title{color:var(--color-success)}.lesson-item.locked{opacity:.5;cursor:not-allowed}.lesson-info{display:flex;flex-direction:column;gap:.25rem}.lesson-title{font-weight:600;font-size:1rem;color:var(--color-text-main)}.lesson-concept{font-size:.875rem;color:var(--color-text-muted)}.lesson-status{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:#f1f5f9;color:var(--color-text-muted);transition:all .2s}.lesson-item:hover .lesson-status{background:var(--color-primary);color:#fff}.lesson-item.completed .lesson-status{background:var(--color-success);color:#fff}.loading{display:flex;align-items:center;justify-content:center;min-height:300px;font-size:1.125rem;color:var(--color-text-muted)}:root{--color-border: #e2e8f0;--color-bg-elevated: #f8fafc;--color-primary-dark: #4f46e5}.auth-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:2rem;position:relative;z-index:10}.auth-card{background:#ffffffe6;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);padding:3.5rem;border-radius:24px;box-shadow:0 25px 50px -12px #0000001a,0 0 0 1px #fff9 inset;width:100%;max-width:440px;animation:authSlideUp .6s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent))}.auth-card h2{font-family:var(--font-heading);font-size:2.25rem;font-weight:800;text-align:center;margin-bottom:2.5rem;color:var(--color-text-main);background:linear-gradient(135deg,var(--color-primary),var(--color-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.02em}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.9rem;font-weight:600;color:var(--color-text-main);margin-bottom:.5rem;margin-left:.25rem}.form-group input{width:100%;padding:.875rem 1.25rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-family:var(--font-body);transition:all .2s cubic-bezier(.4,0,.2,1);background:#f8fafc;color:var(--color-text-main)}.form-group input:hover{border-color:#cbd5e1}.form-group input:focus{outline:none;border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px var(--color-primary-light);transform:translateY(-1px)}.form-group input::-moz-placeholder{color:#94a3b8}.form-group input::placeholder{color:#94a3b8}.error-message{background:#fef2f2;border:1px solid #fee2e2;color:#ef4444;padding:.75rem;border-radius:8px;font-size:.875rem;margin-bottom:1.5rem;text-align:center;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem}.auth-button{width:100%;padding:1rem;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;border:none;border-radius:14px;font-size:1.125rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);margin-top:1rem;box-shadow:0 4px 6px -1px #6366f133;display:flex;justify-content:center;align-items:center;gap:.5rem}.auth-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px -5px #6366f166;filter:brightness(1.05)}.auth-button:active{transform:translateY(0)}.auth-button:disabled{opacity:.7;cursor:not-allowed;transform:none!important}.auth-link{text-align:center;margin-top:2rem;color:var(--color-text-muted);font-size:.95rem;padding-top:1.5rem;border-top:1px solid #f1f5f9}.auth-link a{color:var(--color-primary);text-decoration:none;font-weight:700;margin-left:.5rem;position:relative;transition:color .2s}.auth-link a:hover{color:var(--color-primary-dark)}.auth-link a:after{content:"";position:absolute;width:100%;height:2px;bottom:-2px;left:0;background-color:var(--color-primary);transform:scaleX(0);transform-origin:bottom right;transition:transform .3s ease-out}.auth-link a:hover:after{transform:scaleX(1);transform-origin:bottom left}@keyframes authSlideUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:640px){.auth-card{padding:2rem}.auth-card h2{font-size:1.75rem}}.dashboard:before,.dashboard:after{content:"";position:fixed;border-radius:50%;filter:blur(100px);opacity:.4;pointer-events:none;z-index:-1}.dashboard:before{width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.15) 0%,transparent 70%);top:-200px;right:-200px;animation:floatOrb 20s ease-in-out infinite}.dashboard:after{width:500px;height:500px;background:radial-gradient(circle,rgba(139,92,246,.12) 0%,transparent 70%);bottom:-150px;left:-150px;animation:floatOrb 25s ease-in-out infinite reverse}@keyframes floatOrb{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-20px) scale(1.05)}50%{transform:translate(-20px,30px) scale(.95)}75%{transform:translate(20px,20px) scale(1.02)}}.module-card{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);box-shadow:0 8px 32px #6366f114,0 0 0 1px #ffffff1a inset;transition:all .4s cubic-bezier(.4,0,.2,1)}.module-card:hover{background:#fffffff2;border-color:#6366f133;box-shadow:0 20px 50px #6366f126,0 0 0 1px #6366f11a,0 0 40px #6366f10d;transform:translateY(-8px)}.module-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent 0%,rgba(99,102,241,.5) 20%,rgba(139,92,246,.6) 50%,rgba(99,102,241,.5) 80%,transparent 100%);border-radius:20px 20px 0 0;opacity:0;transition:opacity .3s ease}.module-card:hover:before{opacity:1}.hero-section:after{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(99,102,241,.08) 1px,transparent 1px);background-size:40px 40px;z-index:0;animation:gridPulse 8s ease-in-out infinite}@keyframes gridPulse{0%,to{opacity:.3}50%{opacity:.6}}.cta-button{position:relative;overflow:hidden}.cta-button:before{content:"";position:absolute;top:50%;left:50%;width:120%;height:120%;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 60%);transform:translate(-50%,-50%) scale(0);transition:transform .5s ease}.cta-button:hover:before{transform:translate(-50%,-50%) scale(1)}.modules-section h3:before{content:"";display:inline-block;width:4px;height:1.2em;background:var(--tech-gradient-1);border-radius:2px;margin-right:12px;vertical-align:middle;box-shadow:0 0 10px var(--tech-glow-primary)}.tab-btn{position:relative;overflow:hidden}.tab-btn.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40%;height:2px;background:var(--tech-gradient-1);border-radius:2px;box-shadow:0 0 8px var(--tech-glow-primary)}@keyframes float{0%,to{transform:translateY(0) translate(0);opacity:.3}50%{transform:translateY(-20px) translate(10px);opacity:.6}}.floating-shapes{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;overflow:hidden}.floating-shapes>div{position:absolute;opacity:.75}.shape-circle{border-radius:50%;background:linear-gradient(135deg,#6366f14d,#8b5cf638)}.shape-1{width:180px;height:180px;top:12%;right:6%;animation:floatShape1 18s ease-in-out infinite}.shape-2{width:130px;height:130px;bottom:18%;left:5%;background:linear-gradient(135deg,#4f46e540,#6366f12e);animation:floatShape2 22s ease-in-out infinite}.shape-ring{border-radius:50%;border:3px solid rgba(99,102,241,.35);background:transparent}.shape-3{width:220px;height:220px;top:35%;right:3%;animation:floatShape3 25s ease-in-out infinite}.shape-square{border-radius:16px;background:linear-gradient(45deg,#8b5cf638,#6366f126);transform:rotate(15deg)}.shape-4{width:100px;height:100px;top:55%;left:10%;animation:floatShape4 20s ease-in-out infinite}.shape-dot{border-radius:50%;background:#6366f180;box-shadow:0 0 20px #6366f166}.shape-5{width:20px;height:20px;top:22%;left:22%;animation:floatDot 15s ease-in-out infinite}.shape-6{width:16px;height:16px;bottom:30%;right:18%;background:#8b5cf68c;box-shadow:0 0 18px #8b5cf666;animation:floatDot 12s ease-in-out infinite reverse}.shape-triangle{width:0;height:0;border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:100px solid rgba(99,102,241,.18);background:transparent}.shape-7{top:62%;right:20%;animation:floatShape5 28s ease-in-out infinite}@keyframes floatShape1{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(-20px,15px) rotate(5deg)}50%{transform:translate(15px,-20px) rotate(-3deg)}75%{transform:translate(-10px,-15px) rotate(8deg)}}@keyframes floatShape2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(25px,-20px) scale(1.05)}66%{transform:translate(-15px,25px) scale(.95)}}@keyframes floatShape3{0%,to{transform:translate(0) rotate(0)}50%{transform:translate(-30px,20px) rotate(180deg)}}@keyframes floatShape4{0%,to{transform:translate(0) rotate(15deg)}25%{transform:translate(20px,-15px) rotate(25deg)}50%{transform:translate(-10px,20px) rotate(5deg)}75%{transform:translate(15px,10px) rotate(35deg)}}@keyframes floatShape5{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(-20px,-15px) rotate(10deg)}66%{transform:translate(25px,10px) rotate(-5deg)}}@keyframes floatDot{0%,to{transform:translate(0);opacity:.25}50%{transform:translate(30px,-25px);opacity:.5}}.module-page{display:flex;flex-direction:column;min-height:calc(100vh - 80px);padding:2rem 3rem;max-width:1400px;margin:0 auto;width:100%}.module-header{margin-bottom:2rem}.module-header h1{font-family:var(--font-heading);font-size:2.2rem;font-weight:800;margin-top:1rem;background:linear-gradient(135deg,#1e293b 0%,var(--color-primary) 50%,var(--color-secondary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.01em;position:relative;padding-bottom:.75rem}.module-header h1:after{content:"";position:absolute;bottom:0;left:0;width:80px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:2px}.back-btn{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#3b82f614,#6366f11f);border:1px solid rgba(59,130,246,.2);color:#1e40af;padding:.6rem 1.2rem;border-radius:999px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .3s ease}.back-btn:hover{background:linear-gradient(135deg,#3b82f626,#8b5cf633);border-color:#6366f166;transform:translate(-3px);box-shadow:0 4px 12px #6366f133}.units-container{display:flex;flex-direction:column;gap:2rem}.unit-card{background:#fff;border-radius:20px;padding:2rem;border:1px solid #f1f5f9;box-shadow:var(--shadow-sm)}.unit-card h2{font-family:var(--font-heading);font-size:1.5rem;font-weight:800;margin-bottom:1.5rem;background:linear-gradient(135deg,#334155 0%,var(--color-primary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.01em;display:flex;align-items:center;gap:.75rem;padding-left:16px;position:relative}.unit-card h2:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:60%;background:linear-gradient(180deg,var(--color-primary),var(--color-secondary));border-radius:2px}.lessons-list{display:flex;flex-direction:column;gap:.75rem}.lesson-item{display:flex;align-items:center;padding:1.25rem 1.5rem;background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid #e2e8f0;border-radius:16px;cursor:pointer;transition:all .3s ease}.lesson-item:hover{background:linear-gradient(135deg,#6366f10d,#8b5cf614);border-color:#6366f14d;transform:translate(8px);box-shadow:0 4px 15px #6366f126}.lesson-item.completed{border-left:4px solid #22c55e}.lesson-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.lesson-title{font-weight:700;font-size:1.1rem;color:#1e293b;letter-spacing:-.01em;transition:all .3s ease}.lesson-item:hover .lesson-title{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.lesson-concept{font-size:.9rem;color:#64748b;font-weight:500}.lesson-status{color:#94a3b8;transition:all .3s ease}.lesson-item:hover .lesson-status{color:var(--color-primary);transform:translate(3px)}.back-to-dashboard{display:inline-block;font-size:14px;color:var(--color-primary);text-decoration:none;font-weight:600;margin-bottom:16px;transition:all .2s}.back-to-dashboard:hover{color:var(--color-primary-hover);transform:translate(-3px)}.project-hero{display:flex;gap:28px;align-items:center;background:#fff;border-radius:20px;padding:32px 36px;margin-bottom:24px;border:1px solid #f1f5f9;box-shadow:var(--shadow-sm)}.project-hero__icon{font-size:4.5rem;width:110px;height:110px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f4ff,#f5f0ff);border-radius:50%;flex-shrink:0}.project-hero__body{flex:1}.project-hero__title{font-family:var(--font-heading);font-size:1.8rem;font-weight:800;margin:0 0 8px;background:linear-gradient(135deg,#1e293b 0%,var(--color-primary) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.01em}.project-hero__subtitle{font-size:.95rem;color:#64748b;margin:0 0 20px;line-height:1.6}.project-hero__grade{color:var(--color-primary);text-decoration:none;font-weight:600}.project-hero__grade:hover{text-decoration:underline}.project-hero__cta{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;padding:11px 24px;border-radius:99px;text-decoration:none;font-weight:700;font-size:.95rem;box-shadow:0 4px 14px #6366f14d;transition:all .25s cubic-bezier(.4,0,.2,1)}.project-hero__cta:hover{transform:translateY(-2px);box-shadow:0 8px 22px #6366f16b}.student-notice{display:flex;gap:16px;align-items:flex-start;background:#f0fbf7;border:2px solid #2dd4bf;border-radius:16px;padding:20px 24px;margin-top:16px}.student-notice__icon{font-size:2rem;line-height:1}.student-notice__title{font-size:1rem;font-weight:700;color:#0f766e;margin-bottom:4px}.student-notice__body{font-size:.9rem;color:#115e59;line-height:1.6}.lesson-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}.lesson-row{display:flex;gap:18px;padding:18px 22px;background:#fff;border:1px solid #f1f5f9;border-radius:14px;transition:all .2s}.lesson-row:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-sm)}.lesson-row__num{flex-shrink:0;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;width:76px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:700;font-size:13px}.lesson-row__body{flex:1}.lesson-row__title{font-size:1rem;font-weight:700;color:#1e293b;margin-bottom:10px}.lesson-row__common{display:inline-block;background:#f3f4f6;color:#6b7280;font-size:.85rem;padding:5px 13px;border-radius:99px}.lesson-row__files{display:flex;flex-wrap:wrap;gap:9px}.lesson-row__file{display:inline-flex;align-items:center;gap:5px;background:#fff;border:1px solid #e2e8f0;border-radius:99px;padding:6px 14px;font-size:.85rem;color:#374151;text-decoration:none;font-weight:600;transition:all .15s}.lesson-row__file:hover{border-color:var(--color-primary);background:#eef2ff;color:var(--color-primary)}.hover\:bg-gray-200:hover{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-700:hover{--tw-bg-opacity: 1;background-color:rgb(126 34 206 / var(--tw-bg-opacity, 1))}.hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.hover\:text-purple-800:hover{--tw-text-opacity: 1;color:rgb(107 33 168 / var(--tw-text-opacity, 1))}.hover\:text-red-900:hover{--tw-text-opacity: 1;color:rgb(127 29 29 / var(--tw-text-opacity, 1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-purple-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity, 1))}@media(min-width:768px){.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1024px){.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}
