@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Inter:wght@300;400;500;600&display=swap);*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background:0 0% 100%;--foreground:0 0% 3.9%;--card:0 0% 100%;--card-foreground:0 0% 3.9%;--popover:0 0% 100%;--popover-foreground:0 0% 3.9%;--primary:0 0% 9%;--primary-foreground:0 0% 98%;--secondary:0 0% 96.1%;--secondary-foreground:0 0% 9%;--muted:0 0% 96.1%;--muted-foreground:0 0% 45.1%;--accent:0 0% 96.1%;--accent-foreground:0 0% 9%;--destructive:0 84.2% 60.2%;--destructive-foreground:0 0% 98%;--border:0 0% 89.8%;--input:0 0% 89.8%;--ring:0 0% 3.9%;--chart-1:12 76% 61%;--chart-2:173 58% 39%;--chart-3:197 37% 24%;--chart-4:43 74% 66%;--chart-5:27 87% 67%;--radius:0.5rem}.dark{--background:0 0% 3.9%;--foreground:0 0% 98%;--card:0 0% 3.9%;--card-foreground:0 0% 98%;--popover:0 0% 3.9%;--popover-foreground:0 0% 98%;--primary:0 0% 98%;--primary-foreground:0 0% 9%;--secondary:0 0% 14.9%;--secondary-foreground:0 0% 98%;--muted:0 0% 14.9%;--muted-foreground:0 0% 63.9%;--accent:0 0% 14.9%;--accent-foreground:0 0% 98%;--destructive:0 62.8% 30.6%;--destructive-foreground:0 0% 98%;--border:0 0% 14.9%;--input:0 0% 14.9%;--ring:0 0% 83.1%;--chart-1:220 70% 50%;--chart-2:160 60% 45%;--chart-3:30 80% 55%;--chart-4:280 65% 60%;--chart-5:340 75% 55%}*{border-color:#e5e5e5;border-color:hsl(var(--border))}body{background-color:#fff;background-color:hsl(var(--background));color:#0a0a0a;color:hsl(var(--foreground))}[data-debug-wrapper=true]{display:contents!important}[data-debug-wrapper=true]>*{border:inherit;column-gap:inherit;gap:inherit;margin:inherit;padding:inherit;row-gap:inherit}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.inset-y-0{bottom:0;top:0}.-bottom-12{bottom:-3rem}.-left-12{left:-3rem}.-right-12{right:-3rem}.-top-12{top:-3rem}.bottom-0{bottom:0}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.left-\[50\%\]{left:50%}.right-0{right:0}.right-1{right:.25rem}.right-2{right:.5rem}.right-4{right:1rem}.top-0{top:0}.top-1{top:.25rem}.top-1\/2{top:50%}.top-4{top:1rem}.top-\[1px\]{top:1px}.top-\[50\%\]{top:50%}.top-\[60\%\]{top:60%}.top-full{top:100%}.z-10{z-index:10}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[1\]{z-index:1}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-bottom:.25rem;margin-top:.25rem}.-ml-4{margin-left:-1rem}.-mt-4{margin-top:-1rem}.mb-1{margin-bottom:.25rem}.ml-1{margin-left:.25rem}.ml-auto{margin-left:auto}.mr-2{margin-right:.5rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-24{margin-top:6rem}.mt-4{margin-top:1rem}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1/1}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-navigation-menu-viewport-height\)\]{height:var(--radix-navigation-menu-viewport-height)}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.max-h-\[--radix-context-menu-content-available-height\]{max-height:var(--radix-context-menu-content-available-height)}.max-h-\[--radix-select-content-available-height\]{max-height:var(--radix-select-content-available-height)}.max-h-\[300px\]{max-height:300px}.max-h-\[var\(--radix-dropdown-menu-content-available-height\)\]{max-height:var(--radix-dropdown-menu-content-available-height)}.max-h-screen{max-height:100vh}.min-h-\[60px\]{min-height:60px}.w-10{width:2.5rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-4{width:1rem}.w-5{width:1.25rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-\[100px\]{width:100px}.w-\[1px\]{width:1px}.w-full{width:100%}.w-max{width:-webkit-max-content;width:max-content}.w-px{width:1px}.min-w-0{min-width:0}.min-w-10{min-width:2.5rem}.min-w-8{min-width:2rem}.min-w-9{min-width:2.25rem}.min-w-\[12rem\]{min-width:12rem}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-lg{max-width:32rem}.max-w-max{max-width:-webkit-max-content;max-width:max-content}.flex-1{flex:1 1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.grow-0{flex-grow:0}.basis-full{flex-basis:100%}.caption-bottom{caption-side:bottom}.border-collapse{border-collapse:collapse}.origin-\[--radix-context-menu-content-transform-origin\]{transform-origin:var(--radix-context-menu-content-transform-origin)}.origin-\[--radix-dropdown-menu-content-transform-origin\]{transform-origin:var(--radix-dropdown-menu-content-transform-origin)}.origin-\[--radix-hover-card-content-transform-origin\]{transform-origin:var(--radix-hover-card-content-transform-origin)}.origin-\[--radix-menubar-content-transform-origin\]{transform-origin:var(--radix-menubar-content-transform-origin)}.origin-\[--radix-popover-content-transform-origin\]{transform-origin:var(--radix-popover-content-transform-origin)}.origin-\[--radix-select-content-transform-origin\]{transform-origin:var(--radix-select-content-transform-origin)}.origin-\[--radix-tooltip-content-transform-origin\]{transform-origin:var(--radix-tooltip-content-transform-origin)}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-1\/2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y:-50%}.translate-x-\[-50\%\]{--tw-translate-x:-50%}.translate-x-\[-50\%\],.translate-y-\[-50\%\]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-\[-50\%\]{--tw-translate-y:-50%}.rotate-45{--tw-rotate:45deg}.rotate-45,.rotate-90{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate:90deg}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;user-select:none}.resize{resize:both}.list-none{list-style-type:none}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.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}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.375rem*var(--tw-space-y-reverse));margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem;border-radius:var(--radius)}.rounded-md{border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(.5rem - 4px);border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[10px\]{border-top-left-radius:10px;border-top-right-radius:10px}.rounded-tl-sm{border-top-left-radius:calc(.5rem - 4px);border-top-left-radius:calc(var(--radius) - 4px)}.border{border-width:1px}.border-2{border-width:2px}.border-y{border-top-width:1px}.border-b,.border-y{border-bottom-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-destructive{border-color:#ef4444;border-color:hsl(var(--destructive))}.border-destructive\/50{border-color:#ef444480;border-color:hsl(var(--destructive)/.5)}.border-input{border-color:#e5e5e5;border-color:hsl(var(--input))}.border-primary{border-color:#171717;border-color:hsl(var(--primary))}.border-primary\/50{border-color:#17171780;border-color:hsl(var(--primary)/.5)}.border-transparent{border-color:#0000}.border-l-transparent{border-left-color:#0000}.border-t-transparent{border-top-color:#0000}.bg-accent{background-color:#f5f5f5;background-color:hsl(var(--accent))}.bg-background{background-color:#fff;background-color:hsl(var(--background))}.bg-black\/80{background-color:#000c}.bg-border{background-color:#e5e5e5;background-color:hsl(var(--border))}.bg-card{background-color:#fff;background-color:hsl(var(--card))}.bg-destructive{background-color:#ef4444;background-color:hsl(var(--destructive))}.bg-foreground{background-color:#0a0a0a;background-color:hsl(var(--foreground))}.bg-muted{background-color:#f5f5f5;background-color:hsl(var(--muted))}.bg-muted\/50{background-color:#f5f5f580;background-color:hsl(var(--muted)/.5)}.bg-popover{background-color:#fff;background-color:hsl(var(--popover))}.bg-primary{background-color:#171717;background-color:hsl(var(--primary))}.bg-primary\/10{background-color:#1717171a;background-color:hsl(var(--primary)/.1)}.bg-primary\/20{background-color:#17171733;background-color:hsl(var(--primary)/.2)}.bg-secondary{background-color:#f5f5f5;background-color:hsl(var(--secondary))}.bg-transparent{background-color:initial}.fill-current{fill:currentColor}.fill-primary{fill:#171717;fill:hsl(var(--primary))}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-\[1px\]{padding:1px}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.pb-4{padding-bottom:1rem}.pl-2{padding-left:.5rem}.pl-2\.5{padding-left:.625rem}.pl-4{padding-left:1rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pr-2\.5{padding-right:.625rem}.pr-6{padding-right:1.5rem}.pr-8{padding-right:2rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-end{text-align:end}.align-middle{vertical-align:middle}.text-\[0\.8rem\]{font-size:.8rem}.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-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.italic{font-style:italic}.leading-none{line-height:1}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-accent-foreground{color:#171717;color:hsl(var(--accent-foreground))}.text-card-foreground{color:#0a0a0a;color:hsl(var(--card-foreground))}.text-current{color:currentColor}.text-destructive{color:#ef4444;color:hsl(var(--destructive))}.text-destructive-foreground{color:#fafafa;color:hsl(var(--destructive-foreground))}.text-foreground{color:#0a0a0a;color:hsl(var(--foreground))}.text-foreground\/50{color:#0a0a0a80;color:hsl(var(--foreground)/.5)}.text-muted-foreground{color:#737373;color:hsl(var(--muted-foreground))}.text-popover-foreground{color:#0a0a0a;color:hsl(var(--popover-foreground))}.text-primary{color:#171717;color:hsl(var(--primary))}.text-primary-foreground{color:#fafafa;color:hsl(var(--primary-foreground))}.text-secondary-foreground{color:#171717;color:hsl(var(--secondary-foreground))}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-lg{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.outline-none{outline:2px solid #0000;outline-offset:2px}.outline{outline-style:solid}.ring-0{--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(var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-0,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-ring{--tw-ring-color:hsl(var(--ring))}.ring-offset-background{--tw-ring-offset-color:hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-1000{transition-duration:1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}@keyframes enter{0%{opacity:1;opacity:var(--tw-enter-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0) scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:1;opacity:var(--tw-exit-opacity,1);transform:translateZ(0) scaleX(1) rotate(0);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0) scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.animate-in{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.fade-in,.fade-in-0{--tw-enter-opacity:0}.zoom-in-95{--tw-enter-scale:.95}.duration-1000{animation-duration:1s}.duration-200{animation-duration:.2s}.duration-300{animation-duration:.3s}.ease-in-out{animation-timing-function:cubic-bezier(.4,0,.2,1)}.running{animation-play-state:running}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.file\:border-0::-webkit-file-upload-button{border-width:0}.file\:border-0::file-selector-button{border-width:0}.file\:bg-transparent::-webkit-file-upload-button{background-color:initial}.file\:bg-transparent::file-selector-button{background-color:initial}.file\:text-sm::-webkit-file-upload-button{font-size:.875rem;line-height:1.25rem}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::-webkit-file-upload-button{font-weight:500}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::-webkit-file-upload-button{color:#0a0a0a;color:hsl(var(--foreground))}.file\:text-foreground::file-selector-button{color:#0a0a0a;color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::placeholder{color:#737373;color:hsl(var(--muted-foreground))}.after\:absolute:after{content:var(--tw-content);position:absolute}.after\:inset-y-0:after{bottom:0;content:var(--tw-content);top:0}.after\:left-1\/2:after{content:var(--tw-content);left:50%}.after\:w-1:after{content:var(--tw-content);width:.25rem}.after\:-translate-x-1\/2:after{--tw-translate-x:-50%;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.first\:rounded-l-md:first-child{border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.first\:border-l:first-child{border-left-width:1px}.last\:rounded-r-md:last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.focus-within\:relative:focus-within{position:relative}.focus-within\:z-20:focus-within{z-index:20}.hover\:bg-accent:hover{background-color:#f5f5f5;background-color:hsl(var(--accent))}.hover\:bg-destructive\/80:hover{background-color:#ef4444cc;background-color:hsl(var(--destructive)/.8)}.hover\:bg-destructive\/90:hover{background-color:#ef4444e6;background-color:hsl(var(--destructive)/.9)}.hover\:bg-muted:hover{background-color:#f5f5f5;background-color:hsl(var(--muted))}.hover\:bg-muted\/50:hover{background-color:#f5f5f580;background-color:hsl(var(--muted)/.5)}.hover\:bg-primary:hover{background-color:#171717;background-color:hsl(var(--primary))}.hover\:bg-primary\/80:hover{background-color:#171717cc;background-color:hsl(var(--primary)/.8)}.hover\:bg-primary\/90:hover{background-color:#171717e6;background-color:hsl(var(--primary)/.9)}.hover\:bg-secondary:hover{background-color:#f5f5f5;background-color:hsl(var(--secondary))}.hover\:bg-secondary\/80:hover{background-color:#f5f5f5cc;background-color:hsl(var(--secondary)/.8)}.hover\:text-accent-foreground:hover{color:#171717;color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:#0a0a0a;color:hsl(var(--foreground))}.hover\:text-muted-foreground:hover{color:#737373;color:hsl(var(--muted-foreground))}.hover\:text-primary-foreground:hover{color:#fafafa;color:hsl(var(--primary-foreground))}.hover\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.focus\:bg-accent:focus{background-color:#f5f5f5;background-color:hsl(var(--accent))}.focus\:bg-primary:focus{background-color:#171717;background-color:hsl(var(--primary))}.focus\:text-accent-foreground:focus{color:#171717;color:hsl(var(--accent-foreground))}.focus\:text-primary-foreground:focus{color:#fafafa;color:hsl(var(--primary-foreground))}.focus\:opacity-100:focus{opacity:1}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-1: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(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-1:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-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)}.focus\:ring-ring:focus{--tw-ring-color:hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:outline-none:focus-visible{outline:2px solid #0000;outline-offset:2px}.focus-visible\:ring-1:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color:hsl(var(--ring))}.focus-visible\:ring-offset-1:focus-visible{--tw-ring-offset-width:1px}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color:hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}.group.destructive .group-\[\.destructive\]\:border-muted\/40{border-color:#f5f5f566;border-color:hsl(var(--muted)/.4)}.group.toaster .group-\[\.toaster\]\:border-border{border-color:#e5e5e5;border-color:hsl(var(--border))}.group.toast .group-\[\.toast\]\:bg-muted{background-color:#f5f5f5;background-color:hsl(var(--muted))}.group.toast .group-\[\.toast\]\:bg-primary{background-color:#171717;background-color:hsl(var(--primary))}.group.toaster .group-\[\.toaster\]\:bg-background{background-color:#fff;background-color:hsl(var(--background))}.group.destructive .group-\[\.destructive\]\:text-red-300{--tw-text-opacity:1;color:#fca5a5;color:rgb(252 165 165/var(--tw-text-opacity,1))}.group.toast .group-\[\.toast\]\:text-muted-foreground{color:#737373;color:hsl(var(--muted-foreground))}.group.toaster .group-\[\.toaster\]\:text-foreground{color:#0a0a0a;color:hsl(var(--foreground))}.group.toaster .group-\[\.toaster\]\:text-primary-foreground{color:#fafafa;color:hsl(var(--primary-foreground))}.group.toaster .group-\[\.toaster\]\:shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.group.destructive .group-\[\.destructive\]\:hover\:border-destructive\/30:hover{border-color:#ef44444d;border-color:hsl(var(--destructive)/.3)}.group.destructive .group-\[\.destructive\]\:hover\:bg-destructive:hover{background-color:#ef4444;background-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:hover\:text-destructive-foreground:hover{color:#fafafa;color:hsl(var(--destructive-foreground))}.group.destructive .group-\[\.destructive\]\:hover\:text-red-50:hover{--tw-text-opacity:1;color:#fef2f2;color:rgb(254 242 242/var(--tw-text-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-destructive:focus{--tw-ring-color:hsl(var(--destructive))}.group.destructive .group-\[\.destructive\]\:focus\:ring-red-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(248 113 113/var(--tw-ring-opacity,1))}.group.destructive .group-\[\.destructive\]\:focus\:ring-offset-red-600:focus{--tw-ring-offset-color:#dc2626}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\:disabled\]\:opacity-50:has(:disabled){opacity:.5}.aria-selected\:bg-accent[aria-selected=true]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.aria-selected\:bg-accent\/50[aria-selected=true]{background-color:#f5f5f580;background-color:hsl(var(--accent)/.5)}.aria-selected\:text-accent-foreground[aria-selected=true]{color:#171717;color:hsl(var(--accent-foreground))}.aria-selected\:text-muted-foreground[aria-selected=true]{color:#737373;color:hsl(var(--muted-foreground))}.aria-selected\:opacity-100[aria-selected=true]{opacity:1}.data-\[disabled\=true\]\:pointer-events-none[data-disabled=true],.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[panel-group-direction\=vertical\]\:h-px[data-panel-group-direction=vertical]{height:1px}.data-\[panel-group-direction\=vertical\]\:w-full[data-panel-group-direction=vertical]{width:100%}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y:0.25rem}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom],.data-\[side\=left\]\:-translate-x-1[data-side=left]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x:-0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x:0.25rem}.data-\[side\=right\]\:translate-x-1[data-side=right],.data-\[side\=top\]\:-translate-y-1[data-side=top]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y:-0.25rem}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x:1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked],.data-\[swipe\=cancel\]\:translate-x-0[data-swipe=cancel]{--tw-translate-x:0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end]{--tw-translate-x:var(--radix-toast-swipe-end-x)}.data-\[swipe\=end\]\:translate-x-\[var\(--radix-toast-swipe-end-x\)\][data-swipe=end],.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[swipe\=move\]\:translate-x-\[var\(--radix-toast-swipe-move-x\)\][data-swipe=move]{--tw-translate-x:var(--radix-toast-swipe-move-x)}@keyframes accordion-up{0%{height:var(--radix-accordion-content-height)}to{height:0}}.data-\[state\=closed\]\:animate-accordion-up[data-state=closed]{animation:accordion-up .2s ease-out}@keyframes accordion-down{0%{height:0}to{height:var(--radix-accordion-content-height)}}.data-\[state\=open\]\:animate-accordion-down[data-state=open]{animation:accordion-down .2s ease-out}.data-\[panel-group-direction\=vertical\]\:flex-col[data-panel-group-direction=vertical]{flex-direction:column}.data-\[selected\=true\]\:bg-accent[data-selected=true]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:#fff;background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:#171717;background-color:hsl(var(--primary))}.data-\[state\=on\]\:bg-accent[data-state=on],.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.data-\[state\=open\]\:bg-accent\/50[data-state=open]{background-color:#f5f5f580;background-color:hsl(var(--accent)/.5)}.data-\[state\=open\]\:bg-secondary[data-state=open]{background-color:#f5f5f5;background-color:hsl(var(--secondary))}.data-\[state\=selected\]\:bg-muted[data-state=selected]{background-color:#f5f5f5;background-color:hsl(var(--muted))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:#e5e5e5;background-color:hsl(var(--input))}.data-\[placeholder\]\:text-muted-foreground[data-placeholder]{color:#737373;color:hsl(var(--muted-foreground))}.data-\[selected\=true\]\:text-accent-foreground[data-selected=true]{color:#171717;color:hsl(var(--accent-foreground))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:#0a0a0a;color:hsl(var(--foreground))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:#fafafa;color:hsl(var(--primary-foreground))}.data-\[state\=on\]\:text-accent-foreground[data-state=on],.data-\[state\=open\]\:text-accent-foreground[data-state=open]{color:#171717;color:hsl(var(--accent-foreground))}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:#737373;color:hsl(var(--muted-foreground))}.data-\[disabled\=true\]\:opacity-50[data-disabled=true],.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=active\]\:shadow[data-state=active]{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.data-\[swipe\=move\]\:transition-none[data-swipe=move]{transition-property:none}.data-\[state\=closed\]\:duration-300[data-state=closed]{transition-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{transition-duration:.5s}.data-\[motion\^\=from-\]\:animate-in[data-motion^=from-],.data-\[state\=open\]\:animate-in[data-state=open],.data-\[state\=visible\]\:animate-in[data-state=visible]{--tw-enter-opacity:initial;--tw-enter-scale:initial;--tw-enter-rotate:initial;--tw-enter-translate-x:initial;--tw-enter-translate-y:initial;animation-duration:.15s;animation-name:enter}.data-\[motion\^\=to-\]\:animate-out[data-motion^=to-],.data-\[state\=closed\]\:animate-out[data-state=closed],.data-\[state\=hidden\]\:animate-out[data-state=hidden],.data-\[swipe\=end\]\:animate-out[data-swipe=end]{--tw-exit-opacity:initial;--tw-exit-scale:initial;--tw-exit-rotate:initial;--tw-exit-translate-x:initial;--tw-exit-translate-y:initial;animation-duration:.15s;animation-name:exit}.data-\[motion\^\=from-\]\:fade-in[data-motion^=from-]{--tw-enter-opacity:0}.data-\[motion\^\=to-\]\:fade-out[data-motion^=to-],.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:fade-out-80[data-state=closed]{--tw-exit-opacity:0.8}.data-\[state\=hidden\]\:fade-out[data-state=hidden]{--tw-exit-opacity:0}.data-\[state\=open\]\:fade-in-0[data-state=open],.data-\[state\=visible\]\:fade-in[data-state=visible]{--tw-enter-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:zoom-in-90[data-state=open]{--tw-enter-scale:.9}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}.data-\[motion\=from-end\]\:slide-in-from-right-52[data-motion=from-end]{--tw-enter-translate-x:13rem}.data-\[motion\=from-start\]\:slide-in-from-left-52[data-motion=from-start]{--tw-enter-translate-x:-13rem}.data-\[motion\=to-end\]\:slide-out-to-right-52[data-motion=to-end]{--tw-exit-translate-x:13rem}.data-\[motion\=to-start\]\:slide-out-to-left-52[data-motion=to-start]{--tw-exit-translate-x:-13rem}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{--tw-enter-translate-y:-0.5rem}.data-\[side\=left\]\:slide-in-from-right-2[data-side=left]{--tw-enter-translate-x:0.5rem}.data-\[side\=right\]\:slide-in-from-left-2[data-side=right]{--tw-enter-translate-x:-0.5rem}.data-\[side\=top\]\:slide-in-from-bottom-2[data-side=top]{--tw-enter-translate-y:0.5rem}.data-\[state\=closed\]\:slide-out-to-bottom[data-state=closed]{--tw-exit-translate-y:100%}.data-\[state\=closed\]\:slide-out-to-left[data-state=closed]{--tw-exit-translate-x:-100%}.data-\[state\=closed\]\:slide-out-to-left-1\/2[data-state=closed]{--tw-exit-translate-x:-50%}.data-\[state\=closed\]\:slide-out-to-right-full[data-state=closed],.data-\[state\=closed\]\:slide-out-to-right[data-state=closed]{--tw-exit-translate-x:100%}.data-\[state\=closed\]\:slide-out-to-top[data-state=closed]{--tw-exit-translate-y:-100%}.data-\[state\=closed\]\:slide-out-to-top-\[48\%\][data-state=closed]{--tw-exit-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-bottom[data-state=open]{--tw-enter-translate-y:100%}.data-\[state\=open\]\:slide-in-from-left[data-state=open]{--tw-enter-translate-x:-100%}.data-\[state\=open\]\:slide-in-from-left-1\/2[data-state=open]{--tw-enter-translate-x:-50%}.data-\[state\=open\]\:slide-in-from-right[data-state=open]{--tw-enter-translate-x:100%}.data-\[state\=open\]\:slide-in-from-top[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=open\]\:slide-in-from-top-\[48\%\][data-state=open]{--tw-enter-translate-y:-48%}.data-\[state\=open\]\:slide-in-from-top-full[data-state=open]{--tw-enter-translate-y:-100%}.data-\[state\=closed\]\:duration-300[data-state=closed]{animation-duration:.3s}.data-\[state\=open\]\:duration-500[data-state=open]{animation-duration:.5s}.data-\[panel-group-direction\=vertical\]\:after\:left-0[data-panel-group-direction=vertical]:after{content:var(--tw-content);left:0}.data-\[panel-group-direction\=vertical\]\:after\:h-1[data-panel-group-direction=vertical]:after{content:var(--tw-content);height:.25rem}.data-\[panel-group-direction\=vertical\]\:after\:w-full[data-panel-group-direction=vertical]:after{content:var(--tw-content);width:100%}.data-\[panel-group-direction\=vertical\]\:after\:-translate-y-1\/2[data-panel-group-direction=vertical]:after{--tw-translate-y:-50%;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[panel-group-direction\=vertical\]\:after\:translate-x-0[data-panel-group-direction=vertical]:after{--tw-translate-x:0px;content:var(--tw-content);transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=open\]\:focus\:bg-accent:focus[data-state=open],.data-\[state\=open\]\:hover\:bg-accent:hover[data-state=open]{background-color:#f5f5f5;background-color:hsl(var(--accent))}.group[data-state=open] .group-data-\[state\=open\]\:rotate-180{--tw-rotate:180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.dark\:border-destructive:is(.dark *){border-color:#ef4444;border-color:hsl(var(--destructive))}@media (min-width:640px){.sm\:bottom-0{bottom:0}.sm\:right-0{right:0}.sm\:top-auto{top:auto}.sm\:mt-0{margin-top:0}.sm\:max-w-sm{max-width:24rem}.sm\:flex-row{flex-direction:row}.sm\:flex-col{flex-direction:column}.sm\:justify-end{justify-content:flex-end}.sm\:gap-2\.5{gap:.625rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.sm\:rounded-lg{border-radius:.5rem;border-radius:var(--radius)}.sm\:text-left{text-align:left}.data-\[state\=open\]\:sm\:slide-in-from-bottom-full[data-state=open]{--tw-enter-translate-y:100%}}@media (min-width:768px){.md\:absolute{position:absolute}.md\:w-\[var\(--radix-navigation-menu-viewport-width\)\]{width:var(--radix-navigation-menu-viewport-width)}.md\:w-auto{width:auto}.md\:max-w-\[420px\]{max-width:420px}.md\:text-sm{font-size:.875rem;line-height:1.25rem}}.\[\&\+div\]\:text-xs+div{font-size:.75rem;line-height:1rem}.\[\&\:has\(\>\.day-range-end\)\]\:rounded-r-md:has(>.day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\>\.day-range-start\)\]\:rounded-l-md:has(>.day-range-start){border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:rounded-md:has([aria-selected]){border-radius:calc(.5rem - 2px);border-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\)\]\:bg-accent:has([aria-selected]){background-color:#f5f5f5;background-color:hsl(var(--accent))}.first\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-l-md:has([aria-selected]):first-child{border-bottom-left-radius:calc(.5rem - 2px);border-bottom-left-radius:calc(var(--radius) - 2px);border-top-left-radius:calc(.5rem - 2px);border-top-left-radius:calc(var(--radius) - 2px)}.last\:\[\&\:has\(\[aria-selected\]\)\]\:rounded-r-md:has([aria-selected]):last-child{border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[aria-selected\]\.day-outside\)\]\:bg-accent\/50:has([aria-selected].day-outside){background-color:#f5f5f580;background-color:hsl(var(--accent)/.5)}.\[\&\:has\(\[aria-selected\]\.day-range-end\)\]\:rounded-r-md:has([aria-selected].day-range-end){border-bottom-right-radius:calc(.5rem - 2px);border-bottom-right-radius:calc(var(--radius) - 2px);border-top-right-radius:calc(.5rem - 2px);border-top-right-radius:calc(var(--radius) - 2px)}.\[\&\:has\(\[role\=checkbox\]\)\]\:pr-0:has([role=checkbox]){padding-right:0}.\[\&\>\[role\=checkbox\]\]\:translate-y-\[2px\]>[role=checkbox]{--tw-translate-y:2px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>span\]\:line-clamp-1>span{-webkit-box-orient:vertical;-webkit-line-clamp:1;display:-webkit-box;overflow:hidden}.\[\&\>svg\+div\]\:translate-y-\[-3px\]>svg+div{--tw-translate-y:-3px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\>svg\]\:absolute>svg{position:absolute}.\[\&\>svg\]\:left-4>svg{left:1rem}.\[\&\>svg\]\:top-4>svg{top:1rem}.\[\&\>svg\]\:size-4>svg{height:1rem;width:1rem}.\[\&\>svg\]\:h-3\.5>svg{height:.875rem}.\[\&\>svg\]\:w-3\.5>svg{width:.875rem}.\[\&\>svg\]\:shrink-0>svg{flex-shrink:0}.\[\&\>svg\]\:text-destructive>svg{color:#ef4444;color:hsl(var(--destructive))}.\[\&\>svg\]\:text-foreground>svg{color:#0a0a0a;color:hsl(var(--foreground))}.\[\&\>svg\~\*\]\:pl-7>svg~*{padding-left:1.75rem}.\[\&\>tr\]\:last\:border-b-0:last-child>tr{border-bottom-width:0}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div{--tw-rotate:90deg}.\[\&\[data-panel-group-direction\=vertical\]\>div\]\:rotate-90[data-panel-group-direction=vertical]>div,.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.\[\&\[data-state\=open\]\>svg\]\:rotate-180[data-state=open]>svg{--tw-rotate:180deg}.\[\&_\[cmdk-group-heading\]\]\:px-2 [cmdk-group-heading]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-group-heading\]\]\:py-1\.5 [cmdk-group-heading]{padding-bottom:.375rem;padding-top:.375rem}.\[\&_\[cmdk-group-heading\]\]\:text-xs [cmdk-group-heading]{font-size:.75rem;line-height:1rem}.\[\&_\[cmdk-group-heading\]\]\:font-medium [cmdk-group-heading]{font-weight:500}.\[\&_\[cmdk-group-heading\]\]\:text-muted-foreground [cmdk-group-heading]{color:#737373;color:hsl(var(--muted-foreground))}.\[\&_\[cmdk-group\]\:not\(\[hidden\]\)_\~\[cmdk-group\]\]\:pt-0 [cmdk-group]:not([hidden])~[cmdk-group]{padding-top:0}.\[\&_\[cmdk-group\]\]\:px-2 [cmdk-group]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:h-5 [cmdk-input-wrapper] svg{height:1.25rem}.\[\&_\[cmdk-input-wrapper\]_svg\]\:w-5 [cmdk-input-wrapper] svg{width:1.25rem}.\[\&_\[cmdk-input\]\]\:h-12 [cmdk-input]{height:3rem}.\[\&_\[cmdk-item\]\]\:px-2 [cmdk-item]{padding-left:.5rem;padding-right:.5rem}.\[\&_\[cmdk-item\]\]\:py-3 [cmdk-item]{padding-bottom:.75rem;padding-top:.75rem}.\[\&_\[cmdk-item\]_svg\]\:h-5 [cmdk-item] svg{height:1.25rem}.\[\&_\[cmdk-item\]_svg\]\:w-5 [cmdk-item] svg{width:1.25rem}.\[\&_p\]\:leading-relaxed p{line-height:1.625}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:size-4 svg{height:1rem;width:1rem}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_tr\:last-child\]\:border-0 tr:last-child{border-width:0}.\[\&_tr\]\:border-b tr{border-bottom-width:1px}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}h1,h2,h3,h4,h5,h6{font-family:Space Grotesk,sans-serif}.App{min-height:100vh}.landing-container{background:linear-gradient(180deg,#faf5ff,#dbeafe);min-height:100vh;overflow:hidden;position:relative}.landing-container.theme-sample2{background:linear-gradient(180deg,#f8fafc,#e2e8f0)}.landing-container.theme-sample4{background:linear-gradient(180deg,#fff1f2,#fae8ff 50%,#f3e8ff)}.hero-section{justify-content:center;margin:0 auto;max-width:900px;min-height:70vh;padding:60px 24px 40px;text-align:center}.hero-content,.hero-section{align-items:center;display:flex}.hero-content{flex-direction:column;gap:24px;width:100%}.hero-badge{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #8b5cf633;border-radius:24px;color:#6b46c1;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;width:-webkit-fit-content;width:fit-content}.badge-icon{color:#8b5cf6}.hero-title{color:#1a1a2e;font-size:clamp(2.5rem,5vw,4rem);font-weight:700;letter-spacing:-.02em;line-height:1.1}.title-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#7c3aed,#3b82f6);-webkit-background-clip:text;background-clip:text}.theme-sample2 .title-gradient{-webkit-text-fill-color:unset;background:none;-webkit-background-clip:unset;color:#1e293b}.theme-sample2 .title-gradient .accent{color:#3b82f6}.theme-sample4 .title-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#fb7185,#f472b6 50%,#c084fc);-webkit-background-clip:text;background-clip:text}.hero-description{color:#4a5568;font-size:1.125rem;line-height:1.7;max-width:600px;text-align:center}.hero-actions{display:flex;flex-direction:row;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:16px}.hero-secondary-btn{background:#0000;border:2px solid #ffffff80;border-radius:12px;color:#fff;font-size:1rem;font-weight:600;padding:16px 32px}.hero-secondary-btn:hover{background:#ffffff1a;border-color:#fff;color:#fff}.primary-button{align-items:center;background:linear-gradient(135deg,#7c3aed,#6366f1);border:none;border-radius:12px;color:#fff;cursor:pointer;display:inline-flex;font-size:1.125rem;font-weight:600;gap:12px;padding:24px 40px;transition:transform .2s,box-shadow .2s}.theme-sample4 .primary-button{background:linear-gradient(135deg,#fb7185,#f472b6);border-radius:14px;box-shadow:0 4px 15px #fb71854d}.primary-button:hover{box-shadow:0 8px 30px #667eea66;transform:translateY(-2px)}.button-icon{transition:transform .2s}.primary-button:hover .button-icon{transform:translateX(4px)}.features-section{margin:0 auto;max-width:1200px;padding:30px 24px 10px}.section-title{color:#1a1a2e;font-size:2.5rem;font-weight:700;margin-bottom:40px}.centered-title{text-align:center!important}.features-grid{grid-template-columns:repeat(3,1fr)}.feature-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#faf5ff,#f0f9ff);border:2px solid #e9d5ff;border-radius:16px;display:flex;flex-direction:column;justify-content:flex-start;min-height:240px;padding:30px 24px;transition:transform .3s,box-shadow .3s,border .3s}.feature-card:hover{border-color:#7c3aed;box-shadow:0 10px 30px #7c3aed26;transform:translateY(-5px)}.theme-sample2 .feature-card{background:#f8fafc;border:2px solid #e2e8f0}.theme-sample2 .feature-card:hover{background:#fff;border-color:#3b82f6;box-shadow:0 10px 30px #0000001a}.theme-sample4 .feature-card{background:linear-gradient(135deg,#fff1f2,#fae8ff);border:2px solid #fecdd3;border-radius:20px}.theme-sample4 .feature-card:hover{border-color:#fda4af;box-shadow:0 12px 35px #fb718533}.feature-icon-wrapper{align-items:center;background:linear-gradient(135deg,#7c3aed,#6366f1);border-radius:12px;color:#fff;display:flex;height:64px;justify-content:center;margin:0 auto 24px;width:64px}.theme-sample2 .feature-icon-wrapper{background:#3b82f6}.theme-sample4 .feature-icon-wrapper{background:linear-gradient(135deg,#fb7185,#f472b6);border-radius:15px;box-shadow:0 4px 15px #fb71854d}.feature-card h3{color:#2d3748;font-size:1.25rem;font-weight:600;margin-bottom:12px}.feature-card p{color:#718096;font-size:.938rem;line-height:1.6}.features-list{flex-direction:column;gap:10px;list-style:none;margin:0;padding:0;text-align:left}.features-list li{color:#4a5568;font-size:.938rem;line-height:1.5;padding-left:24px;position:relative}.features-list li:before{color:#10b981;content:"✓";font-size:1.125rem;font-weight:700;left:0;position:absolute}.cta-section{display:flex;justify-content:center;margin:40px auto;max-width:1200px;padding:0 24px}.cta-card{max-width:600px;padding:40px 32px;width:100%}.cta-card h3{color:#2d3748;font-size:1.875rem;font-weight:700;margin-bottom:8px}.cta-card .promo-subtitle{color:#667eea;font-size:1.25rem;font-weight:600;margin-bottom:16px}.cta-card p{color:#4a5568;font-size:1rem;line-height:1.7;margin-bottom:24px}.cta-button{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:1rem;margin-top:8px;padding:14px 32px;transition:transform .2s,box-shadow .2s}.cta-button:hover{box-shadow:0 8px 30px #667eea66;transform:translateY(-2px)}.side-by-side-section{margin:10px auto;max-width:1200px;padding:0 24px}.side-by-side-container{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.side-card{display:flex;flex-direction:column;min-height:400px}.side-card.cta-card{padding:40px 32px}.side-card .cta-button{margin-top:auto}.landing-header{background:linear-gradient(135deg,#7c3aed,#3b82f6);box-shadow:0 2px 10px #7c3aed33;padding:16px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.theme-sample2 .landing-header{background:#1e293b;box-shadow:0 2px 10px #0000001a}.theme-sample4 .landing-header{background:linear-gradient(135deg,#fda4af,#f9a8d4 50%,#c4b5fd);box-shadow:0 2px 15px #fda4af4d}.header-left{display:none}.logo{color:#fff;font-size:1.5rem;font-weight:700}.theme-sample2 .logo{color:#3b82f6}@media (max-width:640px){.header-actions.header-actions-mobile{align-items:center!important;display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:4px!important;justify-content:center!important}}.header-actions button[data-testid=login-btn]{background:#0000;border:2px solid #0000;border-radius:12px;color:#fff}.header-actions button[data-testid=login-btn]:hover{background:#ffffff1a;box-shadow:0 4px 12px #7c3aed4d;transform:translateY(-1px)}.header-actions button[data-testid=register-btn]{background:#0000;border:2px solid #0000;border-radius:12px;color:#fff}.header-actions button[data-testid=register-btn]:hover{background:#ffffff1a;box-shadow:0 4px 12px #7c3aed4d;transform:translateY(-1px)}.header-actions button[data-testid=pricing-btn]{background:#0000;border:2px solid #0000;border-radius:12px;color:#fff}.header-actions button[data-testid=pricing-btn]:hover{background:#ffffff1a;box-shadow:0 4px 12px #7c3aed4d;transform:translateY(-1px)}.theme-sample4 .header-actions button[data-testid=login-btn],.theme-sample4 .header-actions button[data-testid=register-btn]{border-radius:14px}.header-actions button[data-testid=dashboard-btn]{background:#0000;border:none;border-radius:12px;color:#fff;min-width:110px}.header-actions button[data-testid=dashboard-btn]:hover{background:#0000;box-shadow:none;color:#fff;text-decoration:underline;transform:none}.header-actions button[data-testid=logout-btn]{background:#0000;border:none;border-radius:12px;color:#fff;min-width:110px}.header-actions button[data-testid=logout-btn]:hover{background:#0000;box-shadow:none;color:#fff;text-decoration:underline;transform:none}.header-actions button[data-testid=student-login-btn]{background:#0000;border:none;color:#ffffffe6;font-size:.875rem}.header-actions button[data-testid=student-login-btn]:hover{color:#fff;text-decoration:underline}.theme-sample4 .header-actions button[data-testid=student-login-btn]{color:#663399e6}.theme-sample4 .header-actions button[data-testid=student-login-btn]:hover{color:#639}.theme-sample4 .header-actions button[data-testid=dashboard-btn],.theme-sample4 .header-actions button[data-testid=logout-btn],.theme-sample4 .header-actions button[data-testid=pricing-btn]{border-radius:14px}.welcome-text{color:#000;font-size:.938rem;margin-right:8px}.promo-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fffc;border-radius:24px;box-shadow:0 8px 32px #00000014;margin:30px auto;max-width:900px;padding:40px 36px;text-align:center}.promo-section:first-of-type{margin-top:30px}.promo-content{flex-direction:column;gap:16px}.promo-content,.promo-icon{align-items:center;display:flex}.promo-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;height:80px;justify-content:center;margin-bottom:4px;width:80px}.promo-title{color:#1a1a2e;font-size:2.25rem;font-weight:700;line-height:1.2;margin:0}.promo-subtitle{color:#667eea;font-size:1.375rem;font-weight:600;margin:0}.promo-description{color:#4a5568;font-size:1.063rem;line-height:1.7;margin:0;max-width:700px}.promo-cta-text{color:#2d3748;font-size:1.125rem;font-weight:600;margin:4px 0}.promo-button{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:1.063rem;margin-top:8px;padding:16px 36px;transition:transform .2s,box-shadow .2s}.promo-button:hover{box-shadow:0 8px 30px #667eea66;transform:translateY(-2px)}.promo-button-outline{background:#fff;border:2px solid #667eea;border-radius:12px;color:#667eea;font-size:1.063rem;margin-top:8px;padding:16px 36px;transition:all .2s}.promo-button-outline:hover{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 8px 30px #667eea66;color:#fff;transform:translateY(-2px)}.promo-thank-you{color:#718096;font-size:.938rem;font-style:italic;margin-top:12px}.landing-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff9;border-top:1px solid #667eea1a;margin-top:10px;padding:40px 24px;text-align:center}.footer-content{margin:0 auto;max-width:1200px}.footer-section-title{color:#2d3748;font-size:1rem;font-weight:700;letter-spacing:.5px;margin-bottom:16px;text-transform:uppercase}.footer-links{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:20px}.footer-link{color:#4a5568;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s}.footer-link:hover{color:#667eea;text-decoration:underline}.footer-separator{color:#cbd5e0;font-size:.875rem}.footer-copyright{color:#718096;font-size:.875rem}.footer-copyright p{margin:0}@media (max-width:968px){.hero-section{min-height:auto;padding:40px 24px 20px}.hero-content{gap:16px}.hero-title{font-size:2rem}.header-content{flex-wrap:wrap;gap:12px}.header-actions{flex-wrap:wrap;font-size:.875rem;gap:8px}.welcome-text{font-size:.813rem;margin-right:4px}.logo{font-size:1.125rem}.features-section{padding:20px 24px 10px}.cta-section{margin:20px auto}}@media (max-width:640px){.header-content{align-items:center;flex-direction:column;gap:0;padding:0 8px}.logo{margin-bottom:0;padding-bottom:2px;text-align:center;width:100%}.header-actions,.header-actions.header-actions-mobile{align-items:center!important;display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;gap:8px!important;justify-content:center!important;margin:0 auto!important;max-width:100%!important;width:100%!important}.header-actions button,.header-actions.header-actions-mobile button,.header-actions>button{flex:0 1 auto!important;max-width:none!important;white-space:nowrap!important}.header-actions button,.header-actions button[data-testid=dashboard-btn],.header-actions button[data-testid=login-btn],.header-actions button[data-testid=logout-btn],.header-actions button[data-testid=pricing-btn],.header-actions button[data-testid=register-btn],.header-actions button[data-testid=student-login-btn],.header-actions.header-actions-mobile button,.header-actions>button{font-size:.8rem!important;min-width:0!important;min-width:auto!important;padding:8px 12px!important;width:auto!important}.welcome-text{text-align:center;width:100%}.features-grid{gap:16px;grid-template-columns:1fr}.side-by-side-container{gap:20px;grid-template-columns:1fr}.features-section{padding:15px 24px 5px}.cta-section{margin:15px auto}.footer-links{flex-direction:column;gap:12px}.footer-separator{display:none}.landing-footer{margin-top:20px}}.assessment-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px;transition:background .3s ease}.theme-sample2 .assessment-container{background:linear-gradient(135deg,#e0f7ff,#cef4ff 50%,#e0f2fe)}.theme-sample4 .assessment-container{background:linear-gradient(135deg,#ffe4e6,#fecdd3 50%,#fce7f3)}.assessment-header{flex-direction:column;margin:0 auto 32px;max-width:650px}.back-button{align-self:flex-start}.header-center-buttons{display:flex;gap:12px;justify-content:center;width:100%}.header-action-button{align-items:center;display:inline-flex;font-weight:500;gap:8px;justify-content:center;min-width:180px;width:180px}.assessment-content{margin:0 auto;max-width:650px}.assessment-title{color:#1a1a2e;font-size:2rem;font-weight:700;margin-bottom:12px;text-align:center}.assessment-subtitle{color:#718096;font-size:1rem;margin-bottom:32px;text-align:center}.assessment-cards-container{display:flex;flex-direction:column;gap:20px}.action-card,.content-card,.info-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 12px #0000000f;overflow:hidden}.card-header{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-bottom:1px solid #667eea1a;padding:20px 24px}.card-header h3{align-items:center;display:flex;font-size:1.125rem;gap:8px;justify-content:center;width:100%}.card-content{padding:24px}.section-header{margin-bottom:16px;padding:0 4px}.section-header h3{color:#4a5568;font-size:1rem;font-weight:600;margin:0}.upload-placeholder{cursor:pointer;text-align:center;width:100%}.upload-icon-wrapper{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;color:#fff;display:flex;height:96px;justify-content:center;margin:0 auto 24px;width:96px}.upload-placeholder h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:12px}.upload-placeholder p{color:#718096;font-size:1rem;margin-bottom:24px}.student-input-section{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;width:100%}.student-input-section .form-group{align-items:center;display:flex;flex-direction:column;gap:8px}.student-input-section .form-group input,.student-input-section .form-group label{text-align:center;width:100%}.select-button{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;font-weight:600;padding:16px 32px;transition:transform .2s,box-shadow .2s}.select-button:hover{box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.preview-container{display:flex;flex-direction:column;gap:24px;width:100%}.image-preview{border-radius:12px;box-shadow:0 4px 20px #0000001a;max-height:400px;object-fit:contain;width:100%}.preview-actions{gap:16px}.assess-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;display:inline-flex;font-weight:600;gap:8px;padding:16px 32px;transition:transform .2s,box-shadow .2s}.assess-button:hover:not(:disabled){box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.assess-button:disabled{cursor:not-allowed;opacity:.7}.results-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fffc;border-radius:20px;box-shadow:0 8px 32px #00000014;padding:40px}.results-header{align-items:center;border-bottom:2px solid #667eea1a;display:flex;justify-content:space-between;padding-bottom:24px}.results-header-left{align-items:center;display:flex;gap:16px}.results-icon{color:#667eea}.results-header h2{color:#2d3748;font-size:1.875rem;margin:0}.student-name-display{color:#718096;font-size:1rem;margin-top:4px}.level-display,.results-actions{display:flex;gap:8px}.level-display{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;flex-direction:column;justify-content:center;margin-bottom:24px;padding:24px;text-align:center}.theme-sample2 .level-display{background:linear-gradient(135deg,#4facfe,#00f2fe)}.theme-sample4 .level-display{background:linear-gradient(135deg,#ff9a9e,#fecfef)}.level-phase{color:#fff;font-size:1.5rem;font-weight:700;line-height:1.3}.level-descriptor,.level-status{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:8px;color:#fff;font-size:1.25rem;font-weight:600;padding:8px 20px}.level-number{color:#fff;font-size:1.5rem;font-weight:700}.plagiarism-section{background:#667eea0d;border-radius:12px;margin-bottom:24px;padding:16px}.plagiarism-header{align-items:center;color:#2d3748;display:flex;font-weight:600;gap:12px;margin-bottom:8px}.plagiarism-details{color:#4a5568;font-size:.938rem;margin:0}.ai-detection-section{background:#8b5cf60d;border-radius:12px;margin-bottom:24px;padding:16px}.ai-detection-header{align-items:center;color:#2d3748;display:flex;font-weight:600;gap:12px;margin-bottom:8px}.ai-detection-details{color:#4a5568;font-size:.938rem;line-height:1.6;margin:0}.rubric-section{margin-bottom:32px}.rubric-grid{grid-gap:16px;display:grid;gap:16px}.rubric-item{background:linear-gradient(135deg,#667eea14,#764ba214);border:1px solid #667eea26;border-radius:12px;flex-direction:column;gap:8px;padding:16px}.rubric-criterion{color:#4a5568;font-size:.938rem;font-weight:500}.rubric-score-bar{background:#667eea26;border-radius:6px;height:12px;overflow:hidden;position:relative}.rubric-score-fill{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;height:100%;left:0;min-width:10%;position:absolute;top:0;transition:width .5s ease}.results-content{gap:32px}.result-section,.results-content{display:flex;flex-direction:column}.result-section{gap:16px}.result-section-title{align-items:center;color:#2d3748;display:flex;font-size:1.25rem;font-weight:600;gap:12px}.result-section-title svg{color:#667eea}.feedback-list{display:flex;flex-direction:column;gap:12px;list-style:none;margin:0;padding:0}.feedback-list li{border-radius:10px;color:#4a5568;line-height:1.6;padding:16px 16px 16px 44px;position:relative}.well-list li{background:#10b9811a;border-left:4px solid #10b981}.well-list li:before{color:#10b981;content:"✓";font-size:1.25rem;font-weight:700;left:16px;position:absolute}.work-on-list li{background:#667eea1a;border-left:4px solid #667eea}.work-on-list li:before{color:#667eea;content:"→";font-size:1.25rem;font-weight:700;left:16px;position:absolute}.detailed-feedback{background:#667eea0d;border-left:4px solid #667eea;border-radius:12px;color:#4a5568;font-size:1rem;line-height:1.7;padding:20px}.input-mode-cards{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.mode-card{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:140px;padding:20px;text-align:center}.mode-card:before{background:linear-gradient(135deg,#667eea,#764ba2);height:4px;transform:scaleX(0);transition:transform .3s ease}.mode-card:hover{box-shadow:0 4px 12px #667eea26}.mode-card.active,.mode-card:hover{border-color:#667eea;transform:translateY(-2px)}.mode-card.active{background:linear-gradient(135deg,#667eea0d,#764ba20d);box-shadow:0 4px 12px #667eea33}.theme-sample2 .mode-card.active{background:linear-gradient(135deg,#4facfe0d,#00f2fe0d);border-color:#4facfe;box-shadow:0 4px 12px #4facfe33}.theme-sample4 .mode-card.active{background:linear-gradient(135deg,#ff9a9e0d,#fecfef0d);border-color:#ff9a9e;box-shadow:0 4px 12px #ff9a9e33}.mode-card.active:before{transform:scaleX(1)}.mode-icon{filter:grayscale(70%);font-size:48px;margin-bottom:12px;transition:all .3s ease}.mode-card.active .mode-icon,.mode-card:hover .mode-icon{filter:grayscale(0);transform:scale(1.1)}.mode-title{color:#2d3748;font-size:18px;font-weight:600;margin-bottom:8px}.mode-card.active .mode-title{color:#667eea}.mode-description{color:#64748b;font-size:13px;line-height:1.4}.mode-card.active .mode-description{color:#4a5568}.text-input-card .card-content{padding:24px}.writing-text-area{background:#fff;border:2px solid #e2e8f0;border-radius:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:15px;line-height:1.6;margin-bottom:12px;min-height:200px;padding:16px;resize:vertical;transition:all .3s ease;width:100%}.writing-text-area:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.writing-text-area::placeholder{color:#a0aec0;font-style:italic}.text-meta-fields{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-top:16px}.text-meta-fields .form-group{margin-bottom:0}.text-meta-fields label{color:#2d3748;display:block;font-size:14px;font-weight:600;margin-bottom:8px}@media (max-width:768px){.assessment-container{padding:16px}.assessment-header{align-items:stretch;flex-direction:column;gap:12px}.assessment-title{font-size:1.75rem}.assessment-subtitle{font-size:.938rem;margin-bottom:24px}.assessment-cards-container{gap:16px}.card-header{padding:16px 20px}.card-header h3{font-size:1rem}.card-content{padding:20px}.input-mode-cards{gap:12px;grid-template-columns:1fr}.mode-card{min-height:120px;padding:20px}.mode-icon{font-size:40px;margin-bottom:10px}.mode-title{font-size:16px}.mode-description{font-size:12px}.writing-text-area{font-size:14px;min-height:180px;padding:12px}.text-meta-fields{gap:12px}.preview-grid,.text-meta-fields{grid-template-columns:1fr}.preview-image-small{height:180px}.student-input-section{display:flex;flex-direction:column;gap:16px}}@media (max-width:480px){.assessment-container{padding:12px}.assessment-title{font-size:1.5rem}.card-header{padding:12px 16px}.card-content,.mode-card{padding:16px}.mode-card{min-height:110px}.mode-icon{font-size:36px}.writing-text-area{min-height:160px}.assess-button-full{font-size:1rem;padding:14px 24px}}.textarea-wrapper{position:relative}.char-counter{align-items:center;color:#64748b;display:flex;font-size:13px;gap:4px;justify-content:flex-end;margin-bottom:16px;margin-top:-12px;padding:0 4px}.char-counter .text-warning{color:#f59e0b;font-weight:600}.char-counter .text-success{color:#10b981;font-weight:600}.counter-hint{color:#94a3b8;font-size:12px}.upload-instructions-card .card-content{padding:40px 24px}.upload-info-section{text-align:center}.upload-hint{color:#64748b;font-size:15px;font-weight:500;margin-bottom:20px}.multi-photo-toggle{margin-top:20px}.multi-photo-toggle label{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:inline-flex;gap:10px;padding:12px 20px;transition:all .2s}.multi-photo-toggle label:hover{background:#667eea0d;border-color:#667eea}.multi-photo-toggle input[type=checkbox]{cursor:pointer;height:18px;width:18px}.multi-photo-toggle span{color:#2d3748;font-size:14px;font-weight:500}.preview-card .image-preview{border-radius:12px;margin-bottom:20px;max-height:400px;object-fit:contain;width:100%}.multi-preview-container{margin-bottom:20px}.preview-count{color:#2d3748;font-weight:600;margin-bottom:16px;text-align:center}.preview-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.preview-item{border-radius:8px;cursor:pointer;overflow:hidden;position:relative;transition:transform .2s}.preview-item:hover{transform:scale(1.02)}.preview-image-small{border:2px solid #e2e8f0;border-radius:8px;display:block;height:150px;object-fit:cover;width:100%}.preview-item-overlay{align-items:center;background:#00000080;bottom:0;display:flex;flex-direction:column;justify-content:space-between;left:0;opacity:0;padding:8px;position:absolute;right:0;top:0;transition:opacity .2s}.preview-item:hover .preview-item-overlay{opacity:1}.preview-item-number{background:#0009;border-radius:4px;color:#fff;font-size:12px;font-weight:600;padding:4px 8px}.preview-item-remove{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;padding:0;width:32px}.preview-item-remove:hover{background:#dc2626}.preview-actions{display:flex;gap:12px;justify-content:center}.action-card .card-content{padding:24px}.assess-button-full{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;display:inline-flex;font-size:1.0625rem;font-weight:600;gap:8px;justify-content:center;padding:16px 32px;transition:transform .2s,box-shadow .2s;width:100%}.theme-sample2 .assess-button-full{background:linear-gradient(135deg,#4facfe,#00f2fe)}.theme-sample4 .assess-button-full{background:linear-gradient(135deg,#ff9a9e,#fecfef)}.assess-button-full:hover:not(:disabled){box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.theme-sample2 .assess-button-full:hover:not(:disabled){box-shadow:0 8px 20px #4facfe4d}.theme-sample4 .assess-button-full:hover:not(:disabled){box-shadow:0 8px 20px #ff9a9e4d}.assess-button-full:disabled{cursor:not-allowed;opacity:.7}.exemplars-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.exemplars-header{align-items:center;display:flex;justify-content:space-between;margin:0 auto 32px;max-width:1400px}.header-left{display:flex;gap:16px}.add-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;display:inline-flex;font-weight:600;gap:8px;padding:12px 24px;transition:transform .2s,box-shadow .2s}.add-button:hover{box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.exemplars-content{margin:0 auto;max-width:1400px}.page-header{margin-bottom:32px}.page-title{color:#1a1a2e;font-size:2.5rem;font-weight:700;margin-bottom:12px}.page-subtitle{color:#718096;font-size:1.125rem}.login-prompt-card{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:2px solid #667eea4d;border-radius:16px;margin-bottom:32px;padding:24px}.login-prompt-content{align-items:center;display:flex;gap:20px}.login-prompt-content svg{color:#667eea;flex-shrink:0}.login-prompt-content h3{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0 0 4px}.login-prompt-content p{color:#4a5568;font-size:.938rem;line-height:1.5;margin:0}.prompt-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-left:auto;white-space:nowrap}.filters-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;display:flex;gap:24px;margin-bottom:32px;padding:24px}.filter-group{flex:1 1;gap:8px}.empty-state,.loading-state{color:#718096;gap:16px;padding:80px 24px}.empty-state svg{color:#cbd5e0}.empty-state h3{color:#2d3748;font-size:1.5rem;margin:0}.empty-state p{font-size:1rem}.exemplars-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.exemplar-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fffc;border-radius:16px;display:flex;flex-direction:column;gap:16px;padding:24px;transition:transform .3s,box-shadow .3s}.exemplar-card:hover{box-shadow:0 12px 40px #0000001a;transform:translateY(-4px)}.card-header{align-items:flex-start;justify-content:space-between}.card-title-section h3{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0 0 8px}.card-badges{display:flex;flex-wrap:wrap;gap:8px}.genre-badge,.level-badge,.school-badge{border-radius:12px;font-size:.75rem;font-weight:600;padding:4px 12px}.genre-badge{background:#667eea1a;color:#667eea}.school-badge{background:#10b9811a;color:#10b981}.delete-btn{color:#ef4444;transition:color .2s}.delete-btn:hover{color:#dc2626}.exemplar-content{color:#4a5568;font-size:.938rem;line-height:1.7}.highlights-section{border-top:1px solid #667eea1a;padding-top:16px}.highlights-header{align-items:center;color:#667eea;display:flex;font-size:.938rem;font-weight:600;gap:8px;margin-bottom:12px}.highlights-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.highlights-list li{background:#667eea0d;border-radius:8px;color:#4a5568;font-size:.875rem;padding:8px 12px 8px 32px;position:relative}.highlights-list li:before{color:#667eea;content:"•";font-weight:700;left:12px;position:absolute}.dialog-content{display:flex;flex-direction:column;max-height:90vh;max-width:600px;overflow-y:auto}.dialog-form{flex:1 1;overflow-y:auto}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:768px){.page-title{font-size:2rem}.filters-section{flex-direction:column}.exemplars-grid,.form-row{grid-template-columns:1fr}.exemplars-header{align-items:stretch;flex-direction:column;gap:16px}}.exemplars-container.theme-sample2{background:linear-gradient(135deg,#e8f4f8,#f0f4f8 50%,#e8eef5)}.exemplars-container.theme-sample2 .page-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#1e40af);-webkit-background-clip:text;background-clip:text}.exemplars-container.theme-sample2 .exemplar-card{background:#fffffffa;border:1px solid #3b82f626;box-shadow:0 4px 20px #3b82f614}.exemplars-container.theme-sample2 .exemplar-card:hover{border-color:#3b82f6;box-shadow:0 8px 30px #3b82f626}.exemplars-container.theme-sample2 .add-button,.exemplars-container.theme-sample2 .level-badge{background:linear-gradient(135deg,#3b82f6,#1e40af)}.exemplars-container.theme-sample2 .add-button:hover{box-shadow:0 8px 20px #3b82f64d}.exemplars-container.theme-sample4{background:linear-gradient(135deg,#fef5f0,#fff0f5 50%,#fef5f8)}.exemplars-container.theme-sample4 .page-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ec4899,#db2777);-webkit-background-clip:text;background-clip:text}.exemplars-container.theme-sample4 .exemplar-card{background:#fffffffa;border:1px solid #ec489926;box-shadow:0 4px 20px #ec489914}.exemplars-container.theme-sample4 .exemplar-card:hover{border-color:#ec4899;box-shadow:0 8px 30px #ec489926}.exemplars-container.theme-sample4 .add-button,.exemplars-container.theme-sample4 .level-badge{background:linear-gradient(135deg,#ec4899,#db2777)}.exemplars-container.theme-sample4 .add-button:hover{box-shadow:0 8px 20px #ec48994d}.auth-page-wrapper{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);display:flex;flex-direction:column;min-height:100vh}.auth-container{align-items:center;display:flex;flex:1 1;justify-content:center;padding:24px}.auth-content{max-width:480px;position:relative;width:100%}.auth-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fffc;border-radius:20px;box-shadow:0 8px 32px #00000014;margin-top:60px;padding:48px 40px}.auth-header{margin-bottom:32px;text-align:center}.auth-header h1{color:#1a1a2e;font-size:2rem;font-weight:700;margin-bottom:8px}.auth-header p{color:#718096;font-size:1rem}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.auth-submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;font-weight:600;margin-top:8px;padding:16px;transition:transform .2s,box-shadow .2s}.auth-submit-button:hover:not(:disabled){box-shadow:0 8px 20px #667eea4d;transform:translateY(-2px)}.auth-submit-button:disabled{cursor:not-allowed;opacity:.7}.auth-footer{border-top:1px solid #667eea1a;margin-top:24px;padding-top:24px;text-align:center}.auth-footer p{color:#718096;font-size:.938rem}.auth-link{background:none;border:none;color:#667eea;cursor:pointer;font-weight:600;transition:color .2s}.auth-link:hover{color:#764ba2;text-decoration:underline}.student-dashboard{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;overflow-x:hidden}.student-dashboard.loading{align-items:center;color:#718096;display:flex;flex-direction:column;gap:16px;justify-content:center}.student-header{background:#fff;border-bottom:2px solid #e2e8f0;padding:20px 24px}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px}.header-content,.header-title{align-items:center;display:flex}.header-title{gap:16px}.header-title h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#1a1a1a;font-size:24px;font-weight:700;margin:0}.class-info{color:#718096;font-size:14px;margin:0}.student-dashboard .dashboard-content{align-items:center;display:flex;flex-direction:column;margin:0 auto;max-width:600px;padding:32px 24px}.student-dashboard .welcome-section{margin-bottom:32px;width:100%}.welcome-card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 10px 30px #667eea4d;color:#fff;display:flex;justify-content:space-between;padding:40px}.welcome-text h2{font-size:32px;font-weight:700;margin:0 0 8px}.welcome-text p{font-size:18px;margin:0;opacity:.9}.welcome-actions{display:flex;flex-wrap:wrap;gap:12px}.start-writing-btn{background:#fff!important;box-shadow:0 4px 12px #0000001a;color:#667eea!important;font-size:16px;font-weight:600;height:auto!important;padding:24px 32px!important}.start-writing-btn:hover{box-shadow:0 6px 16px #00000026;transform:scale(1.05)}.exemplars-btn{background:#ffffff26!important;border:2px solid #ffffff80!important;color:#fff!important;font-size:16px;font-weight:600;height:auto!important;padding:24px 32px!important}.exemplars-btn:hover{background:#ffffff40!important;border-color:#fff!important;transform:scale(1.05)}.student-dashboard .dashboard-grid{align-items:center!important;box-sizing:border-box;display:flex!important;flex-direction:column!important;gap:24px;margin-bottom:24px;width:100%}.student-dashboard .chart-card,.student-dashboard .goals-chart-card,.student-dashboard .growth-chart-card,.student-dashboard .learning-intentions-card,.student-dashboard .recent-card,.student-dashboard .stats-card{background:#fff;border-radius:12px;box-sizing:border-box;max-width:100%;padding:24px;width:100%}.student-dashboard .learning-intentions-card{grid-column:unset}.card-header{border-bottom:2px solid #f0f0f0;margin-bottom:20px;padding-bottom:16px}.card-header h3{color:#2d3748;font-size:18px;font-weight:600;margin:0}.stats-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.stat-item{background:#f7fafc;padding:20px}.stat-value{font-size:48px;line-height:1;margin-bottom:8px}.stat-label{color:#718096;font-size:14px;font-weight:500}.recent-content{min-height:200px}.empty-state,.loading-state{padding:40px 20px}.empty-state p,.loading-state p{font-size:14px;margin-top:12px}.empty-subtitle{font-size:13px!important;margin-top:4px!important}.assessment-item{background:#f7fafc;border-radius:8px;padding:12px}.assessment-item:hover{background:#edf2f7;transform:translateX(4px)}.assessment-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0}.assessment-title{font-size:14px;margin-bottom:4px}.assessment-meta{color:#718096;font-size:12px}.assessment-rating{display:flex;gap:2px}.assessment-phase-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 10px}.intentions-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.intention-badge{border-radius:12px;box-shadow:0 4px 12px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:20px;transition:transform .2s}.intention-badge:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-4px)}.intention-badge-expanded{box-shadow:0 4px 12px #0000001a;display:flex;flex-direction:column;gap:12px;padding:16px 20px;transition:transform .2s}.intention-badge-expanded:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-4px)}.intention-badge-expanded .intention-header{align-items:center;display:flex;justify-content:space-between;width:100%}.intention-badge-expanded .intention-name{font-size:15px;font-weight:600}.intention-badge-expanded .intention-count{font-size:20px;font-weight:700;opacity:.9}.intention-goals{background:#ffffff26;border-radius:8px;padding:10px 12px;width:100%}.intention-goals .goals-label{font-size:11px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;opacity:.85;text-transform:uppercase}.intention-goals .goals-list{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.intention-goals .goals-list li{font-size:12px;line-height:1.4;opacity:.95;padding-left:12px;position:relative}.intention-goals .goals-list li:before{content:"•";left:0;opacity:.7;position:absolute}.intention-goals .goals-list li.more-goals{font-style:italic;opacity:.75}.intention-name{font-size:14px}.intention-count{font-size:24px;font-weight:700;opacity:.9}@media (max-width:768px){.student-dashboard .dashboard-content{max-width:400px;padding:24px 16px}.student-dashboard .welcome-card{flex-direction:column;gap:24px;text-align:center}.student-dashboard .welcome-text h2{font-size:24px}.student-dashboard .welcome-text p{font-size:16px}.student-dashboard .dashboard-grid{gap:16px}.student-dashboard .header-content{align-items:center;flex-direction:column;gap:16px;text-align:center}.student-dashboard .header-title{flex-direction:column;gap:8px}.student-dashboard .header-actions{justify-content:center;width:100%}.student-dashboard .intentions-grid{grid-template-columns:1fr}}.parent-mode-banner{padding:12px 24px}.parent-mode-banner .banner-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.parent-mode-banner span{font-size:1rem;font-weight:600}.exit-parent-btn{border-color:#ffffff4d!important;color:#fff!important}.exit-parent-btn:hover{background:#ffffff1a!important}.student-dashboard.parent-mode .welcome-card{background:linear-gradient(135deg,#22c55e,#16a34a)}.student-dashboard.parent-mode .stat-value{color:#22c55e}.student-dashboard.parent-mode .assessment-icon{background:linear-gradient(135deg,#22c55e,#16a34a)}.assessment-item.clickable{cursor:pointer}.assessment-item.clickable:hover{background:#e8f5e9;border-color:#22c55e}.assessment-right .chevron{color:#a0aec0;transition:transform .2s}.assessment-item.clickable:hover .chevron{color:#667eea;transform:translateX(4px)}.rating-text-small{color:#22c55e;font-weight:500}.view-all-link{border-top:1px solid #e2e8f0;margin-top:12px;padding-top:12px}.latest-writing-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px}.latest-writing-card .card-header{border-bottom:2px solid #f59e0b4d;gap:12px;margin-bottom:16px;padding-bottom:12px}.latest-writing-card .card-header h3{color:#92400e}.latest-writing-card .writing-date{color:#b45309;font-size:.85rem;font-weight:500}.writing-meta{flex-wrap:wrap;gap:10px}.writing-topic{background:#fff;box-shadow:0 2px 4px #00000014;color:#92400e;font-weight:600}.writing-genre,.writing-topic{border-radius:20px;font-size:.85rem;padding:6px 14px}.writing-genre{background:#ffffffb3;color:#b45309}.latest-writing-card .writing-preview{background:#fff;border-radius:10px;box-shadow:inset 0 2px 4px #0000000d;margin-bottom:16px;padding:20px}.latest-writing-card .writing-preview,.latest-writing-card .writing-text{-webkit-line-clamp:unset!important;-webkit-box-orient:unset!important;display:block!important;max-height:none!important;overflow:visible!important}.latest-writing-card .writing-text{word-wrap:break-word;color:#374151;font-size:.95rem;line-height:1.7;margin:0;white-space:pre-wrap;word-break:break-word}.read-more-btn{color:#b45309!important;font-size:.85rem;height:auto!important;margin-top:12px;padding:0!important}.read-more-btn:hover{color:#92400e!important;text-decoration:underline}.writing-stats{flex-wrap:wrap}.writing-stats .stat-badge{background:#fff;box-shadow:0 2px 4px #0000000d;color:#78350f;font-size:.8rem;font-weight:500}@media (max-width:768px){.latest-writing-card{box-sizing:border-box;margin-bottom:16px;padding:16px;width:100%}.latest-writing-card .writing-preview{box-sizing:border-box;padding:16px;width:100%}.latest-writing-card .writing-preview,.latest-writing-card .writing-text{-webkit-line-clamp:unset!important;-webkit-box-orient:unset!important;display:block!important;max-height:none!important;overflow:visible!important}.latest-writing-card .writing-text{font-size:.9rem;line-height:1.6;word-break:break-word}.writing-meta{gap:8px}.writing-genre,.writing-topic{font-size:.8rem;padding:5px 12px}.writing-stats .stat-badge{font-size:.75rem;padding:5px 10px}}@media (max-width:480px){.latest-writing-card{margin:0 0 16px;padding:12px}.latest-writing-card .card-header{flex-wrap:wrap;gap:8px}.latest-writing-card .card-header h3{font-size:1rem}.latest-writing-card .writing-preview{padding:12px}.latest-writing-card .writing-preview,.latest-writing-card .writing-text{-webkit-line-clamp:unset!important;-webkit-box-orient:unset!important;display:block!important;max-height:none!important;overflow:visible!important}.latest-writing-card .writing-text{font-size:.85rem;line-height:1.5}}.parent-help-card{background:linear-gradient(135deg,#dcfce7,#d1fae5);border:2px solid #22c55e;border-radius:12px;padding:24px}.parent-help-card .card-header{border-bottom-color:#22c55e4d}.parent-help-card .card-header h3{color:#166534}.help-content ul{margin:0;padding-left:24px}.help-content li{color:#166534;line-height:1.6;margin-bottom:8px}.pin-input{font-family:monospace!important;font-size:32px!important;height:auto!important;letter-spacing:12px!important;padding:16px!important;text-align:center!important}.pin-hint{color:#6b7280;font-size:.85rem;margin-top:12px;text-align:center}@media (max-width:768px){.parent-mode-banner .banner-content{flex-direction:column;gap:8px;text-align:center}}.chart-card{border-radius:12px;box-sizing:border-box}.chart-card.growth-chart-card{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981}.chart-card.goals-chart-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.chart-header{justify-content:space-between;margin-bottom:12px}.chart-title h3{color:#065f46;font-size:1rem;font-weight:700}.goals-chart-card .chart-title h3{color:#92400e}.trend-badge{font-size:.75rem;font-weight:600;padding:4px 10px}.trend-badge.improving{background:#d1fae5;color:#059669}.trend-badge.steady{background:#fef3c7;color:#d97706}.trend-badge.declining{color:#dc2626}.rate-badge{background:#fff;box-shadow:0 2px 4px #0000001a;color:#d97706;font-weight:700}.chart-container{background:#fff;border-radius:10px;margin-bottom:12px;min-height:150px;padding:8px 4px}.chart-tooltip{background:#1f2937;box-shadow:0 4px 12px #0003;color:#fff;font-size:.8rem}.chart-tooltip .tooltip-date{color:#9ca3af;font-size:.7rem;margin:0 0 4px}.chart-tooltip .tooltip-score{margin:0}.chart-tooltip .tooltip-score strong{color:#10b981}.chart-tooltip .tooltip-achieved{color:#10b981;margin:4px 0 0}.chart-stats{border-top:1px solid #0000001a;justify-content:space-around;padding:10px 0}.mini-stat{gap:2px}.mini-stat .mini-value{color:#059669;font-size:1.2rem}.goals-chart-card .mini-stat .mini-value{color:#d97706}.mini-stat .mini-label{color:#6b7280;font-size:.65rem;letter-spacing:.5px;text-transform:uppercase}.mini-stat.highlight .mini-value{color:#d97706;font-size:1.3rem}.chart-explanation{border-top:1px solid #0000000f;color:#4b5563;font-size:.8rem;line-height:1.4;margin:10px 0 0;padding-top:10px;text-align:center}.growth-chart-card .chart-explanation{color:#065f46}.goals-chart-card .chart-explanation{color:#78350f}@media (max-width:480px){.chart-card{box-sizing:border-box;margin:0 auto;max-width:100%!important;overflow:hidden;padding:12px}.chart-card,.chart-card.goals-chart-card,.chart-card.growth-chart-card{width:100%!important}.chart-header{flex-wrap:wrap;gap:6px;margin-bottom:8px}.chart-title{flex:1 1;min-width:0}.chart-title h3{font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rate-badge,.trend-badge{flex-shrink:0;font-size:.65rem;padding:2px 6px}.chart-container{box-sizing:border-box;margin-bottom:8px;overflow:hidden;padding:4px 0;width:100%}.chart-stats{gap:4px;padding:8px 0}.mini-stat .mini-value{font-size:.95rem}.mini-stat .mini-label{font-size:.5rem;letter-spacing:.2px}.mini-stat.highlight .mini-value{font-size:1rem}.chart-explanation{font-size:.7rem;line-height:1.3;margin:8px 0 0;padding-top:8px}}@media (max-width:768px){.chart-card.goals-chart-card,.chart-card.growth-chart-card{margin:0;max-width:100%!important;overflow:hidden;width:100%!important}.chart-container{overflow:hidden;width:100%}}.questions-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #3b82f6;border-radius:12px;margin-top:16px;padding:24px}.questions-card .card-header{align-items:center;border-bottom:1px solid #3b82f64d;display:flex;gap:12px;margin-bottom:16px;padding-bottom:12px}.questions-card .card-header h3{color:#1e40af;font-size:1.1rem;font-weight:600;margin:0}.questions-icon{font-size:1.3rem}.questions-intro{color:#1e40af;font-size:.95rem;line-height:1.5;margin:0 0 16px}.questions-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.question-item{align-items:flex-start;background:#ffffffb3;border-radius:8px;display:flex;gap:12px;padding:12px 16px}.question-number{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:flex;font-size:.8rem;font-weight:600;height:24px;justify-content:center;min-width:24px;width:24px}.question-item p{color:#1e3a5f;font-size:.95rem;font-style:italic;line-height:1.5;margin:0}.questions-tip{background:#fffc;border-radius:8px;color:#1e40af;font-size:.9rem;line-height:1.5;margin:0;padding:12px 16px}.questions-tip strong{color:#1e3a5f}@media (max-width:768px){.questions-card{padding:20px 16px}.questions-card .card-header h3{font-size:1rem}.question-item{padding:10px 12px}.question-item p{font-size:.9rem}}.delete-writing-btn{color:#ef4444!important;opacity:.6;padding:4px!important;transition:opacity .2s ease}.delete-writing-btn:hover{background:#ef44441a!important;opacity:1}.delete-confirm-dialog{max-width:400px}.delete-writing-preview{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-top:12px;padding:12px 16px}.delete-writing-title{color:#991b1b;font-weight:600;margin-bottom:4px}.delete-writing-meta{color:#b91c1c;font-size:.85rem}.delete-dialog-footer{gap:8px;margin-top:20px}.delete-confirm-btn{align-items:center;background:#ef4444!important;color:#fff!important;display:flex;gap:6px}.delete-confirm-btn:hover{background:#dc2626!important}.vocab-toggle-btn{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:12px 0 0 12px;box-shadow:-2px 0 10px #0000001a;color:#fff;cursor:pointer;display:flex;gap:4px;padding:12px 8px;position:fixed;right:0;top:50%;transform:translateY(-50%);transition:all .3s ease;z-index:1001}.vocab-toggle-btn:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);padding-right:12px}.vocab-toggle-btn.open{right:320px}.toggle-label{font-size:.8rem;font-weight:600;padding:8px 0;text-orientation:mixed;writing-mode:vertical-rl}.vocabulary-sidebar{background:#fff;box-shadow:-4px 0 20px #0000001a;display:flex;flex-direction:column;height:100vh;position:fixed;right:-320px;top:0;transition:right .3s ease;width:320px;z-index:1000}.vocabulary-sidebar.open{right:0}.vocab-header{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;display:flex;justify-content:space-between;padding:16px 20px}.vocab-header h3{font-size:1.1rem;font-weight:700;margin:0}.close-btn{align-items:center;background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;transition:background .2s;width:28px}.close-btn:hover{background:#ffffff4d}.vocab-tabs{border-bottom:1px solid #e5e7eb;display:flex}.vocab-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#6b7280;cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:500;gap:6px;justify-content:center;padding:12px;transition:all .2s}.vocab-tab:hover{background:#f9fafb;color:#4b5563}.vocab-tab.active{background:#faf5ff;border-bottom-color:#7c3aed;color:#7c3aed}.vocab-search{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;gap:8px;padding:12px 16px}.vocab-search svg{color:#9ca3af}.search-input{background:#fff;border:none;flex:1 1;font-size:.9rem}.definition-box{animation:slideDown .2s ease-out;background:linear-gradient(135deg,#1e293b,#334155);border-radius:12px;box-shadow:0 4px 12px #00000026;margin:0 12px 12px;padding:14px}.definition-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.definition-word{color:#a5b4fc;font-size:1.1rem;font-weight:700;letter-spacing:.3px}.definition-actions{align-items:center;display:flex;gap:8px}.definition-add-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:600;gap:4px;padding:6px 14px;transition:all .2s}.definition-add-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:scale(1.05)}.definition-add-btn:active{transform:scale(.98)}.definition-close{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;height:24px;justify-content:center;transition:all .2s;width:24px}.definition-close:hover{background:#fff3;color:#fff}.definition-text{color:#e2e8f0;font-size:.95rem;line-height:1.6;margin:0}.vocab-content{flex:1 1;overflow-y:auto;padding:16px}.vocab-intro{background:#faf5ff;border:1px solid #e9d5ff;border-radius:8px;color:#6b7280;font-size:.85rem;line-height:1.5;margin-bottom:16px;padding:12px}.selected-word-info{color:#7c3aed}.selected-word-hint{color:#9ca3af;font-style:italic}.vocab-category{margin-bottom:20px}.category-title{border-bottom:2px solid #e9d5ff;color:#374151;font-size:.8rem;font-weight:600;letter-spacing:.5px;margin-bottom:10px;padding-bottom:6px;text-transform:uppercase}.word-chips{display:flex;flex-wrap:wrap;gap:8px}@media (max-width:768px){.word-chips{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin}.word-chips::-webkit-scrollbar{height:4px}.word-chips::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.word-chips::-webkit-scrollbar-thumb{background:#c4b5fd;border-radius:4px}.word-chip{flex-shrink:0}}.word-chip{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:20px;color:#374151;cursor:pointer;display:flex;font-size:.85rem;gap:4px;padding:6px 12px;transition:all .2s}.word-chip:hover{background:#f3e8ff;border-color:#c4b5fd;color:#6d28d9}.word-chip.selected{background:#7c3aed;border-color:#7c3aed;color:#fff}.word-chip .copy-icon{opacity:0;transition:opacity .2s}.word-chip:hover .copy-icon{opacity:1}.word-chip.copied{background:#dcfce7;border-color:#86efac;color:#166534}.word-chip-wrapper{position:relative}.synonym-section{margin-top:8px}.section-title{color:#374151;font-size:.9rem;margin-bottom:16px}.synonym-group{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:12px;padding:12px}.weak-word{align-items:center;display:flex;gap:6px;margin-bottom:8px}.weak-label{color:#9ca3af;font-size:.75rem}.weak-text{color:#ef4444;font-size:.9rem;font-weight:600;text-decoration:line-through;-webkit-text-decoration-color:#fca5a5;text-decoration-color:#fca5a5}.strong-words{align-items:flex-start;display:flex;gap:8px}.try-label{color:#10b981;font-size:.75rem;font-weight:600;margin-top:6px}.alternative-chips{display:flex;flex:1 1;flex-wrap:wrap;gap:6px}.alt-chip{background:#fff;border:1px solid #d1fae5;border-radius:16px;color:#059669;cursor:pointer;font-size:.8rem;padding:4px 10px;transition:all .2s}.alt-chip:hover{background:#d1fae5;border-color:#6ee7b7;transform:scale(1.05)}.alt-chip.selected{border-color:#059669;transform:scale(1.05)}.alt-chip.copied,.alt-chip.selected{background:#059669;color:#fff}.alternative-chips .word-chip-wrapper{display:inline-block;position:relative}@media (max-width:768px){.alternative-chips{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px}.alternative-chips .word-chip-wrapper{flex-shrink:0}.synonym-tooltip{bottom:auto;left:50%;position:fixed;top:50%;transform:translate(-50%,-50%);width:200px}.synonym-tooltip:after{display:none}}.no-results{color:#9ca3af;padding:32px 16px;text-align:center}.vocab-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:12px 16px}.genre-indicator,.phase-indicator{color:#6b7280;font-size:.75rem;margin:0}@media (max-width:768px){.vocabulary-sidebar{right:-100%;width:100%}.vocabulary-sidebar.open{right:0}.vocab-toggle-btn{bottom:80px;top:auto;transform:none}.vocab-toggle-btn.open{bottom:80px;right:0}}.criterion-with-tooltip{position:relative}.criterion-with-tooltip .criterion-content{align-items:flex-start;display:flex;gap:8px;position:relative}.criterion-with-tooltip.card .criterion-content{align-items:flex-start;flex-direction:row}.criterion-with-tooltip.card .criterion-number{align-items:center;background:linear-gradient(135deg,#818cf8,#6366f1);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:28px;justify-content:center;width:28px}.criterion-with-tooltip.card p{color:#374151;flex:1 1;font-size:.95rem;line-height:1.5;margin:0}.criterion-with-tooltip .criterion-text.hoverable,.criterion-with-tooltip.card p.hoverable{border-bottom:1px dashed #9ca3af;cursor:help;transition:all .2s ease}.criterion-with-tooltip .criterion-text.hoverable:hover,.criterion-with-tooltip.card p.hoverable:hover{border-bottom-color:#6366f1;color:#4f46e5}.criterion-hover-tooltip{background:linear-gradient(135deg,#fefce8,#fef9c3)!important;border:1px solid #fde047!important;border-radius:8px!important;box-shadow:0 4px 12px #0000001a!important;max-width:320px!important;padding:12px 14px!important;z-index:9999!important}.criterion-hover-tooltip p{color:#713f12!important;font-size:.85rem!important;line-height:1.5!important;margin:0!important}.criterion-with-tooltip.sidebar .criterion-content{align-items:flex-start;display:flex;gap:10px}.criterion-with-tooltip.sidebar .criterion-bullet{align-items:center;background:#e0e7ff;border-radius:50%;color:#4f46e5;display:flex;flex-shrink:0;font-size:.75rem;font-weight:600;height:22px;justify-content:center;width:22px}.criterion-with-tooltip.sidebar .criterion-text{color:#374151;flex:1 1;font-size:.85rem;line-height:1.4}.help-trigger{align-items:center;background:none;border:none;border-radius:50%;color:#9ca3af;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;margin-left:auto;padding:2px;transition:all .2s ease}.help-trigger:hover{background:#e0e7ff;color:#6366f1}.help-trigger:focus{outline:2px solid #6366f1;outline-offset:2px}.criterion-help-box{animation:helpBoxSlideIn .2s ease-out;background:#fff;border:2px solid #6366f1;border-radius:12px;box-shadow:0 0 0 6px #fff,0 10px 40px #6366f14d;isolation:isolate;padding:16px;z-index:10001}.criterion-help-box.portal-tooltip.centered-tooltip{animation:portalCenterFadeIn .25s ease-out;left:50%;max-height:calc(100vh - 100px);max-width:calc(100vw - 32px);overflow-y:auto;position:fixed;top:50%;transform:translate(-50%,-50%);width:520px;z-index:10001}@keyframes portalCenterFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.criterion-help-box.portal-tooltip.placement-below{animation:portalSlideInBelow .2s ease-out}.criterion-help-box.portal-tooltip.placement-above{animation:portalSlideInAbove .2s ease-out}.criterion-help-box.portal-tooltip.placement-center{animation:portalFadeIn .2s ease-out}@keyframes portalSlideInBelow{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes portalSlideInAbove{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes portalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.criterion-help-backdrop.portal-backdrop{animation:backdropFadeIn .15s ease-out;background:#0000004d;bottom:0;cursor:pointer;left:0;position:fixed;right:0;top:0;z-index:10000}.criterion-help-box:not(.portal-tooltip){left:-20px;position:absolute;right:-20px;top:calc(100% + 8px);z-index:1000}.criterion-help-backdrop{animation:backdropFadeIn .15s ease-out;background:#0000004d;bottom:0;cursor:pointer;left:0;position:fixed;right:0;top:0;z-index:999}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.criterion-with-tooltip.tooltip-above .criterion-help-box{animation:helpBoxSlideInAbove .2s ease-out;bottom:calc(100% + 8px);top:auto}@keyframes helpBoxSlideInAbove{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes helpBoxSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.help-close{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:8px;top:8px;transition:all .2s ease}.help-close:hover{background:#e5e7eb;color:#374151}.portal-tooltip .help-sections-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.help-section{margin-bottom:12px}.help-section:last-child{margin-bottom:0}.portal-tooltip .help-section{margin-bottom:10px}.portal-tooltip .help-section:last-child{margin-bottom:0}.help-section h4{align-items:center;color:#6366f1;display:flex;font-size:.75rem;font-weight:700;gap:4px;letter-spacing:.5px;margin:0 0 6px;text-transform:uppercase}.help-section p{color:#374151;font-size:.85rem;line-height:1.5}.help-section.example{background:#fef3c7;border-left:3px solid #f59e0b;border-radius:8px;padding:10px 12px}.help-section.example h4{color:#b45309}.help-section.tip{background:#ecfdf5;border-left:3px solid #10b981;border-radius:8px;padding:10px 12px}.help-section.tip h4{color:#059669}.criterion-with-tooltip.checklist .criterion-content{align-items:flex-start;display:flex;flex:1 1;gap:8px}.criterion-with-tooltip.checklist .criterion-text{flex:1 1}@media (max-width:768px){.criterion-help-backdrop.portal-backdrop{background:#00000080;z-index:10000}.criterion-help-box.portal-tooltip,.criterion-help-box.portal-tooltip.centered-tooltip{animation:mobileCenterFadeIn .25s ease-out;border-radius:16px;bottom:auto!important;box-shadow:0 10px 40px #0000004d;left:50%!important;max-height:80vh;max-width:400px!important;overflow-y:auto;padding:20px;position:fixed!important;right:auto!important;top:50%!important;transform:translate(-50%,-50%)!important;width:90%!important;z-index:10001}@keyframes mobileCenterFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.help-section h4{font-size:.8rem}.help-section p{font-size:.9rem}.criterion-hover-tooltip{max-width:280px!important}}@media (min-width:769px){.criterion-help-backdrop:not(.portal-backdrop){display:none}}.criteria-sidebar .criterion-help-box:not(.portal-tooltip){left:-10px;right:-10px}.criterion-with-tooltip.sidebar{padding:8px 0}.criterion-with-tooltip.card{padding:4px 0}.criterion-with-tooltip.help-active{position:relative;z-index:1001}.student-write-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.preview-mode-banner{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 8px #0003;color:#fff;flex-wrap:wrap;justify-content:space-between;padding:12px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:200}.preview-banner-content,.preview-mode-banner{align-items:center;display:flex;gap:12px}.preview-banner-text{font-size:.95rem}.preview-mode-banner .preview-return-btn{background:#fff3;border-color:#ffffff4d;color:#fff}.preview-mode-banner .preview-return-btn:hover{background:#ffffff4d}@media (max-width:640px){.preview-mode-banner{flex-direction:column;padding:10px 16px;text-align:center}.preview-banner-text{font-size:.85rem}}.write-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-bottom:1px solid #fff3;padding:12px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.write-header .header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.write-header .header-title{align-items:center;color:#fff;display:flex;gap:10px}.write-header .header-title h1{font-size:1.5rem;font-weight:700;margin:0}.write-header button{border-color:#ffffff4d;color:#fff}.write-header button:hover{background:#ffffff1a}.write-container{margin:0 auto;max-width:1000px;padding:24px}.progress-bar{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:32px}.progress-step{align-items:center;background:#ffffff1a;border-radius:24px;color:#ffffff80;display:flex;gap:8px;padding:8px 16px;transition:all .3s ease}.progress-step.active{background:#fff3;color:#fff}.progress-step.current{background:#fff;color:#667eea}.step-number{background:currentColor;color:inherit;font-size:12px;font-weight:600;height:24px;width:24px}.progress-step.current .step-number{background:#667eea;color:#fff}.step-label{font-size:14px;font-weight:500}.step-container{background:#fff;border-radius:24px;box-shadow:0 20px 60px #0003;overflow:hidden}.step-content{padding:32px}.section-title{margin-bottom:12px;text-align:center;width:100%}.section-title h1{color:#1f2937;font-size:2.25rem;font-weight:700;margin:0 auto;text-align:center}.step-header{margin-bottom:32px;text-align:center}.step-header.compact{margin-bottom:24px}.step-header-row{align-items:center;display:flex;gap:10px;justify-content:center;margin-bottom:8px}.step-header-row .step-icon{color:#667eea;flex-shrink:0}.step-header-row h2{color:#1f2937;font-size:1.5rem;font-weight:600;margin:0}.step-header .step-icon{color:#667eea;margin-bottom:16px}.step-header h2{color:#1f2937;font-size:1.75rem;font-weight:700;margin:0 0 8px}.step-header p{color:#6b7280;font-size:1rem}.intentions-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:24px}.intention-card{border:2px solid #0000;cursor:pointer;padding:20px;position:relative;text-align:center;transition:all .2s ease}.intention-card:hover{border-color:#667eea;transform:translateY(-2px)}.intention-card.selected{background:linear-gradient(135deg,#667eea10,#764ba210);border-color:#667eea}.intention-icon{font-size:2rem;margin-bottom:12px}.intention-card h3{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 8px}.intention-card h3 .required{color:#ef4444;font-size:.9rem}.intention-card p{color:#6b7280;font-size:.85rem;margin:0}.intention-card .check-icon{color:#667eea;position:absolute;right:12px;top:12px}.intention-card.settings-card{align-items:center;cursor:default;display:flex;flex-direction:column;gap:8px}.intention-card.settings-card h3{margin-bottom:4px}.intention-card.settings-card .card-input,.intention-card.settings-card .card-select{max-width:200px;width:100%}.intention-card.phase-card{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-color:#c4b5fd}.intention-card.phase-card.selected{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-color:#8b5cf6}.intention-card.phase-card .check-icon{color:#8b5cf6}.intention-card.genre-card{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#86efac}.intention-card.genre-card.selected{background:linear-gradient(135deg,#d1fae5,#bbf7d0);border-color:#22c55e}.intention-card.genre-card .check-icon{color:#22c55e}.intention-card.topic-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border-color:#fcd34d}.intention-card.topic-card.selected{background:linear-gradient(135deg,#fde68a,#fcd34d);border-color:#f59e0b}.intention-card.topic-card .check-icon{color:#f59e0b}.prompt-section{margin-bottom:24px}.prompt-card{background:linear-gradient(135deg,#fff7ed,#ffedd5);border:2px solid #fdba74;padding:20px;position:relative}.prompt-card.selected{background:linear-gradient(135deg,#ffedd5,#fed7aa);border-color:#f97316}.prompt-card .check-icon{color:#f97316;position:absolute;right:12px;top:12px}.prompt-header{align-items:center;display:flex;gap:10px;margin-bottom:12px}.prompt-header .prompt-icon{font-size:1.5rem}.prompt-header h3{color:#9a3412;font-size:1rem;font-weight:600;margin:0}.prompt-select{width:100%}.prompt-select.has-prompt{background:#fff;border-color:#f97316}.info-badge.phase-badge{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.step-actions{border-top:1px solid #e5e7eb;display:flex;gap:16px;justify-content:space-between;padding-top:24px}.step-actions button{align-items:center;display:flex;gap:8px}.step-actions .exemplars-btn{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;border-color:#f59e0b!important;color:#92400e!important}.step-actions .exemplars-btn:hover{background:linear-gradient(135deg,#fde68a,#fcd34d)!important}.sidebar-exemplars-btn{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;border-color:#f59e0b!important;color:#92400e!important;font-size:.8rem!important;margin-top:16px;width:100%}.sidebar-exemplars-btn:hover{background:linear-gradient(135deg,#fde68a,#fcd34d)!important}.criteria-view .learning-intention-display{margin-bottom:24px;text-align:center}.criteria-view .learning-intention-display .learning-intention-label{color:#667eea;display:block;font-size:.75rem;font-weight:700;letter-spacing:2px;margin:0 0 12px;text-transform:uppercase}.selected-info{display:flex;gap:12px;justify-content:center}.info-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.875rem;font-weight:500;padding:8px 16px}.info-badge.secondary{background:linear-gradient(135deg,#f093fb,#f5576c)}.criteria-cards{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.criterion-card{align-items:flex-start;background:linear-gradient(135deg,#667eea10,#764ba210);border:1px solid #667eea30;display:flex;gap:16px;padding:20px;position:relative;transition:all .3s ease;z-index:1}.criterion-card:has(.help-active){overflow:visible;z-index:100}.criterion-card.selectable{cursor:pointer;padding-right:20px}.criterion-card.selectable:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.criterion-card.selectable.selected{background:linear-gradient(135deg,#667eea20,#764ba220);border-color:#667eea;border-width:2px;box-shadow:0 4px 12px #667eea33}.criterion-content{align-items:flex-start;display:flex;gap:16px;width:100%}.selected-indicator{align-items:center;background:#10b981;border-radius:20px;color:#fff;display:flex;flex-shrink:0;font-size:.8rem;font-weight:500;gap:6px;margin-left:auto;padding:6px 12px}.selected-indicator svg{flex-shrink:0}.show-more-container{display:flex;justify-content:center;margin-bottom:24px}.show-more-btn{align-items:center;border-color:#667eea40;color:#667eea;display:flex;font-size:.9rem;gap:8px;padding:10px 20px}.show-more-btn:hover{background:#667eea10;border-color:#667eea}.grammar-section{border-top:1px dashed #667eea30;margin-top:16px;padding-top:16px}.show-grammar-btn{align-items:center;background:#8b5cf608;border-color:#8b5cf640;color:#8b5cf6;display:flex;font-size:.9rem;gap:8px;padding:10px 20px}.show-grammar-btn:hover{background:#8b5cf615;border-color:#8b5cf6}.grammar-goals-header{border-top:1px dashed #8b5cf640;margin:24px 0 16px;padding-top:16px;text-align:center}.grammar-goals-header h3{color:#8b5cf6;font-size:1.25rem;font-weight:600;margin:0 0 4px}.grammar-goals-header p{color:#6b7280;font-size:.9rem;margin:0}.grammar-cards .criterion-card{background:linear-gradient(135deg,#8b5cf610,#a78bfa10);border-color:#8b5cf630}.grammar-cards .criterion-card:hover{border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf626}.grammar-cards .criterion-card.selected{background:linear-gradient(135deg,#8b5cf620,#a78bfa20);border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf633}.criterion-card.active{padding-right:50px}.criterion-card.dismissed{background:#f3f4f6;border-color:#e5e7eb;opacity:.7}.dismiss-criterion-btn{align-items:center;background:#fee2e2;border:none;border-radius:50%;color:#dc2626;cursor:pointer;display:flex;height:28px;justify-content:center;position:absolute;right:12px;top:12px;transition:all .2s ease;width:28px}.dismiss-criterion-btn:hover{background:#fecaca;transform:scale(1.1)}.dismissed-criterion{align-items:center;display:flex;gap:12px;justify-content:space-between;width:100%}.dismissed-text{color:#9ca3af;flex:1 1;font-size:.9rem;text-decoration:line-through}.restore-criterion-btn{align-items:center;background:#fff;border:1px solid #667eea;border-radius:16px;color:#667eea;cursor:pointer;display:flex;font-size:.75rem;font-weight:600;gap:4px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.restore-criterion-btn:hover{background:#667eea;color:#fff}.criteria-count-indicator{align-items:center;background:#667eea1a;border-radius:20px;display:flex;gap:8px;margin-bottom:16px;padding:8px 16px;width:-webkit-fit-content;width:fit-content}.count-badge{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:.85rem;font-weight:700;height:24px;justify-content:center;width:24px}.count-text{color:#667eea;font-size:.85rem;font-weight:500}.criterion-card p{color:#374151;font-size:1rem;line-height:1.5;margin:0}.writing-layout{grid-gap:24px;display:grid;gap:24px;grid-template-columns:280px 1fr;margin-bottom:24px}.criteria-sidebar{background:#f9fafb;border-radius:12px;height:-webkit-fit-content;height:fit-content;padding:20px;position:-webkit-sticky;position:sticky;top:100px}.sidebar-learning-intention{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;margin-bottom:20px;padding:14px}.sidebar-learning-intention h4{align-items:center;color:#ffffffd9;display:flex;font-size:.75rem;font-weight:600;gap:6px;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.sidebar-learning-intention h4 svg{color:#ffffffe6}.learning-intention-badge{background:#fffffff2;border-radius:8px;color:#667eea;font-size:.85rem;font-weight:600;padding:8px 12px;text-align:center}.sidebar-learning-intention .genre-badge{background:#fff3;border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:500;margin-top:8px;padding:4px 10px}.criteria-sidebar h3{align-items:center;color:#667eea;display:flex;font-size:.9rem;font-weight:600;gap:8px;margin:0 0 16px}.sidebar-criteria{display:flex;flex-direction:column;gap:12px}.sidebar-criterion{color:#4b5563;display:flex;font-size:.85rem;gap:10px;line-height:1.4}.criterion-bullet{align-items:center;background:#667eea;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.7rem;font-weight:600;height:20px;justify-content:center;width:20px}.writing-area{display:flex;flex-direction:column}.writing-header{margin-bottom:16px}.writing-header h2{align-items:center;color:#1f2937;display:flex;font-size:1.25rem;font-weight:600;gap:10px;margin:0 0 4px}.writing-header p{color:#6b7280;font-size:.9rem;margin:0}.writing-section-heading{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;margin-bottom:24px;padding:24px 20px;text-align:center}.writing-section-heading h2{color:#fff!important;font-size:1.75rem;font-weight:700;margin-bottom:12px;text-shadow:0 2px 4px #0000004d}.writing-section-heading p{color:#fff!important;font-size:1.05rem;font-weight:500;line-height:1.6;margin:0;text-shadow:0 1px 3px #00000040}.writing-section-heading strong{color:#fcd34d!important;font-weight:700;text-shadow:0 1px 3px #0000004d}@media (min-width:900px){.writing-section-heading{margin-bottom:28px;padding:28px 40px}.writing-section-heading h2{font-size:2rem}.writing-section-heading p{font-size:1.1rem}}@media (max-width:600px){.writing-section-heading{border-radius:12px;margin-bottom:16px;padding:16px}.writing-section-heading h2{font-size:1.4rem}.writing-section-heading p{font-size:.9rem}}.writing-guide-image-container{align-items:center;display:flex;justify-content:center;margin-bottom:20px;text-align:center;width:100%}.writing-guide-image-full{border-radius:12px;box-shadow:0 4px 12px #0000001a;display:block;height:auto;margin:0 auto;max-width:400px;width:100%}@media (min-width:900px){.writing-guide-image-container{margin-bottom:24px}.writing-guide-image-full{border-radius:16px;box-shadow:0 4px 16px #0000001a;max-width:800px}}@media (min-width:568px) and (orientation:landscape){.writing-guide-image-container{margin-bottom:16px}.writing-guide-image-full{border-radius:12px;max-width:600px}}.writing-guide-image{display:none}.writing-prompt-display{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;margin-bottom:16px;padding:16px 20px}.writing-prompt-display .prompt-label{align-items:center;color:#92400e;display:flex;font-size:.85rem;font-weight:600;gap:8px;margin-bottom:8px}.writing-prompt-display .prompt-label svg{color:#f59e0b}.writing-prompt-display .prompt-text{color:#78350f;font-size:1.05rem;font-style:italic;font-weight:500;line-height:1.5;margin:0}.writing-textarea{border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;line-height:1.75;min-height:400px;padding:16px;resize:vertical;transition:border-color .2s ease}.writing-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.writing-stats{color:#6b7280;font-size:.85rem;gap:16px;justify-content:flex-end;margin-top:12px}.stat-good{color:#22c55e}.stat-warning{color:#f97316}.submit-btn{background:linear-gradient(135deg,#667eea,#764ba2)}.submit-btn:hover{opacity:.9}.results-header{margin-bottom:32px;text-align:center}.results-header h2{color:#1f2937;font-size:2rem;font-weight:700;margin:0 0 20px}.rating-display{background:#fff;border:3px solid;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:inline-flex;padding:20px 32px}.rating-stars{display:flex;gap:4px}.rating-label{font-size:1.25rem;font-weight:700}.results-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:24px}.results-card{padding:20px}.results-card h3{align-items:center;color:#374151;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0 0 16px}.results-card .emoji{font-size:1.25rem}.criteria-results{grid-column:1/-1}.criteria-checklist{gap:12px}.next-steps-card ul,.strengths-card ul{display:flex;flex-direction:column;gap:10px;margin:0;padding-left:20px}.next-steps-card li,.strengths-card li{color:#4b5563;line-height:1.5}.writing-card{grid-column:1/-1}.writing-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.writing-card-header h3{align-items:center;color:#1f2937;display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin:0}.writing-header-right{align-items:center;display:flex;gap:12px}.word-count-badge{background:#f3f4f6;border-radius:12px;color:#6b7280;font-size:.85rem;padding:4px 10px}.highlight-legend{align-items:center;background:#f9fafb;border-radius:8px;flex-wrap:wrap;gap:20px;margin-bottom:16px;padding:12px 16px}.legend-item{font-size:.85rem;gap:8px}.legend-color{border-radius:4px;height:16px;width:16px}.legend-tip{color:#9ca3af;font-size:.8rem;font-style:italic}.writing-display{background:#fafafa;border:1px solid #e5e7eb;border-radius:12px;color:#374151;font-size:1rem;padding:20px}.original-text{margin:0;white-space:pre-wrap}.highlight-improvement,.highlight-strength{transition:background-color .2s ease}.writing-display .has-tooltip:first-child:after{left:0;transform:translateX(0)}.writing-display .has-tooltip:first-child:before{left:20px;transform:translateX(0)}.results-actions{border-top:none;gap:20px;justify-content:center;padding-top:32px}.get-feedback-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.get-feedback-btn:hover{background:linear-gradient(135deg,#059669,#047857)}@media (max-width:768px){.write-container{padding:16px}.step-content{padding:20px}.intentions-grid{grid-template-columns:repeat(2,1fr)}.intention-card.settings-card .card-input,.intention-card.settings-card .card-select{max-width:100%}.writing-layout{grid-template-columns:1fr}.criteria-sidebar{position:static}.progress-bar{gap:4px}.progress-step{font-size:12px;padding:6px 10px}.step-label{display:none}.step-actions{flex-direction:column}.results-actions{flex-direction:row}.section-title h1{font-size:1.75rem}.step-header-row h2{font-size:1.25rem}}@media (max-width:480px){.intentions-grid{grid-template-columns:1fr}.step-header h2{font-size:1.4rem}.highlight-legend{align-items:flex-start;flex-direction:column;gap:8px}}@media (min-width:568px) and (max-width:899px) and (orientation:landscape){.intentions-grid{grid-template-columns:repeat(4,1fr)}}.reflection-button-container{display:flex;justify-content:center;margin-top:16px}.reflection-btn{background:linear-gradient(135deg,#f59e0b,#d97706)!important;border:none!important;color:#fff!important;font-weight:600;gap:8px;padding:10px 20px!important;transition:all .2s ease}.reflection-btn:hover{box-shadow:0 4px 12px #f59e0b66;transform:translateY(-2px)}.reflection-dialog{max-height:90vh;max-width:600px!important;overflow-y:auto}.reflection-questions{display:flex;flex-direction:column;gap:24px;padding:16px 0}.reflection-question h4{color:#1f2937;font-size:.95rem;font-weight:600;margin:0 0 12px}.reflection-options{display:flex;flex-direction:column;gap:8px}.reflection-option{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.reflection-option:hover{background:#f3f4f6;border-color:#d1d5db}.reflection-option.selected{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981}.reflection-option .option-number{align-items:center;background:#e5e7eb;border-radius:50%;color:#6b7280;display:flex;flex-shrink:0;font-size:.75rem;font-weight:600;height:24px;justify-content:center;width:24px}.reflection-option.selected .option-number{background:#10b981;color:#fff}.reflection-option .option-text{color:#374151;flex:1 1;font-size:.9rem;line-height:1.4}.reflection-option .check-icon{color:#10b981;flex-shrink:0}@media (max-width:768px){.reflection-dialog{margin:0 auto;max-width:95vw!important}.reflection-question h4{font-size:.9rem}.reflection-option{padding:10px 12px}.reflection-option .option-text{font-size:.85rem}}.submit-confirm-dialog{max-height:90vh!important;max-width:450px!important;overflow-y:auto!important}.submit-confirm-title{align-items:center;color:#1f2937;display:flex;font-size:1.35rem;font-weight:700;gap:10px}.submit-confirm-title .title-emoji{font-size:1.5rem}.submit-confirm-description{color:#6b7280;font-size:.95rem;margin-top:8px}.submission-checklist{display:flex;flex-direction:column;gap:12px;padding:20px 0}.checklist-item{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;gap:14px;padding:14px 16px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.checklist-item:hover{background:#f3f4f6;border-color:#d1d5db}.checklist-item.checked{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#10b981}.checklist-item input[type=checkbox]{opacity:0;pointer-events:none;position:absolute}.checkbox-custom{align-items:center;background:#fff;border:2px solid #d1d5db;border-radius:6px;display:flex;flex-shrink:0;height:24px;justify-content:center;transition:all .2s ease;width:24px}.checklist-item.checked .checkbox-custom{background:#10b981;border-color:#10b981;color:#fff}.checklist-text{color:#374151;font-size:.95rem;font-weight:500;line-height:1.4}.checklist-item.checked .checklist-text{color:#065f46}.submit-confirm-footer{display:flex;gap:12px;justify-content:flex-end;padding-top:8px}.confirm-submit-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important;display:flex;gap:8px}.confirm-submit-btn:hover{opacity:.9}@media (max-width:640px){.submit-confirm-dialog{margin:0 auto;max-width:95vw!important}.submit-confirm-title{font-size:1.2rem}.checklist-item{padding:12px 14px}.checklist-text{font-size:.9rem}.submit-confirm-footer{flex-direction:column-reverse}.submit-confirm-footer button{justify-content:center;width:100%}}@media (max-height:500px) and (orientation:landscape){.submit-confirm-dialog{max-height:85vh!important;max-width:90vw!important;overflow-y:auto!important}.submit-confirm-dialog [data-radix-scroll-area-viewport],.submit-confirm-dialog>div{max-height:80vh!important;overflow-y:auto!important}.submit-confirm-title{font-size:1.1rem}.submit-confirm-title .title-emoji{font-size:1.2rem}.submit-confirm-description{font-size:.85rem;margin-top:4px}.submission-checklist{gap:8px;padding:12px 0}.checklist-item{gap:10px;padding:10px 12px}.checkbox-custom{height:20px;width:20px}.checklist-text{font-size:.85rem}.submit-confirm-footer{gap:8px;padding-top:8px}.submit-confirm-footer button{font-size:.9rem;padding:8px 16px}}.desktop-wizard{display:none}.mobile-grid-layout{display:block}@media (min-width:568px) and (orientation:landscape){.desktop-wizard{display:block;margin:0 auto;max-width:100%;padding:0 16px}.mobile-grid-layout{display:none}.wizard-intention-card .intention-tooltip{display:none!important}.wizard-step{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000f;margin-bottom:12px;padding:16px;text-align:center}.wizard-step.fade-in{animation:wizardFadeIn .3s ease-out}.wizard-step-header{gap:10px;margin-bottom:6px}.wizard-step-header,.wizard-step-number{align-items:center;display:flex;justify-content:center}.wizard-step-number{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;font-size:.9rem;font-weight:700;height:28px;width:28px}.wizard-step-header h3{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.wizard-step-hint{color:#6b7280;font-size:.85rem;margin:0 0 12px}.wizard-intentions-row{display:flex;flex-wrap:nowrap;gap:8px;justify-content:center;margin-top:-180px;overflow:visible;padding-top:180px}.wizard-intention-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;min-width:100px;padding:12px 8px;position:relative;text-align:center;transition:all .2s ease;width:100px}.wizard-intention-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.wizard-intention-card.selected{background:linear-gradient(135deg,#667eea15,#764ba215);border-color:#667eea;box-shadow:0 4px 12px #667eea40}.wizard-intention-card .intention-icon{font-size:1.25rem;margin-bottom:4px}.wizard-intention-card h4{color:#374151;font-size:.65rem;font-weight:600;line-height:1.2;margin:0}.wizard-intention-card .check-icon{color:#667eea;position:absolute;right:4px;top:4px}.wizard-phase-options{display:flex;flex-wrap:nowrap;gap:8px;justify-content:center}.wizard-phase-btn{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:2px;min-width:90px;padding:10px 16px;position:relative;transition:all .2s ease}.wizard-phase-btn:hover{background:#faf5ff;border-color:#8b5cf6}.wizard-phase-btn.selected{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf640}.wizard-phase-btn .phase-emoji{font-size:1.2rem}.wizard-phase-btn .phase-label{color:#374151;font-size:.8rem;font-weight:600}.wizard-phase-btn .phase-years{color:#6b7280;font-size:.65rem}.wizard-phase-btn .check-icon{color:#8b5cf6;position:absolute;right:4px;top:4px}.wizard-genre-options{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.wizard-genre-btn{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:20px;color:#374151;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:6px;padding:8px 12px;position:relative;transition:all .2s ease}.wizard-genre-btn:hover{background:#f0fdf4;border-color:#22c55e}.wizard-genre-btn.selected{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#22c55e;color:#166534}.wizard-genre-btn .genre-emoji{font-size:.9rem}.wizard-genre-btn .check-icon{color:#22c55e;margin-left:2px}.wizard-topic-input{margin:0 auto;max-width:400px;position:relative}.wizard-topic-input .topic-input{border:2px solid #e5e7eb;border-radius:10px;font-size:.9rem;padding:10px 40px 10px 14px;width:100%}.wizard-topic-input .topic-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.wizard-topic-input .check-icon.floating{color:#f59e0b;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.wizard-prompt-section{margin:0 auto;max-width:400px;position:relative}.wizard-prompt-select{border:2px solid #e5e7eb;border-radius:10px;font-size:.9rem;padding:10px 14px;width:100%}.wizard-prompt-select.has-prompt{background:#fff7ed;border-color:#f97316}.wizard-prompt-section .check-icon.floating{color:#f97316;position:absolute;right:40px;top:50%;transform:translateY(-50%)}.wizard-ready{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:12px;margin-top:16px;padding:12px}.ready-message{align-items:center;display:flex;flex-wrap:nowrap;gap:10px;justify-content:center}.ready-emoji{font-size:1.5rem}.ready-message p{color:#065f46;font-size:.95rem;margin:0}.ready-text{line-height:1.6;text-align:center}.click-next-group{display:inline-block;white-space:nowrap}.ready-line-2{display:inline;white-space:normal}.ready-line-1{white-space:nowrap}}@media (min-width:900px){.desktop-wizard{display:block;margin:0 auto;max-width:800px}.mobile-grid-layout{display:none}.wizard-step{background:#fff;border:2px solid #e5e7eb;border-radius:16px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px;padding:24px;text-align:center}.wizard-step.fade-in{animation:wizardFadeIn .4s ease-out}@keyframes wizardFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.wizard-step-header{gap:12px;margin-bottom:8px}.wizard-step-header,.wizard-step-number{align-items:center;display:flex;justify-content:center}.wizard-step-number{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;font-size:1rem;font-weight:700;height:32px;width:32px}.wizard-step-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.wizard-step-hint{color:#6b7280;font-size:.95rem;margin:0 0 20px}.wizard-intentions-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.wizard-intention-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;padding:16px 12px;position:relative;text-align:center;transition:all .2s ease;width:130px}.wizard-intention-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-3px)}.wizard-intention-card.selected{background:linear-gradient(135deg,#667eea15,#764ba215);border-color:#667eea;box-shadow:0 4px 12px #667eea40}.wizard-intention-card .intention-icon{font-size:1.75rem;margin-bottom:8px}.wizard-intention-card h4{color:#374151;font-size:.8rem;font-weight:600;line-height:1.3;margin:0}.wizard-intention-card .check-icon{color:#667eea;position:absolute;right:8px;top:8px}.wizard-phase-options{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.wizard-phase-btn{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;min-width:120px;padding:16px 24px;position:relative;transition:all .2s ease}.wizard-phase-btn:hover{background:#faf5ff;border-color:#8b5cf6;transform:translateY(-2px)}.wizard-phase-btn.selected{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-color:#8b5cf6;box-shadow:0 4px 12px #8b5cf640}.wizard-phase-btn .phase-emoji{font-size:1.5rem}.wizard-phase-btn .phase-label{color:#374151;font-size:.95rem;font-weight:600}.wizard-phase-btn .phase-years{color:#6b7280;font-size:.75rem}.wizard-phase-btn .check-icon{color:#8b5cf6;position:absolute;right:8px;top:8px}.wizard-genre-options{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.wizard-genre-btn{align-items:center;background:#f9fafb;border:2px solid #e5e7eb;border-radius:25px;color:#374151;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:8px;padding:12px 18px;position:relative;transition:all .2s ease}.wizard-genre-btn:hover{background:#f0fdf4;border-color:#22c55e}.wizard-genre-btn.selected{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#22c55e;color:#166534}.wizard-genre-btn .genre-emoji{font-size:1.1rem}.wizard-genre-btn .check-icon{color:#22c55e;margin-left:4px}.wizard-topic-input{margin:0 auto;max-width:500px;position:relative}.wizard-topic-input .topic-input{border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;padding:14px 45px 14px 16px;transition:all .2s ease;width:100%}.wizard-topic-input .topic-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.wizard-topic-input .check-icon.floating{color:#f59e0b;position:absolute;right:14px;top:50%;transform:translateY(-50%)}.wizard-prompt-section{margin:0 auto;max-width:500px;position:relative}.wizard-prompt-select{border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;padding:14px 16px;width:100%}.wizard-prompt-select.has-prompt{background:#fff7ed;border-color:#f97316}.wizard-prompt-section .check-icon.floating{color:#f97316;position:absolute;right:45px;top:50%;transform:translateY(-50%)}.wizard-ready{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:16px;margin-top:24px;padding:20px 40px;text-align:center}.ready-message{display:block!important;width:100%}.ready-emoji{display:block;font-size:2rem;margin-bottom:8px}.ready-message p{color:#065f46;font-size:1.1rem;margin:0}.ready-message strong{color:#047857}.ready-text{line-height:1.5;max-width:100%;width:100%}.click-next-group{display:inline-block;white-space:nowrap}.ready-line-2{display:inline;white-space:normal}.ready-line-1{white-space:nowrap}}.intention-tooltip{background:#fff;border:2px solid #667eea;border-radius:12px;bottom:calc(100% + 10px);box-shadow:0 10px 40px #0003;opacity:0;padding:16px;pointer-events:none;transition:all .2s ease;visibility:hidden;width:320px;z-index:9999}.intention-tooltip,.intention-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.intention-tooltip:after{border:10px solid #0000;border-top-color:#667eea;content:"";top:100%}.intention-card:hover .intention-tooltip,.wizard-intention-card:hover .intention-tooltip{opacity:1;visibility:visible}.intention-tooltip .tooltip-definition{color:#374151;font-size:.9rem;line-height:1.5;margin:0 0 12px}.intention-tooltip .tooltip-example{background:#f3f4f6;border-radius:8px;color:#6b7280;font-size:.85rem;font-style:italic;line-height:1.5;margin:0;padding:10px 12px}.intention-tooltip .tooltip-example strong{color:#667eea;font-style:normal}@media (min-width:900px){.wizard-intention-card{overflow:visible;position:relative}.wizard-intention-card .intention-tooltip{bottom:calc(100% + 12px);display:block!important;opacity:0;top:auto;visibility:hidden;width:380px}.wizard-intention-card:hover .intention-tooltip{opacity:1!important;visibility:visible!important}.wizard-intention-card .intention-tooltip:after{border:10px solid #0000;border-top-color:#667eea;top:100%}.wizard-intention-card:first-child .intention-tooltip{left:0;transform:translateX(0)}.wizard-intention-card:first-child .intention-tooltip:after{left:30px;transform:translateX(0)}.wizard-intention-card:last-child .intention-tooltip{left:auto;right:0;transform:translateX(0)}.wizard-intention-card:last-child .intention-tooltip:after{left:auto;right:30px;transform:translateX(0)}.wizard-step{overflow:visible}.wizard-intentions-row{margin-top:-220px;overflow:visible;padding-top:220px}.desktop-wizard,.step-content.intention-selection{overflow:visible}}@media (max-width:899px){.intention-card{position:relative}.intention-card .intention-tooltip{display:none!important}}@media (hover:none){.intention-tooltip{display:none!important}}.assessment-view-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding-bottom:40px}.assessment-view-page.error,.assessment-view-page.loading{align-items:center;color:#fff;display:flex;flex-direction:column;gap:16px;justify-content:center}.loading-spinner{border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:48px;width:48px}.parent-mode-banner{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;font-size:1rem;font-weight:600;padding:12px;position:-webkit-sticky;position:sticky;text-align:center;top:0;z-index:100}.view-header{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:800px;padding:16px 24px}.view-header button{border-color:#ffffff4d;color:#fff}.view-header button:hover{background:#ffffff1a}.header-date{align-items:center;color:#fffc;display:flex;font-size:.9rem;gap:8px}.view-content{margin:0 auto;max-width:800px;padding:0 24px}.title-section{color:#fff;margin-bottom:24px;text-align:center}.title-section h1{font-size:1.75rem;font-weight:700;margin:0 0 12px}.learning-intention-display{margin-bottom:12px}.learning-intention-label{color:#fffc;font-size:.75rem;font-weight:600;letter-spacing:1px;margin:0 0 8px;text-transform:uppercase}.learning-badge{align-items:center;background:#fff3;border-radius:20px;display:inline-flex;font-size:.9rem;gap:8px;margin-right:8px;padding:8px 16px}.genre-badge{background:#ffffff26;border-radius:16px;display:inline-block;font-size:.85rem;padding:6px 12px}.criteria-card,.feedback-card,.rating-card,.writing-card{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000001a;margin-bottom:16px;padding:24px}.rating-card{text-align:center}.rating-display{align-items:center;flex-direction:column}.rating-display,.rating-display .stars{display:flex;gap:8px}.rating-text{font-size:1.5rem}.family-message{color:#059669;font-size:1.25rem;font-weight:600;margin-top:8px}.phase-label{color:#6b7280;margin-top:4px}.growth-score-card{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:2px solid #10b981;text-align:center}.growth-score-title{color:#059669;margin:0 0 16px}.growth-score-display{align-items:center;display:flex;flex-direction:column;gap:12px}.growth-stars{display:flex;gap:8px}.growth-label{font-size:1.3rem;font-weight:700}.growth-message{color:#4b5563;font-size:.95rem;line-height:1.5;max-width:400px}.growth-details{display:flex;gap:16px;margin-top:8px}.growth-stat{background:#fff;border:1px solid #e5e7eb;border-radius:20px;color:#6b7280;font-size:.85rem;padding:6px 12px}.growth-score-card.family-style{background:linear-gradient(135deg,#fef3c7,#fde68a 50%,#fcd34d);border:3px solid #f59e0b;padding:28px}.growth-score-card.family-style .growth-score-title{color:#92400e;font-size:1.4rem}.growth-explanation{background:#ffffffb3;border:1px solid #fcd34d;border-radius:12px;margin-top:16px;padding:12px 16px}.growth-explanation-text{color:#78350f;font-size:.9rem;font-style:italic;line-height:1.5;margin:0}.phase-card{padding:16px;text-align:center}.phase-display{display:flex;justify-content:center}.phase-badge{border-radius:20px;font-size:1rem;padding:8px 20px}.criteria-card h3{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 16px}.criteria-list{display:flex;flex-direction:column;gap:10px}.criteria-item{font-size:.95rem;gap:12px;padding:12px}.criteria-item .check{color:#22c55e;flex-shrink:0}.criteria-item .x{color:#f97316;flex-shrink:0}.feedback-card h3{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 12px}.feedback-card ul{margin:0;padding-left:24px}.feedback-card li{color:#4b5563;line-height:1.6;margin-bottom:8px}.feedback-card.family-style.strengths{background:linear-gradient(135deg,#fef3c7,#fef9c3);border:2px solid #fbbf24}.feedback-card.family-style.next-steps{background:linear-gradient(135deg,#dbeafe,#e0e7ff);border:2px solid #667eea}.feedback-card.help-card{background:linear-gradient(135deg,#dcfce7,#d1fae5);border:2px solid #22c55e}.feedback-card.questions-card{background:linear-gradient(135deg,#fce7f3,#fdf2f8);border:2px solid #ec4899}.feedback-card.teacher-comment{background:linear-gradient(135deg,#f3e8ff,#fae8ff);border:2px solid #a855f7}.comment-text{color:#6b21a8;font-style:italic;line-height:1.6;margin:0}.writing-card h3{color:#374151;font-size:1.1rem;font-weight:600;margin:0}.writing-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.word-count{color:#9ca3af;font-size:.85rem;margin-bottom:12px}.highlighted-text,.writing-text{color:#374151}.progress-chart-card{background:#fff;border-radius:16px;margin-bottom:20px;padding:20px}.progress-chart-card.family-style{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981}.progress-chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.progress-chart-header h3{color:#065f46;font-size:1.1rem;font-weight:700;margin:0}.progress-trend{align-items:center;border-radius:20px;display:flex;font-size:.8rem;font-weight:600;gap:6px;padding:4px 10px}.trend-label.improving{background:#d1fae5;color:#059669}.trend-label.steady{background:#fef3c7;color:#d97706}.trend-label.declining{background:#fee2e2;color:#dc2626}.progress-chart-container{background:#fff;border-radius:12px;margin-bottom:16px;padding:12px 8px}.custom-tooltip{background:#1f2937;border-radius:8px;box-shadow:0 4px 12px #0003;color:#fff;font-size:.8rem;padding:10px 14px}.tooltip-date{color:#9ca3af;margin-bottom:4px}.tooltip-score{margin:0}.tooltip-score strong{color:#10b981}.tooltip-revisions{color:#9ca3af;font-size:.75rem;margin-top:4px}.progress-summary{border-bottom:1px solid #d1fae5;border-top:1px solid #d1fae5;display:flex;justify-content:space-around;margin-bottom:12px;padding:12px 0}.summary-stat{gap:2px}.stat-value{color:#059669;font-size:1.4rem}.stat-label{font-size:.7rem;letter-spacing:.5px;text-transform:uppercase}.progress-explanation{color:#4b5563;font-size:.8rem;line-height:1.5;margin:0;text-align:center}.progress-chart-card.no-data{padding:24px;text-align:center}.no-data-message p{color:#065f46;font-size:.95rem;margin:0 0 8px}.no-data-message .sub-message{color:#6b7280;font-size:.85rem}@media (max-width:480px){.progress-chart-card{padding:16px}.progress-chart-header h3{font-size:1rem}.progress-chart-container{padding:8px 4px}.stat-value{font-size:1.2rem}.stat-label{font-size:.65rem}.progress-explanation{font-size:.75rem}}.action-buttons button{align-items:center;display:flex;gap:8px}.revision-card{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:2px solid #10b981;border-radius:16px;margin-top:24px;padding:24px}.revision-header h3{align-items:center;color:#059669;display:flex;font-size:1.2rem;font-weight:600;gap:8px;margin:0 0 8px}.revision-subtitle{color:#6b7280;font-size:.9rem;margin:0 0 20px}.revision-editor{margin-bottom:20px}.revision-textarea{border:2px solid #d1d5db;border-radius:12px;font-family:inherit;font-size:1rem;line-height:1.7;min-height:250px;padding:16px;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.revision-textarea:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b98126;outline:none}.revision-stats{color:#6b7280;display:flex;font-size:.85rem;gap:16px;margin-top:12px}.saved-indicator{align-items:center;color:#10b981;display:flex;font-weight:500;gap:4px}.revision-actions{display:flex;flex-wrap:wrap;gap:12px}.revision-actions button{align-items:center;display:flex;gap:8px}.get-feedback-btn{background:linear-gradient(135deg,#10b981,#059669)!important;border:none!important;color:#fff!important}.get-feedback-btn:hover{background:linear-gradient(135deg,#059669,#047857)!important}.reflection-section{border-top:2px dashed #d1fae5;margin-top:24px;padding-top:24px}.reflection-title{color:#059669;font-size:1.1rem;font-weight:600;margin:0 0 20px}.reflection-question{margin-bottom:24px}.reflection-question:last-child{margin-bottom:0}.question-text{color:#374151;font-size:.95rem;font-weight:600;margin:0 0 12px}.options-list{display:flex;flex-direction:column;gap:8px}.option-item{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:10px 14px;transition:all .2s ease}.option-item:hover{background:#f0fdf4;border-color:#10b981}.option-item input[type=radio]{accent-color:#10b981;cursor:pointer;height:18px;width:18px}.option-item input[type=radio]:checked+.option-text{color:#059669;font-weight:500}.option-item:has(input:checked){background:#ecfdf5;border-color:#10b981}.option-text{color:#4b5563;font-size:.9rem}@media (max-width:768px){.view-content{padding:0 16px}.title-section h1{font-size:1.5rem}.criteria-card,.feedback-card,.rating-card,.writing-card{padding:16px}.writing-header{align-items:flex-start;gap:12px}.action-buttons,.writing-header{flex-direction:column}.action-buttons button{justify-content:center;width:100%}}.goals-chart-card{background:#fff;border-radius:16px;margin-bottom:20px;padding:20px}.goals-chart-card.family-style{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.goals-chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.goals-chart-header h3{color:#92400e;font-size:1.1rem;font-weight:700;margin:0}.goals-rate{align-items:center;background:#fff;border-radius:20px;box-shadow:0 2px 4px #0000001a;display:flex;gap:6px;padding:4px 12px}.rate-value{color:#d97706;font-size:.9rem;font-weight:700}.goals-chart-container{background:#fff;border-radius:12px;margin-bottom:12px;padding:12px 8px}.goals-legend{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-bottom:12px}.legend-item{color:#6b7280;font-size:.7rem}.legend-dot{border-radius:2px;height:10px;width:10px}.legend-dot.gray{background:#e5e7eb}.legend-dot.green{background:#10b981}.legend-dot.orange{background:#f59e0b}.goals-summary{border-bottom:1px solid #fcd34d;border-top:1px solid #fcd34d;display:flex;justify-content:space-around;margin-bottom:12px;padding:12px 0}.goals-summary .summary-stat.highlight .stat-value{color:#d97706;font-size:1.5rem}.goals-explanation{color:#78350f;font-size:.8rem;line-height:1.5;margin:0;text-align:center}.goals-tooltip .tooltip-achieved{color:#10b981;margin:4px 0}.goals-tooltip .tooltip-cumulative{color:#9ca3af;font-size:.7rem;margin:0}@media (max-width:480px){.goals-chart-card{padding:16px}.goals-chart-header h3{font-size:1rem}.goals-legend{gap:10px}.legend-item{font-size:.65rem}.goals-summary .stat-value{font-size:1.2rem}.goals-summary .summary-stat.highlight .stat-value{font-size:1.3rem}.goals-explanation{font-size:.75rem}}.manage-students-container{width:100%}.manage-students-card{background:#fff;border-radius:12px;padding:24px}.manage-students-empty{background:#fff;border-radius:12px;padding:60px 24px}.section-header{border-bottom:2px solid #f0f0f0}.section-title h2{color:#1a1a1a;font-size:24px}.student-count{color:#718096;font-size:16px;font-weight:400}.section-actions{gap:12px}.empty-state,.loading-state{padding:60px 20px}.empty-state p,.loading-state p{color:#718096;font-size:16px;margin-top:16px}.empty-subtitle{color:#a0aec0!important;font-size:14px!important;margin-top:8px!important}.empty-state button{margin-top:20px}.students-roster{overflow-x:auto}.students-table thead{background:#f7fafc;border-radius:8px}.students-table th{border-bottom:2px solid #e2e8f0;color:#4a5568;font-size:14px;padding:12px 16px;text-align:left}.students-table td{border-bottom:1px solid #e2e8f0;font-size:14px;padding:16px}.students-table tbody tr:hover{background:#f7fafc}.student-name{color:#2d3748;font-weight:500}.username-cell code{background:#edf2f7;border-radius:4px;color:#4a5568;padding:4px 8px}.password-display,.username-cell code{font-family:Courier New,monospace;font-size:13px}.password-display{background:#f0fff4;border-radius:6px;color:#276749;display:inline-block;font-weight:600;padding:4px 12px}.no-data{color:#a0aec0}.family-pin{background:#fff5f5;border-radius:6px;color:#c53030;display:inline-block;font-family:Courier New,monospace;letter-spacing:1px;padding:4px 12px}.assessment-count,.family-pin{font-size:13px;font-weight:600}.assessment-count{align-items:center;background:#e6fffa;border-radius:50%;color:#00695c;display:inline-flex;height:32px;justify-content:center;width:32px}.actions-cell{display:flex;gap:4px}.actions-cell button{padding:6px!important}.actions-cell button:hover{background:#edf2f7}.form-fields{gap:16px;margin:20px 0}.form-fields,.form-group{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{font-size:14px}.form-group input{border:1px solid #e2e8f0;border-radius:6px;font-size:14px;padding:10px}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}@media print{body *{visibility:hidden}.login-cards-print,.login-cards-print *{visibility:visible}.login-cards-print{left:0;position:absolute;top:0}}@media (max-width:768px){.section-header{align-items:flex-start;flex-direction:column;gap:16px}.section-actions{flex-direction:column;width:100%}.section-actions button{width:100%}.students-table{font-size:12px}.students-table td,.students-table th{padding:8px}.actions-cell{flex-direction:column}}.print-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:9999}.print-modal-container{background:#fff;border-radius:16px;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;width:100%}.print-modal-header{align-items:center;background:#f7fafc;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;padding:20px 24px}.print-modal-header h2{color:#2d3748;font-size:20px;font-weight:600;margin:0}.print-modal-actions{display:flex;gap:12px}.print-cards-content{max-height:calc(90vh - 100px);overflow-y:auto;padding:24px}.print-cards-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.print-login-card{background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #667eea;border-radius:12px;color:#fff;padding:20px;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.print-card-header{border-bottom:2px solid #ffffff80;margin-bottom:16px;padding-bottom:12px;text-align:center}.print-card-header h3{font-size:18px;font-weight:600;margin:0}.print-card-body{line-height:1.8}.print-card-field{font-size:14px;margin:8px 0}.print-card-field strong{display:inline-block;width:110px}.print-card-footer{border-top:1px solid #fff6;font-size:13px;margin-top:16px;opacity:.9;padding-top:12px;text-align:center}@media print{body *{visibility:hidden}.print-cards-content,.print-cards-content *,.print-modal-container,.print-modal-overlay{visibility:visible}.print-modal-overlay{background:#fff!important;height:auto;left:0;padding:0;position:absolute;top:0;width:100%}.print-modal-container{border-radius:0;box-shadow:none;max-height:none;max-width:100%}.print-modal-header.no-print{display:none!important}.print-cards-content{max-height:none;padding:.5in}.print-cards-grid{gap:15px}.print-login-card{background:#fff!important;border:2px solid #333!important;break-inside:avoid;color:#000!important;page-break-inside:avoid;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}.print-card-header{border-bottom-color:#333!important}.print-card-body,.print-card-field,.print-card-field strong,.print-card-header,.print-card-header h3{color:#000!important}.print-card-footer{border-top-color:#666!important;color:#333!important;opacity:1!important}@page{size:A4;margin:.5in}}@media (max-width:768px){.print-cards-grid{grid-template-columns:1fr}.print-modal-header{align-items:flex-start;flex-direction:column;gap:12px}.print-modal-actions{justify-content:flex-end;width:100%}}.student-practice-container{padding:24px}.practice-header{align-items:center;display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.header-title-section{text-align:center;width:100%}.header-title-section h2{align-items:center;color:#1f2937;display:flex;font-size:1.5rem;font-weight:700;gap:10px;justify-content:center;margin:0 0 8px}.header-title-section p{color:#6b7280;font-size:.95rem;margin:0}.header-actions{flex-wrap:wrap}.pdf-download-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.pdf-download-btn:hover{background:linear-gradient(135deg,#5a67d8,#6b3fa0);color:#fff}.search-box{padding:0 12px}.search-box input{background:#0000;width:200px}.search-box input:focus{box-shadow:none}.filter-count{background:#667eea;border-radius:10px;color:#fff;font-size:11px;margin-left:6px;padding:2px 6px}.stats-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.stat-icon{height:48px;width:48px}.stat-icon.submissions{background:linear-gradient(135deg,#667eea,#764ba2)}.stat-icon.unviewed{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-icon.students{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-icon.trending{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-content{display:flex;flex-direction:column}.filters-panel{align-items:flex-end;background:#f9fafb;border-radius:12px;display:none;gap:16px;margin-bottom:16px;padding:16px}.filters-panel.show{display:flex;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:6px;min-width:180px}.filter-group label{color:#6b7280;font-size:.8rem;font-weight:500}.results-info{color:#6b7280;font-size:.85rem;margin-bottom:16px}.assessments-list{grid-gap:16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.assessment-card{border:2px solid #0000;cursor:pointer;transition:all .2s ease}.assessment-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.assessment-card.unviewed{background:linear-gradient(135deg,#fdf4ff,#faf5ff);border-left:4px solid #f093fb}.assessment-header{margin-bottom:12px}.student-info{align-items:center;display:flex;gap:8px}.new-badge{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:10px;font-size:10px;padding:2px 8px;text-transform:uppercase}.new-badge,.rating-badge{color:#fff;font-weight:600}.rating-badge{border-radius:20px;font-size:12px;padding:4px 12px}.growth-score-badge{align-items:center;border-radius:20px;display:flex;gap:4px;padding:4px 10px}.growth-stars-small{display:flex;gap:2px}.revision-count{align-items:center;color:#059669;display:flex;font-weight:500;gap:4px}.assessment-content{margin-bottom:12px}.intention-badge{align-items:center;background:#f3f4f6;border-radius:6px;color:#4b5563;display:inline-flex;font-size:12px;gap:6px;margin-bottom:8px;padding:4px 10px}.writing-preview{-webkit-line-clamp:3;-webkit-box-orient:vertical;color:#6b7280;display:-webkit-box;font-size:.9rem;line-height:1.5;margin:0;overflow:hidden}.assessment-footer{align-items:center;color:#9ca3af;display:flex;font-size:.8rem;gap:16px}.assessment-footer span{align-items:center;display:flex;gap:4px}.has-comment{color:#667eea}.download-single-btn{color:#667eea;margin-left:auto;opacity:.7;padding:4px 8px;transition:opacity .2s}.download-single-btn:hover{background:#667eea1a;opacity:1}.assessment-card .assessment-content,.assessment-card .assessment-header{cursor:pointer}.empty-state,.loading-state{padding:60px;text-align:center}.loading-state .spinner{animation:spin 1s linear infinite;color:#667eea}.empty-state svg{color:#d1d5db;margin-bottom:16px}.empty-state h3{color:#374151;margin:0 0 8px}.empty-state p{margin:0}.pagination{align-items:center;border-top:1px solid #e5e7eb;display:flex;gap:16px;justify-content:center;margin-top:24px;padding-top:24px}.page-info{color:#6b7280;font-size:.9rem}.detail-modal{max-height:90vh;max-width:900px;overflow-y:auto}.modal-title{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.view-toggle{display:flex;gap:8px}.modal-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;gap:16px;padding:60px}.modal-content{padding:16px 0}.detail-section{border-bottom:1px solid #e5e7eb;margin-bottom:24px;padding-bottom:24px}.detail-section:last-child{border-bottom:none;margin-bottom:0}.detail-section h4{align-items:center;color:#374151;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0 0 12px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.info-item label{color:#9ca3af;display:block;font-size:.75rem;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.info-item span{color:#1f2937;font-weight:500}.rating-section{text-align:center}.rating-display-large{align-items:center;display:flex;flex-direction:column;gap:8px}.rating-display-large .stars{display:flex;gap:4px}.rating-text{font-size:1.25rem;font-weight:700}.phase-text{color:#6b7280;font-size:.9rem}.growth-section{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:2px solid #10b981;border-radius:12px;padding:20px;text-align:center}.growth-section h4{color:#059669;margin:0 0 16px}.growth-display-large{align-items:center;display:flex;flex-direction:column;gap:8px}.growth-stars-large{display:flex;gap:4px}.growth-label-text{font-size:1.2rem;font-weight:700}.growth-stats{display:flex;gap:12px;margin-top:8px}.revision-badge{background:#ecfdf5;border:1px solid #10b981;border-radius:12px;color:#059669;font-size:.8rem;font-weight:500;padding:4px 12px}.reflection-section{background:#fefce8;border:2px solid #facc15;border-radius:12px;padding:20px}.reflection-section h4{color:#854d0e;margin:0 0 16px}.reflection-answers{display:flex;flex-direction:column;gap:12px}.reflection-item{display:flex;flex-direction:column;gap:4px}.reflection-item label{color:#92400e;font-size:.8rem;font-weight:600;text-transform:uppercase}.reflection-item span{background:#fff;border:1px solid #fde68a;border-radius:8px;color:#451a03;font-size:.95rem;padding:8px 12px}.criteria-checklist{display:flex;flex-direction:column;gap:8px}.criteria-item{align-items:flex-start;border-radius:8px;display:flex;font-size:.9rem;gap:10px;padding:10px 12px}.criteria-item.met{background:#dcfce7;color:#166534}.criteria-item.not-met{background:#fef3c7;color:#92400e}.two-column{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.column h4{margin-bottom:12px}.column ul{margin:0;padding-left:20px}.column li{line-height:1.5;margin-bottom:8px}.writing-section .writing-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.highlight-legend{color:#6b7280;display:flex;font-size:.85rem;gap:16px;margin-bottom:12px}.legend-item{align-items:center;display:flex;gap:6px}.legend-color{border-radius:3px;height:14px;width:14px}.legend-color.strength{background-color:#fef3c7;border:1px solid #f59e0b}.legend-color.improvement{background-color:#fce7f3;border:1px solid #ec4899}.writing-display{background:#f9fafb;border-radius:8px;font-size:.95rem;line-height:1.8;padding:16px}.highlighted-text,.writing-display{white-space:pre-wrap}.highlight-strength{background-color:#fef3c7;border-radius:3px;cursor:help;padding:2px 0}.highlight-strength:hover{background-color:#fde68a}.highlight-improvement{background-color:#fce7f3;border-radius:3px;cursor:help;padding:2px 0}.highlight-improvement:hover{background-color:#fbcfe8}.has-tooltip{position:relative}.has-tooltip:after{background-color:#1f2937;border-radius:8px;bottom:calc(100% + 8px);box-shadow:0 4px 12px #0003;color:#fff;content:attr(data-tooltip);font-size:.85rem;left:50%;line-height:1.5;max-width:min(300px,85vw);opacity:0;padding:10px 14px;pointer-events:none;position:absolute;text-align:left;transform:translateX(-50%);transition:opacity .2s ease,visibility .2s ease;visibility:hidden;white-space:normal;width:-webkit-max-content;width:max-content;z-index:1000}@media (max-width:768px){.has-tooltip:after{bottom:auto;left:50%!important;max-width:85vw;position:fixed;top:50%;transform:translateX(-50%)!important;width:85vw}.has-tooltip:before{display:none}}.has-tooltip:before{border:6px solid #0000;border-top-color:#1f2937;bottom:calc(100% + 2px);content:"";left:50%;opacity:0;position:absolute;transform:translateX(-50%);transition:opacity .2s ease,visibility .2s ease;visibility:hidden;z-index:1001}.has-tooltip:hover:after,.has-tooltip:hover:before{opacity:1;visibility:visible}.highlight-strength.has-tooltip:after{border-left:3px solid #fbbf24}.highlight-improvement.has-tooltip:after{border-left:3px solid #ec4899}.comment-section textarea{margin-bottom:12px}.save-comment-btn{align-items:center;display:flex;gap:8px}.family-view{background:#fefce8;border-radius:16px;padding:24px}.family-header{margin-bottom:24px;text-align:center}.family-header h2{color:#1f2937;font-size:1.5rem;margin:0 0 8px}.family-date{color:#6b7280;font-size:.9rem}.family-rating{margin-bottom:24px;text-align:center}.stars-large{display:flex;gap:8px;justify-content:center;margin-bottom:12px}.rating-description{color:#374151;font-size:1.1rem;font-weight:500}.family-section{background:#fff;margin-bottom:16px;padding:20px}.family-section h3{color:#1f2937;font-size:1.1rem;font-weight:600;margin:0 0 12px}.focus-area{color:#667eea;font-size:1.1rem;font-weight:500;margin:0}.genre-info{color:#6b7280;font-size:.9rem;margin:8px 0 0}.practised-goals{border-top:1px solid #667eea33;margin-top:16px;padding-top:12px}.practised-goals .goals-label{color:#4b5563;font-size:.85rem;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.practised-goals .goals-list{margin:0;padding-left:20px}.practised-goals .goals-list li{color:#374151;font-size:.95rem;line-height:1.4;margin-bottom:6px}.practised-goals .goals-list li:last-child{margin-bottom:0}.family-section.celebration{background:linear-gradient(135deg,#fef3c7,#fef9c3);border:2px solid #fbbf24}.family-section.goals{background:linear-gradient(135deg,#dbeafe,#e0e7ff);border:2px solid #667eea}.family-section.help-section{background:linear-gradient(135deg,#dcfce7,#d1fae5);border:2px solid #22c55e}.family-list{margin:0;padding-left:24px}.family-list li{color:#374151;line-height:1.6;margin-bottom:10px}.family-list.tips li{position:relative}.family-list.tips li::marker{color:#22c55e}.writing-family h3{margin-bottom:8px}.word-count-family{color:#6b7280;font-size:.85rem;margin:0 0 12px}.writing-display-family{background:#f9fafb;border-radius:8px;line-height:1.8;padding:16px;white-space:pre-wrap}.teacher-note{background:linear-gradient(135deg,#f3e8ff,#fae8ff);border:2px solid #a855f7}.teacher-note p{color:#6b21a8;font-style:italic;margin:0}@media (max-width:768px){.student-practice-container{box-sizing:border-box;overflow-x:hidden;padding:12px;width:100%}.practice-header{align-items:center;flex-direction:column;gap:12px;text-align:center;width:100%}.practice-header h2{font-size:1.25rem;text-align:center;width:100%}.practice-header p{font-size:.85rem;text-align:center}.header-actions{align-items:stretch!important;display:flex!important;flex-direction:column!important;flex-wrap:nowrap!important;gap:8px;width:100%}.search-box,.search-box input{width:100%}.header-actions button,.header-actions button[class*=download],.header-actions>.pdf-download-btn,.header-actions>button{flex-shrink:0!important;justify-content:center!important;width:100%!important}.assessments-list,.two-column{grid-template-columns:1fr}.view-toggle{flex-direction:column;width:100%}.view-toggle button{width:100%}.stats-grid{grid-gap:8px;box-sizing:border-box;display:grid;gap:8px;grid-template-columns:1fr 1fr;width:100%}.stat-card{min-width:0;padding:10px}.stat-value{font-size:1.1rem}.stat-label{font-size:.65rem}.assessment-card{box-sizing:border-box;width:100%}}.trial-banner{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:.9rem;justify-content:space-between;padding:12px 20px}.trial-banner.urgent{background:linear-gradient(135deg,#f59e0b,#ef4444)}.trial-banner.expired{background:linear-gradient(135deg,#dc2626,#991b1b)}.trial-banner-content{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.trial-icon{flex-shrink:0}.trial-message{font-weight:500}.trial-cta-btn{background:#fff!important;border-radius:6px;color:#667eea!important;font-size:.85rem;font-weight:600;padding:6px 16px}.trial-banner.urgent .trial-cta-btn{color:#f59e0b!important}.trial-banner.expired .trial-cta-btn{color:#dc2626!important}.trial-cta-btn:hover{opacity:.9}.trial-dismiss{align-items:center;background:#0000;border:none;color:#fff;cursor:pointer;display:flex;justify-content:center;opacity:.8;padding:4px;transition:opacity .2s}.trial-dismiss:hover{opacity:1}@media (max-width:640px){.trial-banner{flex-direction:column;gap:10px;padding:10px 16px}.trial-banner-content{justify-content:center;text-align:center}.trial-dismiss{position:absolute;right:8px;top:8px}.trial-banner{position:relative}}.onboarding-modal{max-height:90vh;max-width:550px!important;overflow-y:auto}.onboarding-title{align-items:center;color:#1f2937;display:flex;font-size:1.5rem;font-weight:700;gap:10px}.welcome-emoji{font-size:1.75rem}.onboarding-subtitle{color:#6b7280;font-size:1rem;margin-top:4px}.onboarding-content{padding:16px 0}.trial-info-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #93c5fd;border-radius:12px;margin-bottom:20px;padding:16px;text-align:center}.trial-badge{align-items:center;display:inline-flex;font-size:.85rem;gap:6px;margin-bottom:10px;padding:6px 14px}.trial-info-card p{color:#1e40af;font-size:.95rem;margin:0}.pilot-badge{background:#fef3c7;border-radius:4px;color:#92400e;display:inline-block;font-size:.75rem;font-weight:600;margin-left:8px;padding:2px 8px}.features-grid{grid-gap:12px;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:20px}.feature-item{background:#f9fafb;border-radius:10px;display:flex;gap:12px;padding:12px;transition:all .2s}.feature-item:hover{background:#f3f4f6}.feature-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.feature-text h4{color:#1f2937;font-size:.9rem;font-weight:600;margin:0 0 4px}.feature-text p{color:#6b7280;font-size:.8rem;line-height:1.3;margin:0}.getting-started{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;margin-bottom:16px;padding:16px}.getting-started h3{color:#166534;font-size:.95rem;font-weight:600;margin:0 0 12px}.getting-started ol{list-style:none;margin:0;padding:0}.getting-started li{align-items:center;color:#166534;display:flex;font-size:.9rem;gap:8px;margin-bottom:6px}.getting-started li svg{color:#22c55e}.getting-started-tip{background:#22c55e1a;border-radius:8px;color:#166534;font-size:.85rem;line-height:1.4;margin-top:12px;padding:10px 12px}.getting-started-tip em{background:#22c55e33;border-radius:4px;font-style:normal;font-weight:500;padding:2px 6px}.pricing-preview{background:#fef3c7;border:1px solid #fcd34d;border-radius:8px;padding:12px 16px;text-align:center}.pricing-preview p{color:#92400e;font-size:.9rem;margin:0}.onboarding-footer{display:flex;gap:12px;justify-content:flex-end;padding-top:8px}.start-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important;display:flex;gap:8px}.start-btn:hover{opacity:.9}@media (max-width:640px){.onboarding-modal{max-width:95vw!important}.onboarding-title{font-size:1.25rem}.features-grid{grid-template-columns:1fr}.onboarding-footer{flex-direction:column-reverse}.onboarding-footer button{justify-content:center;width:100%}}.subscription-prompt-modal{max-width:450px!important}.prompt-title{align-items:center;color:#1f2937;display:flex;font-size:1.4rem;font-weight:700;gap:10px}.prompt-icon{color:#f59e0b}.prompt-subtitle{color:#6b7280;font-size:.95rem;margin-top:4px}.prompt-content{padding:16px 0}.usage-stats{display:flex;gap:40px;justify-content:center;margin-bottom:20px}.stat-number{color:#667eea;font-size:2rem;font-weight:700}.benefits-section{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;margin-bottom:16px;padding:16px}.benefits-section h3{color:#166534;font-size:.95rem;margin:0 0 12px}.benefits-section ul{list-style:none;margin:0;padding:0}.benefits-section li{align-items:center;color:#166534;display:flex;font-size:.9rem;gap:8px;margin-bottom:8px}.benefits-section li svg{color:#22c55e;flex-shrink:0}.price-highlight{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;padding:20px;text-align:center}.price-tag{align-items:baseline;display:flex;gap:4px;justify-content:center}.price-amount{font-size:2.5rem;font-weight:800}.price-period{font-size:1rem;opacity:.9}.price-note{font-size:.9rem;margin:8px 0 0;opacity:.9}.prompt-footer{display:flex;gap:12px;justify-content:flex-end;padding-top:8px}.subscribe-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important;display:flex;gap:8px}.subscribe-btn:hover{opacity:.9}@media (max-width:640px){.subscription-prompt-modal{max-width:95vw!important}.usage-stats{gap:24px}.stat-number{font-size:1.5rem}.prompt-footer{flex-direction:column-reverse}.prompt-footer button{justify-content:center;width:100%}}.growth-score-card{margin-top:24px;padding:24px}.growth-score-header{align-items:flex-start;display:flex;gap:16px;margin-bottom:16px}.growth-score-icon{background:linear-gradient(135deg,#10b981,#059669);border-radius:12px;flex-shrink:0;padding:12px}.growth-score-title{color:#166534;font-size:1.2rem;font-weight:700;margin:0}.tips-challenge-card{display:flex;flex-direction:column;height:100%;min-height:-webkit-fit-content;min-height:fit-content}.parent-dashboard-grid-3col{grid-gap:20px;align-items:stretch;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.weekly-challenge-card{border:none;box-shadow:0 4px 20px #667eea1f;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:0}.challenge-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:18px 20px}.challenge-header-content{align-items:center;display:flex;gap:8px;margin-bottom:10px}.challenge-label{font-size:.7rem;font-weight:600;letter-spacing:1px;opacity:.9;text-transform:uppercase}.challenge-title{font-size:1.1rem;font-weight:700;line-height:1.3;margin:0 0 8px}.challenge-prompt{font-size:.85rem;line-height:1.5;margin:0 0 10px;opacity:.95}.challenge-genre{background:#fff3;border-radius:12px;display:inline-block;font-size:.7rem;padding:4px 10px}.challenge-body{display:flex;flex:1 1;flex-direction:column;gap:16px;padding:16px 20px}.challenge-section-title{color:#374151;font-size:.8rem;font-weight:600;margin-bottom:8px}.prompt-starters{display:flex;flex-wrap:wrap;gap:6px}.prompt-starter-tag{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;color:#166534;font-size:.72rem;padding:5px 10px}.more-ideas{display:flex;flex-direction:column;gap:6px}.idea-item{background:#faf5ff;border-left:3px solid #c084fc;border-radius:6px;color:#6b21a8;font-size:.78rem;line-height:1.4;padding:8px 10px}.challenge-footer{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;color:#6b7280;display:flex;font-size:.78rem;gap:6px;justify-content:center;margin-top:auto;padding:12px 20px;text-align:center}.challenge-footer .footer-icon{flex-shrink:0}.parent-tips-card{border:none;box-shadow:0 4px 20px #f59e0b1f;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:0}.tips-header{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;display:flex;justify-content:space-between;padding:16px 20px}.tips-header-content{align-items:center;display:flex;gap:10px}.tips-title{font-size:1rem;font-weight:700;margin:0}.refresh-tips-btn{color:#fff;height:auto;opacity:.8;padding:4px;transition:opacity .2s}.refresh-tips-btn:hover{background:#ffffff26;opacity:1}.tips-body{display:flex;flex:1 1;flex-direction:column;gap:10px;padding:16px 20px}.tip-item{background:#fefce8;border-left:3px solid #f59e0b;border-radius:8px;padding:12px}.tip-title{color:#854d0e;font-size:.85rem;font-weight:600;margin-bottom:4px}.tip-detail{color:#713f12;font-size:.78rem;line-height:1.5;margin:0}.tips-footer{align-items:center;background:#fef3c7;border-top:1px solid #fde68a;color:#92400e;display:flex;font-size:.78rem;gap:6px;justify-content:center;margin-top:auto;padding:12px 20px;text-align:center}.tips-footer .footer-icon{flex-shrink:0}@media (max-width:1024px){.parent-dashboard-grid-3col{gap:16px;grid-template-columns:1fr}.parent-tips-card,.weekly-challenge-card{max-width:100%}.parent-tips-challenge-row{grid-template-columns:1fr}}.parent-tips-row{margin-top:8px}.parent-tips-card-fullwidth{border:none;box-shadow:0 4px 20px #f59e0b1f;overflow:hidden;padding:0}.tips-header-fullwidth{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;display:flex;justify-content:space-between;padding:16px 24px}.tips-grid-fullwidth{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);padding:20px 24px}.tip-item-fullwidth{background:#fefce8;border-left:4px solid #f59e0b;border-radius:10px;padding:16px}.tip-item-fullwidth .tip-title{color:#854d0e;font-size:.9rem;font-weight:600;margin-bottom:6px}.tip-item-fullwidth .tip-detail{color:#713f12;font-size:.82rem;line-height:1.5;margin:0}.tips-footer-fullwidth{align-items:center;background:#fef3c7;border-top:1px solid #fde68a;color:#92400e;display:flex;font-size:.85rem;gap:8px;justify-content:center;padding:14px 24px;text-align:center}@media (max-width:1024px){.tips-grid-fullwidth{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.tips-grid-fullwidth{gap:12px;grid-template-columns:1fr;padding:16px}.tips-header-fullwidth{padding:14px 16px}.tips-footer-fullwidth{padding:12px 16px}}.add-child-placeholder{align-items:center;background:linear-gradient(135deg,#fafafa,#f5f5f5);border:2px dashed #d1d5db;cursor:pointer;display:flex;justify-content:center;min-height:280px;padding:0;transition:all .3s ease}.add-child-placeholder:hover{background:linear-gradient(135deg,#f0f4ff,#e8ecff);border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-2px)}.add-child-placeholder-content{padding:32px 24px;text-align:center}.add-child-placeholder-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;height:64px;justify-content:center;margin:0 auto 16px;transition:transform .3s ease;width:64px}.add-child-placeholder:hover .add-child-placeholder-icon{transform:scale(1.1)}.add-child-placeholder-content h3{color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 8px}.add-child-placeholder-content p{color:#6b7280;font-size:.85rem;line-height:1.4;margin:0}@media (max-width:768px){.add-child-placeholder{min-height:200px}.add-child-placeholder-icon{height:52px;width:52px}.add-child-placeholder-content{padding:24px 20px}.challenge-header{padding:16px}.challenge-body,.tips-body,.tips-header{padding:14px 16px}}@media (max-width:480px){.growth-score-header{align-items:center;flex-direction:column;text-align:center}.growth-score-card{padding:20px 16px}.growth-score-card p{text-align:center}.tips-challenge-card{margin-top:16px}}.dashboard-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.dashboard-loading{align-items:center;color:#718096;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.dashboard-header{align-items:center;display:flex;justify-content:space-between;margin:0 auto 12px;max-width:1400px}.dashboard-content{margin:0 auto;max-width:1400px}.dashboard-title-section{margin-bottom:20px}.dashboard-title{color:#1a1a2e;font-size:2.5rem;font-weight:700;margin-bottom:4px}.dashboard-subtitle{color:#718096;font-size:1.125rem}.dashboard-tabs{border-bottom:2px solid #e2e8f0;display:flex;gap:8px;padding:16px 24px 0}.tab-button{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#718096;cursor:pointer;display:flex;font-size:15px;font-weight:500;gap:8px;margin-bottom:-2px;padding:12px 20px;transition:all .2s}.tab-button:hover{background:#f7fafc;border-radius:8px 8px 0 0;color:#4a5568}.tab-button.active{border-bottom-color:#667eea;color:#667eea;font-weight:600}.tab-button svg{transition:transform .2s}.tab-button.active svg{transform:scale(1.1)}.trial-alert{align-items:center;border-radius:12px;display:flex;gap:16px;margin-bottom:24px;padding:20px}.alert-error{background:#ef44441a;border-left:4px solid #ef4444;color:#dc2626}.alert-warning{background:#f59e0b1a;border-left:4px solid #f59e0b;color:#d97706}.trial-alert h3{font-size:1.125rem;font-weight:600;margin:0}.trial-alert p{font-size:.938rem;margin:4px 0 0}.dashboard-grid{grid-gap:24px;align-items:start;gap:24px;grid-template-columns:400px 1fr}.dashboard-layout-centered{align-items:center;display:flex;flex-direction:column;gap:24px;width:100%}.classes-section.centered{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;max-width:900px;padding:24px;width:100%}.classes-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.classes-grid .class-item{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:2px solid #0000;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:all .2s ease}.classes-grid .class-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.classes-grid .class-item.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000}.classes-grid .class-item.active .class-info h3,.classes-grid .class-item.active .year-badge{color:#fff}.classes-grid .class-item .class-info h3{color:#2d3748;font-size:1rem;font-weight:600;margin:0 0 4px}.classes-grid .class-item .year-badge{background:#667eea1a;border-radius:4px;color:#667eea;font-size:.75rem;padding:2px 8px}.classes-grid .class-item.active .year-badge{background:#fff3}.students-section.centered{max-width:1400px;width:100%}.classes-section,.students-section,.students-section.centered{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:16px;padding:24px}.section-header{border-bottom:2px solid #667eea1a;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.section-header,.section-title{align-items:center;display:flex}.section-title{color:#2d3748;gap:12px}.section-title h2{font-size:1.5rem;font-weight:600;margin:0}.section-actions{display:flex;gap:8px}.empty-state{color:#718096;padding:40px 20px}.classes-list{display:flex;flex-direction:column;gap:12px}.class-item{align-items:center;background:#667eea0d;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:all .2s}.class-item:hover{background:#667eea1a;transform:translateX(4px)}.class-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.class-item.active .class-info h3{color:#fff}.class-item.active .year-badge{background:#fff3;color:#fff}.class-info h3{font-size:1.125rem;font-weight:600;margin:0 0 4px}.year-badge{background:#667eea1a;border-radius:8px;color:#667eea;font-size:.75rem;font-weight:600}.students-table{overflow-x:auto}.students-table table{border-collapse:collapse;width:100%}.students-table thead{background:#667eea1a}.students-table td,.students-table th{padding:16px}.students-table th{color:#2d3748;font-size:.938rem}.students-table td{border-bottom:1px solid #667eea0d;color:#4a5568}.students-table tbody tr:hover{background:#667eea08}.level-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;font-size:.813rem;font-weight:600;padding:6px 12px;white-space:nowrap}.no-data{color:#cbd5e0;font-style:italic}.date-text{color:#4a5568;font-size:.875rem}.reports-cell{display:flex;flex-direction:column;gap:6px}.pdf-link{align-items:center;background:#667eea1a;border-radius:6px;color:#667eea;display:inline-flex;font-size:.813rem;font-weight:500;gap:6px;padding:6px 12px;text-decoration:none;transition:all .2s;white-space:nowrap}.pdf-link:hover{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;transform:translateX(2px)}.dialog-form{display:flex;flex-direction:column;gap:20px;margin:20px 0}.feedback-textarea{border:1px solid #e2e8f0;padding:12px}.star-button{transition:color .2s}.star-button.active,.star-button:hover{color:#fbbf24}.student-name-link{background:none;border:none;color:#667eea;cursor:pointer;font-weight:500;padding:0;text-align:left;text-decoration:underline;transition:color .2s}.student-name-link:hover{color:#764ba2}.assessment-details-dialog{max-height:80vh;max-width:700px;overflow-y:auto}.assessments-list{display:flex;flex-direction:column;gap:16px;margin:20px 0;max-height:500px;overflow-y:auto;padding-right:8px}.assessment-card{border:1px solid #667eea33;padding:20px}.assessment-header{align-items:start;border-bottom:1px solid #667eea1a;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.assessment-title{color:#2d3748;font-size:1.125rem;font-weight:600;margin:0}.assessment-date{color:#718096;font-size:.813rem;margin:4px 0 0}.assessment-details{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.detail-section h5{color:#2d3748;font-size:.938rem;font-weight:600;margin:0 0 8px}.detail-section ul{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.detail-section li{color:#4a5568;font-size:.875rem;padding-left:20px;position:relative}.detail-section li:before{color:#667eea;content:"•";left:8px;position:absolute}.rubric-grid-small{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(2,1fr)}.rubric-item-small{align-items:center;background:#667eea0d;border-radius:6px;display:flex;font-size:.813rem;justify-content:space-between;padding:8px 12px}.rubric-item-small span:first-child{color:#4a5568;text-transform:capitalize}.rubric-item-small .score{color:#667eea;font-weight:600}.assessment-actions{border-top:1px solid #667eea1a;display:flex;gap:12px;justify-content:flex-end;padding-top:12px}.download-report-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:inline-flex;font-size:.875rem;font-weight:500;gap:8px;padding:10px 20px;text-decoration:none;transition:all .2s}.download-report-btn:hover{box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.delete-assessment-btn{align-items:center;background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s}.delete-assessment-btn:hover{background:#dc2626;box-shadow:0 4px 12px #ef44444d;transform:translateY(-2px)}@media (max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.dashboard-layout-centered{padding:0 16px}.classes-section.centered,.students-section.centered{max-width:100%}}@media (max-width:768px){.dashboard-container{overflow-x:hidden;padding:16px}.dashboard-title{font-size:1.75rem}.dashboard-subtitle,.dashboard-title,.dashboard-title-section{text-align:center}.dashboard-header{align-items:center;flex-direction:column;gap:16px;text-align:center}.header-actions{justify-content:center;width:100%}.section-title{flex-wrap:wrap;justify-content:center;text-align:center}.section-title h2{text-align:center;width:100%}.section-actions{justify-content:center;width:100%}.classes-section,.students-section{box-sizing:border-box;text-align:center;width:100%}.classes-list{align-items:center}.classes-grid{grid-template-columns:1fr}.class-item{box-sizing:border-box;margin:0 auto;max-width:100%;width:100%}.dashboard-grid{display:flex;flex-direction:column;gap:16px;width:100%}.dashboard-tabs{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;display:flex;justify-content:flex-start;overflow-x:auto;padding:12px 8px 0;scrollbar-width:none}.dashboard-tabs::-webkit-scrollbar{display:none}.tab-button{flex-shrink:0;font-size:12px;padding:8px 10px;white-space:nowrap}.section-header{align-items:center;flex-direction:column;gap:12px;text-align:center}.students-section{box-sizing:border-box;padding:16px;width:100%}.students-section .section-header{align-items:center}.students-section .section-actions,.students-section .section-title{justify-content:center;width:100%}.students-table{font-size:.75rem;overflow-x:auto;width:100%}.rubric-grid-small{grid-template-columns:1fr}.empty-class-message{padding:40px 20px;text-align:center}.empty-class-message h3,.empty-class-message p{text-align:center}.dashboard-content{box-sizing:border-box;padding:0;width:100%}}.dashboard-container.theme-sample2{background:linear-gradient(135deg,#e8f4f8,#f0f4f8 50%,#e8eef5)}.dashboard-container.theme-sample2 .dashboard-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#1e40af);-webkit-background-clip:text;background-clip:text}.dashboard-container.theme-sample2 .classes-section,.dashboard-container.theme-sample2 .students-section{background:#fffffffa;border:1px solid #3b82f626;box-shadow:0 4px 20px #3b82f614}.dashboard-container.theme-sample2 .class-item{border-left:4px solid #3b82f6}.dashboard-container.theme-sample2 .class-item:hover{background:linear-gradient(90deg,#3b82f614,#0000)}.dashboard-container.theme-sample2 .class-item.active{background:linear-gradient(90deg,#3b82f61f,#3b82f60d);border-left-color:#1e40af}.dashboard-container.theme-sample4{background:linear-gradient(135deg,#fef5f0,#fff0f5 50%,#fef5f8)}.dashboard-container.theme-sample4 .dashboard-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ec4899,#db2777);-webkit-background-clip:text;background-clip:text}.dashboard-container.theme-sample4 .classes-section,.dashboard-container.theme-sample4 .students-section{background:#fffffffa;border:1px solid #ec489926;box-shadow:0 4px 20px #ec489914}.dashboard-container.theme-sample4 .class-item{border-left:4px solid #ec4899}.dashboard-container.theme-sample4 .class-item:hover{background:linear-gradient(90deg,#ec489914,#0000)}.dashboard-container.theme-sample4 .class-item.active{background:linear-gradient(90deg,#ec48991f,#ec48990d);border-left-color:#db2777}.analytics-tab-content{padding:20px}.analytics-redirect{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px;display:flex;flex-direction:column;margin-top:20px;padding:40px 20px;text-align:center}.analytics-info{max-width:500px}.analytics-info .analytics-icon{color:#3b82f6;margin-bottom:16px}.analytics-info h3{color:#1e3a5f;font-size:1.5rem;margin:0 0 12px}.analytics-info p{color:#64748b;margin-bottom:16px}.analytics-info ul{list-style:none;margin:0 0 24px;padding:0;text-align:left}.analytics-info ul li{border-bottom:1px solid #e2e8f0;color:#475569;padding:8px 0}.analytics-info ul li:last-child{border-bottom:none}.view-analytics-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:8px;color:#fff;display:flex;font-size:1rem;gap:8px;padding:12px 24px;transition:all .2s ease}.view-analytics-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-2px)}.student-preview-dialog{max-height:80vh;max-width:600px!important}.student-preview-list{max-height:400px;overflow-y:auto;padding-right:8px}.class-group{margin-bottom:20px}.class-group:last-child{margin-bottom:0}.class-group-title{border-bottom:1px solid #e2e8f0;color:#64748b;font-size:.875rem;font-weight:600;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;text-transform:uppercase}.student-grid{display:flex;flex-direction:column;gap:8px}.student-preview-btn{align-items:center;background:#f8fafc;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.student-preview-btn:hover{background:#f1f5f9;border-color:#667eea;transform:translateX(4px)}.student-preview-btn .student-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:600;height:40px;justify-content:center;width:40px}.student-preview-btn .student-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.student-preview-btn .student-name{color:#1e293b;font-size:.95rem;font-weight:600}.student-preview-btn .student-username{color:#64748b;font-size:.8rem}.student-preview-btn .preview-icon{color:#94a3b8;transition:all .2s ease}.student-preview-btn:hover .preview-icon{color:#667eea}.analytics-container{background:linear-gradient(135deg,#f0fdf4,#ecfdf5 50%,#f0f9ff);min-height:100vh;padding:24px}.analytics-loading{align-items:center;color:#718096;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.analytics-loading .spinner{animation:spin 1s linear infinite}.analytics-header{align-items:center;display:flex;justify-content:space-between;margin:0 auto 24px;max-width:1400px}.header-actions{align-items:center;display:flex;gap:12px}.time-range-select{width:160px}.analytics-content{margin:0 auto;max-width:1400px}.analytics-title-section{margin-bottom:32px;text-align:center}.analytics-title{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,#10b981,#3b82f6);-webkit-background-clip:text;background-clip:text;display:flex;font-size:2.5rem;font-weight:700;gap:12px;justify-content:center;margin-bottom:8px}.analytics-title svg{color:#10b981}.analytics-subtitle{color:#4b5563;font-size:1.25rem}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:32px}.stat-card{box-shadow:0 4px 6px -1px #0000001a;padding:24px}.stat-icon{border-radius:14px;height:56px;width:56px}.stat-icon.students{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-icon.assessed{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.assessments{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-icon.revisions{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-value{line-height:1.2}.charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.chart-card{box-shadow:0 4px 6px -1px #0000001a}.chart-card.full-width{grid-column:1/-1}.chart-title{font-size:1.25rem}.performance-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.performance-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:24px}.performance-card.top{border-top:4px solid #f59e0b}.performance-card.support{border-top:4px solid #ef4444}.performance-header{align-items:center;display:flex;gap:12px;margin-bottom:8px}.performance-header h3{color:#1f2937;font-size:1.2rem;font-weight:600}.icon-gold{color:#f59e0b}.icon-amber{color:#ef4444}.performance-description{color:#6b7280;font-size:.875rem;margin-bottom:20px}.student-list{display:flex;flex-direction:column;gap:12px}.student-item{align-items:center;background:#f9fafb;border-radius:12px;display:flex;gap:12px;padding:12px 16px;transition:all .2s}.student-item:hover{background:#f3f4f6}.rank-badge{align-items:center;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:32px;justify-content:center;width:32px}.student-details{flex:1 1}.student-name{color:#1f2937;display:block;font-weight:600;margin-bottom:4px}.student-stats{align-items:center;display:flex;gap:8px}.phase-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;font-weight:600}.no-assessment-badge,.phase-badge{border-radius:12px;font-size:.75rem;padding:2px 10px}.no-assessment-badge{background:#e5e7eb;color:#6b7280}.assessment-count{color:#6b7280;font-size:.85rem}.empty-performance{color:#9ca3af;padding:24px;text-align:center}.all-students-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:24px}.students-table-container{overflow-x:auto}.students-table{border-collapse:collapse;width:100%}.students-table td,.students-table th{border-bottom:1px solid #e5e7eb;padding:12px 16px;text-align:left}.students-table th{background:#f9fafb;color:#374151;font-size:.875rem;font-weight:600}.students-table tr:hover{background:#f9fafb}.rank-cell{color:#6b7280;font-weight:700}.name-cell{color:#1f2937;font-weight:600}.phase-badge-small{background:linear-gradient(135deg,#3b82f6,#2563eb);font-size:.75rem}.na-badge{color:#9ca3af;font-size:.875rem}.growth-stars{font-size:.9rem}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-grid,.performance-grid{grid-template-columns:1fr}.analytics-tabs{flex-wrap:wrap}}@media (max-width:640px){.analytics-container{padding:16px}.stats-grid{grid-template-columns:1fr}.analytics-title{font-size:1.75rem}.stat-card{padding:16px}.stat-value{font-size:1.5rem}.analytics-header{align-items:flex-start;flex-direction:column;gap:16px}.header-actions{justify-content:space-between;width:100%}}.analytics-tabs{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;gap:8px;margin-bottom:24px;padding:4px}.tab-btn{background:#0000;border:none;border-radius:8px;color:#6b7280;cursor:pointer;font-size:.95rem;font-weight:500;padding:12px 24px;transition:all .2s}.tab-btn:hover{background:#f3f4f6;color:#374151}.tab-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.class-averages-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:24px;padding:24px}.averages-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr)}.average-item{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;padding:20px;text-align:center}.average-label{color:#6b7280;display:block;font-size:.85rem;margin-bottom:8px}.average-value{color:#1f2937;display:block;font-size:2rem;font-weight:700}.performance-summary-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.performance-summary-card{align-items:center;border-radius:16px;display:flex;gap:20px;padding:24px}.performance-summary-card.above{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #a7f3d0}.performance-summary-card.below{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fcd34d}.summary-icon{align-items:center;border-radius:16px;display:flex;height:60px;justify-content:center;width:60px}.performance-summary-card.above .summary-icon{background:#10b981;color:#fff}.performance-summary-card.below .summary-icon{background:#f59e0b;color:#fff}.summary-info{display:flex;flex-direction:column}.summary-value{color:#1f2937;font-size:2.5rem;font-weight:700}.summary-label{color:#6b7280;font-size:1rem}.rankings-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;margin-bottom:24px;padding:24px}.rankings-table-container{overflow-x:auto}.rankings-table{border-collapse:collapse;width:100%}.rankings-table td,.rankings-table th{border-bottom:1px solid #e5e7eb;padding:12px 16px;text-align:left}.rankings-table th{background:#f9fafb;color:#374151;font-size:.85rem;font-weight:600}.rankings-table tr:hover{background:#f9fafb}.diff-cell{align-items:center;display:flex;font-weight:600;gap:4px}.diff-cell.positive{color:#10b981}.diff-cell.negative{color:#ef4444}.rubric-averages-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:24px}.rubric-averages-grid{display:flex;flex-direction:column;gap:16px}.rubric-avg-item{align-items:center;display:flex;gap:16px}.rubric-avg-item .rubric-name{color:#4b5563;font-size:.9rem;width:180px}.rubric-bar{background:#e5e7eb;border-radius:12px;flex:1 1;height:24px;overflow:hidden}.rubric-fill{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:12px;height:100%;transition:width .5s ease}.rubric-avg-item .rubric-value{color:#1f2937;font-weight:600;text-align:right;width:50px}.student-list-card{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a;padding:24px}.section-description{color:#6b7280;font-size:.9rem;margin-bottom:20px}.student-progress-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.student-progress-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:16px 20px;transition:all .2s}.student-progress-item:hover{background:#fff;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateY(-2px)}.student-progress-info{display:flex;flex-direction:column;gap:4px}.student-progress-name{color:#1f2937;font-size:1rem;font-weight:600}.student-progress-stats{align-items:center;display:flex;gap:8px}.growth-mini{font-size:.85rem}.student-progress-meta{color:#9ca3af;font-size:.8rem}.chevron-icon{color:#9ca3af;transition:transform .2s}.student-progress-item:hover .chevron-icon{color:#3b82f6;transform:translateX(4px)}@media (max-width:1024px){.averages-grid{grid-template-columns:repeat(2,1fr)}.student-progress-grid{grid-template-columns:1fr}}@media (max-width:640px){.averages-grid,.performance-summary-grid{grid-template-columns:1fr}.rubric-avg-item .rubric-name{font-size:.8rem;width:100px}}.summary-report-content{display:flex;flex-direction:column;gap:16px}.summary-header{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:12px;color:#fff;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;padding:16px}.summary-header-left h2{font-size:1.5rem;font-weight:700;margin:0}.summary-header-left p{font-size:.9rem;margin:4px 0 0;opacity:.9}.summary-header-actions{align-items:center;display:flex;gap:8px}.summary-header-actions .comparison-select{background:#fff;color:#1e3a5f;min-width:150px}.summary-header-actions button{align-items:center;display:flex;gap:6px}.summary-section{border-radius:12px;padding:20px}.summary-section h3{color:#1e3a5f;font-size:1.1rem;font-weight:600;margin:0 0 16px}.summary-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(6,1fr)}.summary-stat{align-items:center;background:#f8fafc;border-radius:8px;display:flex;flex-direction:column;padding:16px}.summary-stat .stat-number{color:#3b82f6;font-size:1.8rem;font-weight:700}.summary-stat .stat-label{color:#64748b;font-size:.85rem;margin-top:4px;text-align:center}.summary-distributions{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.phase-bars{display:flex;flex-direction:column;gap:10px}.phase-bar-item{align-items:center;display:flex;gap:12px}.phase-label{font-size:.9rem;font-weight:500;width:70px}.phase-bar-container{background:#e2e8f0;border-radius:4px;flex:1 1;height:24px;overflow:hidden}.phase-bar-fill{border-radius:4px;height:100%;transition:width .5s ease}.phase-count{font-weight:600;text-align:right;width:30px}.rubric-list{display:flex;flex-direction:column;gap:8px}.rubric-item{align-items:center;border-radius:6px;display:flex;gap:10px;padding:8px}.rubric-item.lowest{background:#fef3c7}.rubric-label{font-size:.85rem;text-transform:capitalize;width:140px}.rubric-bar-container{background:#e2e8f0;border-radius:4px;flex:1 1;height:16px;overflow:hidden}.rubric-bar-fill{background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:4px;height:100%}.rubric-score{font-size:.85rem;font-weight:500;text-align:right;width:60px}.historical-section{background:#f0f9ff}.comparison-stats{display:flex;flex-wrap:wrap;gap:40px}.comparison-item{flex:1 1;min-width:200px}.comparison-label{color:#64748b;display:block;font-size:.85rem;margin-bottom:8px}.comparison-values{align-items:center;display:flex;font-size:1.1rem;gap:8px}.old-value{color:#9ca3af}.arrow{color:#64748b}.new-value{color:#1e3a5f;font-weight:600}.change{border-radius:4px;font-size:.85rem;font-weight:500;padding:2px 8px}.change.positive{background:#dcfce7;color:#15803d}.change.negative{background:#fee2e2;color:#dc2626}.next-steps-list{display:flex;flex-direction:column;gap:12px}.step-item{background:#f8fafc;border-radius:8px;display:flex;gap:12px;padding:12px}.step-item.priority-high{background:#fef2f2;border-left:4px solid #ef4444}.step-item.priority-medium{background:#fefce8;border-left:4px solid #f59e0b}.step-priority{font-size:1.2rem}.step-content strong{color:#1e3a5f;display:block;margin-bottom:4px}.step-content p{color:#64748b;font-size:.9rem;margin:0}.groupings-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.grouping-card{background:#f8fafc;border-radius:10px;padding:16px}.grouping-card.extension{background:#ecfdf5;border:1px solid #10b981}.grouping-card.on-track{background:#eff6ff;border:1px solid #3b82f6}.grouping-card.support{background:#fffbeb;border:1px solid #f59e0b}.grouping-header{align-items:center;display:flex;font-weight:600;gap:8px;margin-bottom:12px}.grouping-card.extension .grouping-header{color:#059669}.grouping-card.on-track .grouping-header{color:#2563eb}.grouping-card.support .grouping-header{color:#d97706}.grouping-students{display:flex;flex-wrap:wrap;gap:8px}.student-chip{align-items:center;background:#fff;border-radius:20px;box-shadow:0 1px 2px #0000001a;display:flex;font-size:.85rem;gap:4px;padding:6px 10px}.view-details-btn{height:auto;padding:2px}.student-count{color:#64748b;font-size:1.2rem;font-weight:600}.no-students{color:#9ca3af;font-size:.9rem;font-style:italic}.goals-list{display:flex;flex-direction:column;gap:16px}.goal-item{background:#f8fafc;border-radius:8px;padding:16px}.goal-header{gap:8px;margin-bottom:10px}.goal-header svg{color:#3b82f6}.goal-text{color:#1e3a5f;font-weight:500}.goal-progress{align-items:center;display:flex;gap:12px;margin-bottom:6px}.progress-bar-container{background:#e2e8f0;border-radius:5px;flex:1 1;height:10px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:5px;height:100%;transition:width .5s ease}.progress-percent{color:#3b82f6;font-weight:600;min-width:45px}.goal-current{color:#64748b;font-size:.85rem}.practice-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}.practice-stat{align-items:center;background:#f8fafc;border-radius:8px;display:flex;flex-direction:column;padding:16px;text-align:center}.practice-stat svg{color:#64748b;margin-bottom:8px}.practice-number{color:#1e3a5f;font-size:1.4rem;font-weight:700;margin-bottom:4px}.practice-label{color:#64748b;font-size:.8rem}.practice-stat.highlight-good{background:#ecfdf5}.practice-stat.highlight-good svg{color:#10b981}.practice-stat.highlight-low{background:#fef3c7}.practice-stat.highlight-low svg{color:#f59e0b}.student-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.student-modal{background:#fff;border-radius:16px;box-shadow:0 20px 40px #0003;max-height:80vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px;position:-webkit-sticky;position:sticky;top:0}.modal-header h3{color:#1e3a5f;margin:0}.modal-content{padding:20px}.modal-content h4{color:#64748b;font-size:.9rem;margin:20px 0 10px;text-transform:uppercase}.detail-row{border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:10px 0}.detail-label{color:#64748b;font-size:.9rem}.detail-value{color:#1e3a5f;font-weight:500}.detail-value.strengths{color:#10b981}.detail-value.weaknesses{color:#f59e0b}.summary-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px;text-align:center}.summary-empty p{color:#64748b;margin-bottom:16px}@media (max-width:1024px){.summary-stats-grid{grid-template-columns:repeat(3,1fr)}.groupings-grid,.summary-distributions{grid-template-columns:1fr}.practice-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.summary-header{align-items:flex-start;flex-direction:column}.summary-header-actions{flex-wrap:wrap;width:100%}.summary-stats-grid{grid-template-columns:repeat(2,1fr)}.comparison-stats{flex-direction:column;gap:20px}}@media (max-width:480px){.summary-stats-grid{grid-template-columns:1fr 1fr}.practice-stats{grid-template-columns:1fr}}.rankings-section{margin-bottom:16px}.rankings-section .section-subtitle{color:#64748b;font-size:.9rem;margin:-8px 0 16px}.rankings-legend{background:#f8fafc;border-radius:8px;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:16px;padding:12px}.rankings-legend .legend-item{align-items:center;color:#475569;display:flex;font-size:.85rem;gap:6px}.legend-dot{border-radius:50%;height:12px;width:12px}.legend-dot.exceeding{background-color:#22c55e}.legend-dot.proficient{background-color:#3b82f6}.legend-dot.consolidating{background-color:#f59e0b}.legend-dot.developing{background-color:#f97316}.legend-dot.emerging{background-color:#ef4444}.rankings-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.ranking-row{align-items:center;background:#f8fafc;border-radius:8px;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.ranking-row:hover{background:#f1f5f9;transform:translateX(4px)}.ranking-position{color:#3b82f6;font-size:1.1rem;font-weight:700;min-width:36px}.ranking-info{flex:1 1}.ranking-name{color:#1e3a5f;font-weight:500}.ranking-badges{align-items:center;display:flex;gap:8px}.ranking-badges .phase-badge{background:#e0e7ff;color:#4338ca}.ranking-badges .phase-badge,.ranking-badges .status-badge{border-radius:12px;font-size:.8rem;font-weight:500;padding:4px 10px}.ranking-badges .status-badge{color:#fff}.status-badge.exceeding{background-color:#22c55e}.status-badge.proficient{background-color:#3b82f6}.status-badge.consolidating{background-color:#f59e0b}.status-badge.developing{background-color:#f97316}.status-badge.emerging{background-color:#ef4444}.status-badge.no-assessment,.status-badge.none{background-color:#9ca3af}.empty-rankings{color:#64748b;padding:40px;text-align:center}@media (max-width:640px){.ranking-row{flex-wrap:wrap}.ranking-badges{margin-top:8px;width:100%}.rankings-legend{gap:8px}.rankings-legend .legend-item{font-size:.75rem}}.rankings-toggle-btn{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:8px;color:#1e3a5f;display:flex;font-size:1.1rem;font-weight:600;gap:12px;justify-content:flex-start;padding:16px 20px;transition:all .2s ease;width:100%}.rankings-toggle-btn:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.rankings-toggle-btn svg:first-child{color:#f59e0b}.rankings-toggle-btn svg:last-child{color:#64748b;margin-left:auto}.student-count-badge{background:#3b82f6;border-radius:20px;color:#fff;font-size:.8rem;font-weight:500;padding:4px 12px}.rankings-content{animation:slideDown .3s ease;border-top:1px solid #e2e8f0;margin-top:16px;padding-top:16px}.rankings-content .section-subtitle{color:#64748b;font-size:.9rem;margin-bottom:12px}.phase-badge.no-phase{background:#e2e8f0;color:#64748b}.student-progress-container{background:linear-gradient(135deg,#eff6ff,#f5f3ff 50%,#fdf4ff);min-height:100vh;padding:24px}.progress-error,.progress-loading{align-items:center;color:#718096;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.progress-loading .spinner{animation:spin 1s linear infinite}.progress-header{align-items:center;display:flex;justify-content:space-between;margin:0 auto 24px;max-width:1400px}.progress-content{margin:0 auto;max-width:1400px}.student-header-card{align-items:center;background:#fff;border-radius:20px;box-shadow:0 4px 6px -1px #0000001a;display:flex;gap:24px;margin-bottom:24px;padding:32px}.student-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;height:80px;justify-content:center;width:80px}.student-info{flex:1 1}.student-info h1{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:4px}.student-info .class-name{color:#6b7280;font-size:1rem;margin-bottom:8px}.year-badge{background:#e5e7eb;border-radius:12px;color:#374151;font-size:.85rem;font-weight:500;padding:4px 12px}.current-status{display:flex;gap:32px}.status-item{align-items:center;display:flex;flex-direction:column;gap:8px}.status-label{color:#6b7280;font-size:.85rem;font-weight:600;text-transform:uppercase}.phase-badge-large{border-radius:16px;color:#fff;font-size:1.1rem;font-weight:700;padding:8px 20px}.growth-stars-large{font-size:1.5rem}.summary-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(5,1fr);margin-bottom:24px}.stat-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 2px 4px #0000000d;display:flex;gap:16px;padding:20px}.stat-icon{border-radius:12px;height:50px;width:50px}.stat-icon.assessments{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-icon.teacher{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.stat-icon.practice{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon.revisions{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.phase-change{background:linear-gradient(135deg,#ec4899,#db2777)}.stat-value{color:#1f2937;font-size:1.75rem}.stat-label{color:#6b7280}.trend-up{color:#10b981}.trend-down{color:#ef4444}.trend-neutral{color:#6b7280}.charts-row{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.chart-card{box-shadow:0 2px 4px #0000000d;padding:24px}.chart-title{color:#1f2937;font-size:1.2rem;font-weight:600;margin-bottom:4px}.chart-description{color:#6b7280;font-size:.9rem;margin-bottom:20px}.chart-container{width:100%}.chart-container.large{margin-top:16px}.no-data{align-items:center;color:#9ca3af;display:flex;flex-direction:column;font-size:.95rem;gap:8px;height:200px;justify-content:center}.no-data-icon{font-size:3rem;margin-bottom:8px}.no-data-hint{color:#c4c4c4;font-size:.85rem}.growth-progress-card{background:#fff;border:1px solid #d1fae5;border-radius:16px;box-shadow:0 2px 4px #0000000d;margin-bottom:24px;padding:24px}.growth-tooltip{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 12px #00000026;padding:12px 16px}.growth-tooltip .tooltip-date{color:#374151;font-size:.9rem;font-weight:600;margin-bottom:8px}.growth-tooltip .tooltip-score{align-items:center;display:flex;gap:8px;margin-bottom:4px}.growth-tooltip .tooltip-stars{font-size:1rem}.growth-tooltip .tooltip-label{color:#10b981;font-size:.85rem;font-weight:600}.growth-tooltip .tooltip-revisions{color:#6b7280;font-size:.8rem}.growth-legend{border-top:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:20px;padding-top:16px}.growth-legend .legend-item{align-items:center;color:#6b7280;display:flex;font-size:.8rem;gap:6px}.growth-legend .legend-star{font-size:.9rem}.rubric-breakdown-card{margin-bottom:24px}.assessment-history-card,.rubric-breakdown-card{background:#fff;border-radius:16px;box-shadow:0 2px 4px #0000000d;padding:24px}.section-title{color:#1f2937;font-size:1.25rem;font-weight:600;margin-bottom:20px}.assessment-list{gap:12px}.assessment-item{border:1px solid #e5e7eb;overflow:hidden;transition:all .2s}.assessment-item:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.assessment-item.teacher_assessment{border-left:4px solid #8b5cf6}.assessment-item.student_practice{border-left:4px solid #f59e0b}.assessment-header{align-items:center;background:#f9fafb;cursor:pointer;display:flex;gap:16px;padding:16px}.assessment-header:hover{background:#f3f4f6}.assessment-date{align-items:center;color:#4b5563;display:flex;font-weight:500;gap:8px;min-width:120px}.assessment-type-badge{background:#e5e7eb;font-weight:500}.assessment-type-badge,.phase-badge-small{border-radius:12px;font-size:.8rem;padding:4px 12px}.phase-badge-small{color:#fff;font-weight:600}.growth-mini{font-size:.9rem}.score-badge{background:#ecfdf5;border-radius:8px;color:#059669;font-size:.85rem;font-weight:600;padding:4px 10px}.expand-btn{background:none;border:none;color:#6b7280;cursor:pointer;margin-left:auto;padding:4px}.expand-btn:hover{color:#3b82f6}.assessment-details{background:#fff;border-top:1px solid #e5e7eb;padding:20px}.detail-row{margin-bottom:12px}.detail-label{color:#374151;font-weight:600;margin-right:8px}.detail-value{color:#4b5563}.rubric-mini-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);margin:16px 0}.rubric-mini-item{background:#f3f4f6;border-radius:8px;display:flex;justify-content:space-between;padding:8px 12px}.rubric-name{color:#4b5563;font-size:.8rem}.rubric-score{color:#1f2937;font-weight:600}.feedback-section{border-radius:8px;margin:16px 0;padding:12px}.feedback-section.strengths{background:#ecfdf5;border:1px solid #a7f3d0}.feedback-section.improvements{background:#fef3c7;border:1px solid #fde68a}.feedback-section h5{align-items:center;display:flex;font-size:.9rem;gap:8px;margin-bottom:8px}.feedback-section.strengths h5{color:#059669}.feedback-section.improvements h5{color:#d97706}.feedback-section ul{color:#4b5563;font-size:.9rem;list-style:disc;margin-left:20px}.reflection-section{background:#faf5ff;border:1px solid #e9d5ff;border-radius:8px;margin:16px 0;padding:12px}.reflection-section h5{color:#7c3aed;margin-bottom:8px}.reflection-section p{color:#4b5563;font-size:.9rem;margin:4px 0}.revision-info{align-items:center;color:#10b981;display:flex;font-size:.9rem;font-weight:500;gap:8px;margin-top:12px}.no-assessments{color:#9ca3af;padding:48px;text-align:center}.no-assessments svg{margin-bottom:16px}@media (max-width:1024px){.summary-stats{grid-template-columns:repeat(3,1fr)}.charts-row{grid-template-columns:1fr}.current-status{flex-direction:column;gap:16px}}@media (max-width:768px){.student-progress-container{padding:16px}.student-header-card{flex-direction:column;padding:24px;text-align:center}.rubric-mini-grid,.summary-stats{grid-template-columns:repeat(2,1fr)}.assessment-header{flex-wrap:wrap;gap:8px}}@media (max-width:480px){.rubric-mini-grid,.summary-stats{grid-template-columns:1fr}}.faqs-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.faqs-content{margin:0 auto;max-width:900px}.faqs-header{margin-bottom:48px;text-align:center}.faqs-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:16px}.faqs-header p{color:#718096;font-size:1.125rem}.faqs-list{display:flex;flex-direction:column;gap:16px;margin-bottom:48px}.faq-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:12px;overflow:hidden;transition:all .3s}.faq-item:hover{border-color:#667eea;box-shadow:0 4px 20px #667eea1a}.faq-item.open{border-color:#667eea;box-shadow:0 4px 20px #667eea26}.faq-question{align-items:center;background:none;border:none;color:#2d3748;cursor:pointer;display:flex;font-size:1.125rem;font-weight:600;justify-content:space-between;padding:20px 24px;text-align:left;transition:color .2s;width:100%}.faq-question:hover{color:#667eea}.faq-question span{flex:1 1;padding-right:16px}.faq-answer{animation:slideDown .3s ease-out;padding:0 24px 24px}.faq-answer p{color:#4a5568;font-size:1rem;line-height:1.7;margin:0}.faqs-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;padding:40px 24px;text-align:center}.faqs-footer p{color:#2d3748;font-size:1.25rem;font-weight:600;margin-bottom:20px}@media (max-width:768px){.faqs-header h1{font-size:2rem}.faq-question,.faqs-header p{font-size:1rem}.faq-question{padding:16px 20px}.faq-answer{padding:0 20px 20px}.faq-answer p{font-size:.95rem}}.faq-answer table{border-collapse:collapse;font-size:.95rem;margin-bottom:16px;width:100%}.faq-answer td,.faq-answer th{border-bottom:1px solid #e5e7eb;padding:12px;text-align:left}.faq-answer th{background-color:#f3f4f6;border-bottom:2px solid #e5e7eb;font-weight:600}.faq-answer tr:nth-child(2n){background-color:#f9fafb}.faq-table-wrapper{-webkit-overflow-scrolling:touch;margin-bottom:16px;overflow-x:auto;width:100%}@media (max-width:640px){.faq-answer table{font-size:.85rem;min-width:500px}.faq-answer td,.faq-answer th{padding:10px 8px}.faq-table-wrapper{margin-left:-8px;margin-right:-8px;padding:0 8px}}.faq-image-answer ol{margin:16px 0;padding-left:24px}.faq-image-answer ol li{line-height:1.6;margin-bottom:8px}.faq-process-image{display:flex;justify-content:center;margin:24px 0}.faq-process-image img{border-radius:12px;box-shadow:0 4px 12px #0000001a;height:auto;max-width:100%;width:400px}@media (min-width:768px){.faq-process-image img{width:500px}}@media (max-width:480px){.faq-process-image img{border-radius:8px;width:100%}}.feedback-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.feedback-content{margin:0 auto;max-width:700px}.feedback-header{margin-bottom:40px;text-align:center}.feedback-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:16px}.feedback-header p{color:#718096;font-size:1.125rem}.feedback-form-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:32px;padding:32px}.form-group:last-child{margin-bottom:0}.feedback-textarea{border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:1rem;padding:12px 16px;resize:vertical;transition:border-color .2s;width:100%}.feedback-textarea:focus{border-color:#667eea;outline:none}.rating-input{display:flex;gap:8px;margin-bottom:8px}.star-button{background:none;border:none;color:#cbd5e0;cursor:pointer;font-size:2rem;padding:4px;transition:all .2s}.star-button:hover{color:#fbbf24;transform:scale(1.1)}.star-button.active{color:#fbbf24}.rating-label{color:#667eea;font-size:.95rem;font-weight:600;margin:0}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px}.submit-button{transition:transform .2s,box-shadow .2s}.submit-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea4d}.feedback-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #667eea1a;border-radius:12px;padding:24px;text-align:center}.feedback-info p{color:#4a5568;font-size:.95rem;line-height:1.6;margin:8px 0}@media (max-width:768px){.feedback-header h1{font-size:2rem}.feedback-header p{font-size:1rem}.feedback-form-card{padding:24px 20px}.form-actions{flex-direction:column}.form-actions button{width:100%}.star-button{font-size:1.75rem}}.privacy-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.privacy-content{margin:0 auto;max-width:900px}.privacy-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:48px;padding:32px 24px;text-align:center}.privacy-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:12px}.privacy-body{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:32px;padding:40px}.privacy-section{margin-bottom:40px}.privacy-section:last-child{margin-bottom:0}.privacy-section h2{border-bottom:2px solid #667eea33;color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:16px;padding-bottom:12px}.privacy-section h3{color:#4a5568;font-size:1.125rem;font-weight:600;margin-bottom:12px;margin-top:20px}.privacy-section p{color:#4a5568;font-size:1rem;line-height:1.8;margin-bottom:16px}.privacy-section p:last-child{margin-bottom:0}.privacy-section ul{list-style:none;margin:16px 0;padding:0}.privacy-section ul li{color:#4a5568;line-height:1.7;padding:8px 0 8px 28px;position:relative}.privacy-section ul li:before{color:#667eea;content:"•";font-size:1.2rem;font-weight:700;left:12px;position:absolute}.note{color:#718096;font-size:.95rem;font-style:italic}.privacy-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #667eea1a;border-radius:12px;padding:24px;text-align:center}@media (max-width:768px){.privacy-header h1{font-size:2rem}.privacy-body{padding:24px 20px}.privacy-section h2{font-size:1.25rem}.privacy-section h3{font-size:1rem}.privacy-section p,.privacy-section ul li{font-size:.95rem}}.terms-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.terms-content{margin:0 auto;max-width:900px}.terms-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:48px;padding:32px 24px;text-align:center}.terms-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:12px}.last-updated{color:#718096;font-size:.95rem;font-style:italic;margin-bottom:16px}.terms-body{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:32px;padding:40px}.terms-section{margin-bottom:40px}.terms-section:last-child{margin-bottom:0}.terms-section h2{border-bottom:2px solid #667eea33;color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:16px;padding-bottom:12px}.terms-section p{color:#4a5568;font-size:1rem;line-height:1.8;margin-bottom:16px}.terms-section p:last-child{margin-bottom:0}.subsection-title{color:#2d3748;font-weight:600;margin-top:12px}.terms-section ul{list-style:none;margin:16px 0;padding:0}.terms-section ul li{color:#4a5568;line-height:1.7;padding:8px 0 8px 28px;position:relative}.terms-section ul li:before{color:#667eea;content:"•";font-size:1.2rem;font-weight:700;left:12px;position:absolute}.highlight{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-left:4px solid #667eea;border-radius:8px;color:#2d3748;font-weight:600;padding:12px 16px}.contact-email{color:#667eea;font-size:1.125rem;font-weight:600;margin-top:8px}.terms-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #667eea1a;border-radius:12px;padding:24px;text-align:center}@media (max-width:768px){.terms-header h1{font-size:2rem}.terms-body{padding:24px 20px}.terms-section h2{font-size:1.25rem}.terms-section p,.terms-section ul li{font-size:.95rem}.intro-text{font-size:1rem}}.contact-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.contact-content{margin:0 auto;max-width:900px}.contact-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:48px;padding:32px 24px;text-align:center}.contact-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin-bottom:12px}.intro-text{color:#4a5568;font-size:1.05rem;line-height:1.8;margin-top:16px}.contact-body{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:32px;padding:40px}.contact-info{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:40px}.info-card{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid #667eea26;border-radius:12px;padding:32px 24px;text-align:center;transition:all .3s ease}.info-card:hover{box-shadow:0 8px 24px #667eea26;transform:translateY(-4px)}.info-icon{color:#667eea;margin:0 auto 16px}.info-card h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin-bottom:12px}.info-card p{color:#4a5568;font-size:.95rem;line-height:1.6;margin-bottom:12px}.email-link{color:#667eea;display:inline-block;font-size:1.125rem;font-weight:600;text-decoration:none;transition:color .2s}.email-link:hover{color:#764ba2;text-decoration:underline}.contact-form{margin:0 auto;max-width:600px}.form-group{margin-bottom:24px}.form-group label{font-size:.95rem;font-weight:600;margin-bottom:8px}.form-group input,.form-group textarea{background:#fff;border:2px solid #667eea33;border-radius:8px;color:#2d3748;font-size:1rem;padding:12px 16px;transition:all .2s;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group textarea{font-family:inherit;min-height:120px;resize:vertical}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;cursor:pointer;padding:14px 24px}.submit-button:hover:not(:disabled){box-shadow:0 8px 24px #667eea4d}@media (max-width:768px){.contact-header h1{font-size:2rem}.contact-body{padding:24px 20px}.contact-info{grid-template-columns:1fr}.info-card{padding:24px 20px}.form-group input,.form-group textarea{font-size:.95rem}}.customise-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:24px;transition:background .3s ease}.customise-container.theme-sample2{background:linear-gradient(135deg,#4facfe,#00f2fe)}.customise-container.theme-sample4{background:linear-gradient(135deg,#ff9a9e,#fecfef)}.customise-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.customise-loading .spinner{animation:spin 1s linear infinite}.customise-header{margin:0 auto 32px;max-width:1200px}.back-button{background:#ffffffe6;border-radius:8px;padding:8px 16px}.back-button:hover{background:#fff;opacity:.8}.customise-content{margin:0 auto;max-width:1200px}.customise-title-section{color:#fff;margin-bottom:48px;text-align:center}.customise-icon{display:block;margin:0 auto 24px;opacity:.95}.customise-title{font-size:3rem;font-weight:800;margin-bottom:16px;text-shadow:0 2px 8px #0000001a}.customise-subtitle{font-size:1.125rem;line-height:1.7;margin:0 auto;max-width:700px;opacity:.95}.theme-card{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;padding:40px}.theme-options{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:32px}.theme-option{background:#f8fafc;border:3px solid #0000;border-radius:12px;cursor:pointer;padding:20px;position:relative;transition:all .3s ease}.theme-option:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-4px)}.theme-option.active{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-color:#667eea}.theme-preview{border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:8px;height:80px;margin-bottom:16px;overflow:hidden}.preview-color{flex:1 1}.theme-preview-sample3 .color-1{background:linear-gradient(135deg,#667eea,#764ba2)}.theme-preview-sample3 .color-2{background:#667eea}.theme-preview-sample3 .color-3{background:#764ba2}.theme-preview-sample4 .color-1{background:linear-gradient(135deg,#ff9a9e,#fecfef)}.theme-preview-sample4 .color-2{background:#ff9a9e}.theme-preview-sample4 .color-3{background:#fecfef}.theme-preview-sample2 .color-1{background:linear-gradient(135deg,#4facfe,#00f2fe)}.theme-preview-sample2 .color-2{background:#4facfe}.theme-preview-sample2 .color-3{background:#00f2fe}.theme-info h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin-bottom:8px}.theme-info p{color:#64748b;font-size:.95rem;margin-bottom:12px}.theme-colors{display:flex;gap:8px}.color-dot{border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #00000026;height:24px;width:24px}.active-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 2px 8px #667eea4d;color:#fff;font-size:.875rem;font-weight:600;padding:6px 12px;position:absolute;right:16px;top:16px}.theme-info-footer{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-left:4px solid #667eea;border-radius:8px;padding:20px}.theme-info-footer p{color:#4a5568;font-size:.95rem;margin:0}.theme-info-footer strong{color:#2d3748}@media (max-width:768px){.customise-title{font-size:2rem}.customise-subtitle{font-size:1rem}.theme-card{padding:24px}.theme-options{grid-template-columns:1fr}.theme-option{padding:16px}.theme-preview{height:60px}}.about-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.about-content{margin:0 auto;max-width:900px}.back-button{color:#000;transition:color .2s}.back-button:hover{color:#000}.about-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:48px;padding:32px 24px;text-align:center}.about-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800;margin:0}.about-body{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;box-shadow:0 4px 20px #667eea14;margin-bottom:32px;padding:40px}.about-section{margin-bottom:48px}.about-section:last-child{margin-bottom:0}.intro-section .intro-text{color:#2d3748;font-size:1.125rem;line-height:1.8;margin:0 auto;max-width:800px;text-align:center}.goal-section{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-left:4px solid #667eea;border-radius:12px;padding:40px 24px;text-align:center}.goal-header{align-items:center;display:flex;gap:16px;justify-content:center;margin-bottom:20px}.section-icon{color:#667eea}.goal-header h2{color:#2d3748;font-size:1.75rem;font-weight:700;margin:0}.goal-statement{color:#4a5568;font-size:1.25rem;font-weight:500;line-height:1.7;margin:0}.mission-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.mission-card{background:linear-gradient(135deg,#667eea08,#764ba208);border:1px solid #667eea26;border-radius:12px;padding:32px 24px;text-align:center;transition:all .3s ease}.mission-card:hover{box-shadow:0 8px 24px #667eea26;transform:translateY(-4px)}.mission-icon{color:#667eea;margin:0 auto 16px}.mission-card h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin-bottom:12px}.mission-card p{color:#4a5568;font-size:1rem;line-height:1.6;margin:0}.values-section h2{color:#2d3748;font-size:1.75rem;font-weight:700;margin-bottom:32px;text-align:center}.values-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.value-item{background:#fff;border:2px solid #667eea1a;border-radius:12px;padding:24px 20px;text-align:center;transition:all .3s ease}.value-item:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.value-item h4{color:#2d3748;font-size:1.125rem;font-weight:700;margin-bottom:8px}.value-item p{color:#64748b;font-size:.95rem;line-height:1.5;margin:0}.about-footer{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #667eea1a;border-radius:12px;padding:24px;text-align:center}@media (max-width:768px){.about-header h1{font-size:2rem}.about-body{padding:24px 20px}.intro-section .intro-text{font-size:1rem}.goal-header{flex-direction:column;gap:12px}.goal-header h2{font-size:1.5rem}.goal-statement{font-size:1.125rem}.mission-section,.values-grid{grid-template-columns:1fr}.story-section h2{font-size:1.5rem}.story-content p{font-size:1rem}}.story-section{border-top:1px solid #667eea26;margin-top:48px;padding-top:48px}.story-section h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#2d3748;font-size:1.75rem;font-weight:700;margin-bottom:32px;text-align:center}.story-content{margin:0 auto;max-width:700px}.story-content p{color:#4a5568;font-size:1.1rem;line-height:1.9;margin-bottom:20px;text-align:left}.story-content p:last-child{margin-bottom:0}.story-content .story-intro{color:#667eea;font-size:1.25rem;margin-bottom:28px;text-align:center}.story-content strong{color:#2d3748}.pricing-container{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh;padding:24px}.pricing-content{margin:0 auto;max-width:1000px}.back-button{align-items:center;color:#1f2937!important;display:inline-flex;font-weight:500;gap:8px;margin-bottom:32px;transition:opacity .2s}.back-button:hover{color:#1f2937!important;opacity:.7}.pricing-header{margin-bottom:40px;text-align:center}.pricing-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.25rem;font-weight:800;margin-bottom:16px}.pricing-subtitle{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:8px}.pricing-description{color:#6b7280;font-size:1rem}.pricing-cards-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin:0 auto 48px;max-width:900px}.pricing-main-card{display:flex;justify-content:center;margin-bottom:48px}.pricing-card.single-plan{max-width:500px;padding:32px;text-align:center;width:100%}.pricing-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;display:flex;flex-direction:column;padding:28px;position:relative;text-align:center}.pricing-card.featured{border:2px solid #667eea;box-shadow:0 8px 32px #667eea33}.plan-badge{background:#f3f4f6;color:#374151;display:inline-block;font-size:.8rem;margin-bottom:16px;padding:6px 16px}.plan-badge,.popular-badge{border-radius:20px;font-weight:600}.popular-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.85rem;left:50%;padding:6px 20px;position:absolute;top:-12px;transform:translateX(-50%);white-space:nowrap}.savings-badge{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px;color:#92400e;display:inline-block;font-size:.8rem;font-weight:700;margin-bottom:12px;margin-top:8px;padding:4px 12px}.plan-savings{color:#10b981;font-size:.85rem;font-weight:600;margin-top:4px}.plan-features{flex-grow:1;list-style:none;margin:16px 0;padding:0;text-align:left}.plan-features li{align-items:center;color:#4b5563;display:flex;font-size:.9rem;gap:10px;margin-bottom:10px}.plan-features li svg{color:#10b981;flex-shrink:0}.plan-header{margin-bottom:16px}.plan-price{align-items:baseline;display:flex;gap:4px;justify-content:center;margin-top:16px}.plan-price .currency{color:#667eea;font-size:1.5rem;font-weight:600}.plan-price .amount{color:#1f2937;font-size:3.5rem;font-weight:800;line-height:1}.plan-price .period{color:#6b7280;font-size:1rem;margin-left:4px}.plan-tagline{color:#6b7280;font-size:.95rem;margin-top:8px}.plan-description{color:#4b5563;font-size:1rem;line-height:1.6;margin:20px 0}.subscribe-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:14px 24px;transition:all .3s;width:100%}.subscribe-button:hover{box-shadow:0 4px 16px #667eea66;transform:translateY(-2px)}.subscribe-button.large{font-size:1.2rem;padding:16px 32px}.plan-note{color:#9ca3af;font-size:.85rem;margin-top:12px}.subscribe-divider{align-items:center;display:flex;margin:16px 0}.subscribe-divider span{background:#fff;color:#9ca3af;font-size:.85rem;padding:0 12px;position:relative;z-index:1}.subscribe-divider:after,.subscribe-divider:before{background:#e5e7eb;content:"";flex:1 1;height:1px}.subscribe-button-secondary{background:#0000;border:2px solid #667eea;border-radius:8px;color:#667eea;font-weight:600;padding:12px 24px;transition:all .2s;width:100%}.subscribe-button-secondary:hover{background:#667eea1a;transform:translateY(-1px)}.annual-billing-note{background:#667eea14;border-left:3px solid #667eea;border-radius:8px;margin-top:20px;padding:16px}.annual-billing-note p{color:#4b5563;font-size:.9rem;line-height:1.5;margin:0}.annual-billing-note p:first-child{color:#1f2937;margin-bottom:8px}.whats-included{margin-bottom:48px}.whats-included h2{color:#1f2937;font-size:1.75rem;font-weight:700;margin-bottom:24px;text-align:center}.included-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.included-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;padding:24px}.included-card h3{border-bottom:2px solid #f3f4f6;color:#667eea;font-size:1.2rem;font-weight:700;margin-bottom:16px;padding-bottom:12px}.feature-list{list-style:none;margin:0;padding:0}.feature-list li{align-items:flex-start;color:#4b5563;display:flex;font-size:.9rem;gap:10px;line-height:1.4;margin-bottom:12px}.feature-list li svg{color:#10b981;flex-shrink:0;margin-top:2px}.why-limits-section{margin-bottom:48px}.why-limits-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:16px;padding:32px;text-align:center}.why-limits-card h2{color:#92400e;font-size:1.5rem;font-weight:700;margin-bottom:16px}.section-intro{color:#78350f;font-size:1rem;margin-bottom:16px}.limits-list{list-style:none;margin:0 auto 20px;max-width:600px;padding:0;text-align:left}.limits-list li{color:#78350f;font-size:.95rem;margin-bottom:10px;padding-left:24px;position:relative}.limits-list li:before{color:#f59e0b;content:"•";font-weight:700;left:8px;position:absolute}.limits-benefit{color:#92400e;font-size:1rem;font-style:italic;font-weight:600}.trial-notice-section{margin-bottom:48px}.trial-notice-section.top-notice{margin-bottom:32px}.trial-notice-card{background:#fffffff2;border:2px solid #667eea;border-radius:16px;padding:32px;text-align:center}.trial-notice-card h2{color:#374151;font-size:1.5rem;font-weight:700;margin-bottom:16px}.trial-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;display:inline-block;font-size:.9rem;font-weight:600;margin-bottom:16px;padding:8px 20px}.trial-notice-card p{color:#6b7280;font-size:.95rem;margin-bottom:12px;margin-left:auto;margin-right:auto;max-width:700px}.release-notice{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:12px;margin-top:20px;padding:20px;text-align:center}.release-notice h3{color:#92400e;font-size:1.1rem;font-weight:700;margin:0 0 10px}.release-notice p{color:#78350f;font-size:.95rem;line-height:1.6;margin:0}.release-notice strong{color:#92400e}.waitlist-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2)!important;border:none!important;color:#fff!important;display:inline-flex;font-weight:600;gap:8px;margin-top:16px;padding:10px 20px;transition:transform .2s,box-shadow .2s}.waitlist-button:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.notice-highlight{color:#4b5563!important;font-weight:500}.impact-section{margin-bottom:48px}.impact-card{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:2px solid #10b981;border-radius:16px;padding:32px;text-align:center}.impact-card h2{color:#065f46;font-size:1.5rem;font-weight:700;margin-bottom:12px}.impact-intro{color:#047857;font-size:1rem;margin-bottom:24px}.impact-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.impact-item{align-items:center;background:#ffffffb3;border-radius:12px;display:flex;flex-direction:column;gap:8px;padding:16px}.impact-icon{font-size:1.5rem}.impact-item span:last-child{color:#065f46;font-size:.9rem;font-weight:500}.impact-price{color:#065f46;font-size:1.1rem}.impact-price strong{font-size:1.25rem}.worth-it-section{margin-bottom:48px}.worth-it-section h2{color:#1f2937;font-size:1.75rem;font-weight:700;margin-bottom:12px;text-align:center}.worth-it-intro{color:#667eea;font-size:1.1rem;font-weight:600;margin-bottom:8px;text-align:center}.worth-it-description{color:#6b7280;font-size:1rem;margin-bottom:32px;margin-left:auto;margin-right:auto;max-width:700px;text-align:center}.worth-it-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:40px}.worth-it-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #667eea1a;border-radius:16px;padding:24px;text-align:center;transition:all .3s}.worth-it-item:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea26;transform:translateY(-4px)}.worth-it-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;height:48px;justify-content:center;margin:0 auto 16px;width:48px}.worth-it-item h4{color:#1f2937;font-size:1rem;font-weight:700;margin-bottom:8px}.worth-it-item p{color:#6b7280;font-size:.9rem;line-height:1.5}.final-cta{background:#fffffff2;border:2px solid #667eea;border-radius:16px;padding:32px;text-align:center}.final-message{color:#374151;font-size:1.1rem;font-weight:600;margin-bottom:20px}.final-cta .subscribe-button{margin:0 auto;max-width:300px}@media (max-width:900px){.pricing-cards-grid{max-width:450px}.included-grid,.pricing-cards-grid{grid-template-columns:1fr}.impact-grid,.worth-it-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.pricing-header h1{font-size:1.75rem}.pricing-subtitle{font-size:1.1rem}.plan-price .amount{font-size:2.5rem}.pricing-cards-grid{gap:20px}.pricing-card{padding:24px 20px}.impact-grid{gap:12px;grid-template-columns:1fr 1fr}.impact-item{padding:12px}.worth-it-grid{grid-template-columns:1fr}.whats-included h2,.worth-it-section h2{font-size:1.4rem}.impact-card,.trial-notice-card,.why-limits-card{padding:24px 16px}}.spinner{animation:spin 1s linear infinite}.subscription-status-container{align-items:center;background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;padding:16px}.status-card{align-items:center!important;border-radius:16px;box-shadow:0 8px 32px #0000001f;box-sizing:border-box;display:flex!important;flex-direction:column!important;max-width:600px;padding:48px;text-align:center;width:100%}.status-icon{display:block;flex-shrink:0;margin:0 auto 24px}.status-icon.spinning{animation:spin 1s linear infinite;color:#667eea}.status-icon.success-icon{color:#10b981}.status-icon.error-icon{color:#ef4444}.status-card h1{word-wrap:break-word;color:#2d3748;font-size:1.75rem;font-weight:800;margin-bottom:16px;width:100%}.status-card p{color:#64748b;font-size:1rem;line-height:1.6;margin-bottom:20px;width:100%}.success-message{font-size:1rem}.success-details{display:flex;flex-direction:column;margin:24px 0;text-align:left;width:100%}.detail-item{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-left:4px solid #667eea;border-radius:8px;box-sizing:border-box;margin-bottom:16px;padding:16px;width:100%}.detail-item strong{color:#2d3748;display:block;font-size:1rem;margin-bottom:8px}.detail-item p{color:#64748b;font-size:.9rem;line-height:1.5;margin:0}.action-buttons{flex-wrap:wrap;gap:12px;margin-top:24px;width:100%}.action-buttons button{min-width:140px}@media (max-width:480px){.subscription-status-container{align-items:flex-start;padding:24px 12px 12px}.status-card{border-radius:12px;padding:24px 16px}.status-icon{margin-bottom:16px}.status-card .status-icon,.status-icon svg{height:48px!important;width:48px!important}.status-card h1{font-size:1.35rem;margin-bottom:12px}.status-card p{line-height:1.5;margin-bottom:16px}.status-card p,.success-message{font-size:.9rem}.success-details{margin:16px 0}.detail-item{margin-bottom:12px;padding:12px}.detail-item strong{font-size:.9rem}.detail-item p{font-size:.85rem}.action-buttons{flex-direction:column;gap:10px;margin-top:20px}.action-buttons button{font-size:.9rem;min-width:0;min-width:auto;padding:12px 16px;width:100%}}@media (min-width:481px) and (max-width:768px){.status-card{padding:32px 24px}.status-card h1{font-size:1.5rem}.action-buttons{flex-direction:column}.action-buttons button{width:100%}}.subscription-required-container{align-items:center;background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);display:flex;justify-content:center;min-height:100vh;padding:24px}.subscription-required-card{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001f;max-width:700px;padding:48px;text-align:center;width:100%}.icon-container{margin-bottom:24px}.lock-icon{color:#667eea;margin:0 auto}.subscription-required-card h1{color:#2d3748;font-size:2.5rem;font-weight:800;margin-bottom:16px}.subtitle{color:#64748b;font-size:1.125rem;line-height:1.7;margin-bottom:32px}.trial-info{align-items:center;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-left:4px solid #667eea;border-radius:8px;color:#4a5568;display:flex;font-weight:500;gap:12px;justify-content:center;margin-bottom:32px;padding:16px 24px}.benefits-list{background:#f8fafc;border-radius:12px;margin:32px 0;padding:24px;text-align:left}.benefits-list h3{color:#2d3748;font-size:1.25rem;font-weight:700;margin-bottom:16px;text-align:center}.benefit-item{align-items:center;color:#4a5568;display:flex;gap:12px;padding:10px 0}.check-icon{color:#10b981;flex-shrink:0}.pricing-preview{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr);margin:32px 0}.price-option{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:24px;position:relative;transition:all .3s ease}.price-option:hover{border-color:#667eea;transform:translateY(-2px)}.price-option.featured{background:linear-gradient(135deg,#667eea0d,#764ba20d);border-color:#667eea}.best-value-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;font-size:.7rem;font-weight:700;left:50%;padding:4px 12px;position:absolute;top:-10px;transform:translateX(-50%)}.price-option h4{color:#2d3748;font-size:1.125rem;font-weight:700;margin-bottom:8px}.price-option .price{color:#667eea;font-size:2rem;font-weight:800;margin-bottom:8px}.price-option .price span{color:#64748b;font-size:1rem;font-weight:500}.price-option p{color:#64748b;font-size:.875rem;margin:0}.action-buttons{display:flex;gap:16px;justify-content:center;margin:32px 0}.action-buttons button{min-width:200px}.support-text{color:#64748b;font-size:.95rem;margin-top:24px}.support-text a{color:#667eea;font-weight:600;text-decoration:none}.support-text a:hover{text-decoration:underline}@media (max-width:768px){.subscription-required-card{padding:32px 24px}.subscription-required-card h1{font-size:1.75rem}.subtitle{font-size:1rem}.pricing-preview{grid-template-columns:1fr}.action-buttons{flex-direction:column}.action-buttons button{width:100%}}.waiting-list-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem 1rem}.waiting-list-content{margin:0 auto;max-width:800px}.back-button{color:#fff;margin-bottom:2rem}.back-button:hover{background:#ffffff1a}.waiting-list-header{color:#fff;margin-bottom:2rem;text-align:center}.header-icon{height:64px;margin:0 auto 1rem;opacity:.9;width:64px}.waiting-list-header h1{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.subtitle{font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:600px;opacity:.9}.status-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.status-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;gap:1rem;padding:1.5rem}.card-icon{color:#667eea;height:40px;width:40px}.card-content{flex:1 1}.card-value{color:#2d3748;font-size:1.75rem;font-weight:700}.card-label{color:#718096;font-size:.875rem;margin-top:.25rem}.form-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:2rem}.form-card h2{color:#2d3748;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.waiting-list-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#2d3748;display:block;font-weight:500;margin-bottom:.5rem}.submit-button{background:#667eea;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;padding:.75rem;transition:all .3s;width:100%}.submit-button:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.submit-button:disabled{cursor:not-allowed;opacity:.6}.benefits-section{border-top:1px solid #e2e8f0;padding-top:2rem}.benefits-section h3{color:#2d3748;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.benefits-list{list-style:none;margin:0;padding:0}.benefits-list li{align-items:flex-start;color:#4a5568;display:flex;gap:.75rem;margin-bottom:.75rem}.benefit-icon{color:#48bb78;flex-shrink:0;height:20px;margin-top:2px;width:20px}.success-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:3rem 2rem;text-align:center}.success-icon{color:#48bb78;height:80px;margin:0 auto 1.5rem;width:80px}.success-card h1{color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:1rem}.success-message{color:#4a5568;line-height:1.6}.position-badge,.success-message{font-size:1.125rem;margin-bottom:2rem}.position-badge{align-items:center;background:#667eea;border-radius:50px;color:#fff;display:inline-flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem}.info-box{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:2rem;padding:1.5rem;text-align:left}.info-box h3{color:#2d3748;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.info-box ul{list-style:none;margin:0;padding:0}.info-box li{color:#4a5568;padding:.5rem 0 .5rem 1.5rem;position:relative}.info-box li:before{color:#48bb78;content:"✓";font-weight:700;left:0;position:absolute}.home-button{background:#667eea;color:#fff;font-weight:600;padding:.75rem 2rem}.home-button:hover{background:#5568d3}@media (max-width:768px){.waiting-list-header h1{font-size:2rem}.subtitle{font-size:1rem}.status-cards{grid-template-columns:1fr}.form-card{padding:1.5rem}.success-card{padding:2rem 1.5rem}}.draft-label{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:20px;box-shadow:0 4px 12px #3b82f64d;color:#fff;font-size:.85rem;font-weight:600;padding:8px 16px;position:fixed;right:20px;top:20px;z-index:1000}.landing-draft{background:linear-gradient(180deg,#fdf2f8,#fff,#f0f9ff);min-height:100vh}.hero-section-draft{margin:0 auto;max-width:1200px;padding:80px 20px;text-align:center}.hero-content{margin:0 auto;max-width:800px}.hero-badge,.hero-badge-problem{border-radius:30px;display:inline-block;font-size:.9rem;font-weight:600;margin-bottom:24px;padding:8px 20px}.hero-badge{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#15803d}.hero-badge-problem{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.hero-section-draft h1{color:#1e3a5f;font-size:3rem;font-weight:800;line-height:1.2;margin-bottom:20px}.hero-subtitle{color:#64748b;font-size:1.25rem;line-height:1.6;margin-bottom:32px}.hero-stats{display:flex;gap:48px;justify-content:center;margin-bottom:40px}.stat-item{text-align:center}.stat-number{color:#3b82f6;display:block;font-size:2.5rem;font-weight:800}.stat-label{font-size:.9rem}.hero-cta{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.hero-cta button{align-items:center;display:flex;font-size:1rem;gap:8px;padding:14px 28px}.hero-trust{color:#64748b;font-size:.9rem}.features-section-draft{background:#fff;padding:80px 20px}.audience-section h2,.features-section-draft h2,.social-proof-section h2{color:#1e3a5f;font-size:2rem;margin-bottom:12px;text-align:center}.section-subtitle{color:#64748b;margin-bottom:48px;text-align:center}.features-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(5,1fr);margin:0 auto;max-width:1200px}.feature-card{border-radius:12px;padding:24px;text-align:center;transition:all .3s ease}.feature-card:hover{box-shadow:0 12px 24px #0000001a;transform:translateY(-4px)}.feature-card.highlighted{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff}.feature-card.highlighted .feature-icon{color:#fff}.feature-icon{color:#3b82f6;height:48px;margin:0 auto 16px;width:48px}.feature-icon svg{height:100%;width:100%}.feature-card h3{font-size:1rem;margin-bottom:8px}.feature-card p{color:#64748b;font-size:.85rem;line-height:1.4}.feature-card.highlighted p{color:#ffffffe6}.audience-section{background:#f8fafc;padding:80px 20px}.audience-tabs{display:flex;gap:16px;justify-content:center;margin-bottom:40px}.audience-tabs button{background:#fff;border:2px solid #e2e8f0;border-radius:30px;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .2s}.audience-tabs button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.audience-tabs button:hover:not(.active){border-color:#3b82f6;color:#3b82f6}.audience-content{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;margin:0 auto;max-width:600px;padding:40px;text-align:center}.audience-content h3{color:#1e3a5f;font-size:1.8rem;margin-bottom:24px}.audience-content ul{list-style:none;margin:0 0 32px;padding:0;text-align:left}.audience-content li{align-items:center;border-bottom:1px solid #f1f5f9;color:#475569;display:flex;gap:12px;padding:12px 0}.audience-content li svg{color:#22c55e;flex-shrink:0}.social-proof-section{background:#fff;padding:80px 20px}.testimonials{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.testimonial-card{padding:32px;text-align:center}.testimonial-card .stars{font-size:1.5rem;margin-bottom:16px}.testimonial-card p{color:#475569;font-style:italic;line-height:1.6;margin-bottom:16px}.testimonial-card .author{color:#94a3b8;font-size:.9rem}.final-cta-section{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;padding:80px 20px;text-align:center}.final-cta-section h2{font-size:2.5rem;margin-bottom:16px}.final-cta-section p{font-size:1.1rem;margin-bottom:32px;opacity:.9}.final-cta-section button{background:#fff;color:#3b82f6;font-size:1.1rem;padding:16px 32px}.final-cta-section button:hover{background:#f8fafc}.draft-navigation{background:#1e3a5f;display:flex;gap:16px;justify-content:center;padding:40px 20px}.draft-navigation button{border-color:#ffffff4d;color:#fff}.draft-navigation button:hover{background:#ffffff1a;border-color:#fff}.problem-hero{background:linear-gradient(180deg,#fef2f2,#fff)}.problem-solution-section{background:#fff;padding:80px 20px}.problem-solution-section h2{color:#1e3a5f;font-size:2rem;margin-bottom:48px;text-align:center}.problem-solution-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1000px}.problem-solution-card{align-items:center;display:flex;gap:20px;padding:24px}.problem-side,.solution-side{flex:1 1;text-align:center}.side-label{color:#94a3b8;display:block;font-size:.75rem;font-weight:600;margin-bottom:12px;text-transform:uppercase}.problem-icon,.problem-side{color:#dc2626}.solution-icon,.solution-side{color:#16a34a}.arrow-divider{color:#94a3b8;font-size:1.5rem}.how-it-works-section{background:#f8fafc;padding:80px 20px}.how-it-works-section h2{color:#1e3a5f;margin-bottom:12px;text-align:center}.steps-container{align-items:center;display:flex;gap:20px;justify-content:center;margin:48px auto 0;max-width:1000px}.step{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000000d;flex:1 1;padding:32px;text-align:center}.step-number{background:#3b82f6;height:40px;margin:0 auto 16px;width:40px}.step svg{color:#3b82f6;margin-bottom:12px}.step h3{color:#1e3a5f;margin-bottom:8px}.step p{color:#64748b;font-size:.9rem}.step-arrow{color:#3b82f6;font-size:2rem}.everyone-section{background:#fff;padding:80px 20px}.everyone-section h2{color:#1e3a5f;font-size:2rem;margin-bottom:48px;text-align:center}.audience-cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.audience-card{border-radius:16px;padding:32px;transition:all .3s}.audience-card:hover{box-shadow:0 20px 40px #0000001a;transform:translateY(-8px)}.card-header{align-items:center;display:flex;gap:12px;margin-bottom:24px}.card-header .emoji{font-size:2rem}.card-header h3{color:#1e3a5f;font-size:1.3rem}.audience-card ul{list-style:none;margin:0 0 24px;padding:0}.audience-card li{align-items:center;color:#475569;display:flex;font-size:.95rem;gap:8px;padding:8px 0}.audience-card li svg{color:#22c55e}.audience-card.teachers{border:2px solid #3b82f6}.audience-card.students{border:2px solid #8b5cf6}.audience-card.parents{border:2px solid #f59e0b}.emotional-section{background:linear-gradient(135deg,#fdf2f8,#fce7f3);padding:80px 20px;text-align:center}.emotional-content{margin:0 auto;max-width:700px}.heart-icon{color:#ec4899;margin-bottom:24px}.emotional-section h2{color:#1e3a5f;font-size:2rem;margin-bottom:24px}.emotional-section p{color:#64748b;line-height:1.8;margin-bottom:16px}.emotional-section .emphasis{color:#1e3a5f;font-size:1.1rem}.features-quick-section{background:#1e3a5f;color:#fff;padding:60px 20px}.features-quick-section h2{margin-bottom:32px;text-align:center}.features-quick-grid{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin:0 auto;max-width:1000px}.feature-quick{align-items:center;background:#ffffff1a;border-radius:30px;display:flex;font-size:.9rem;gap:8px;padding:12px 20px}.feature-quick svg{opacity:.8}.emotional-cta{background:linear-gradient(135deg,#ec4899,#8b5cf6)}.small-text{font-size:.85rem;margin-top:16px;opacity:.8}.visual-hero{padding:60px 20px}.hero-split{align-items:center;display:flex;gap:60px;margin:0 auto;max-width:1200px}.hero-left{flex:1 1;text-align:left}.hero-left h1{font-size:2.5rem}.hero-left .hero-cta{justify-content:flex-start}.hero-right{flex:1 1}.video-placeholder{background:linear-gradient(135deg,#1e3a5f,#3b82f6);border-radius:16px;box-shadow:0 20px 40px #1e3a5f4d;color:#fff;padding:80px 40px;text-align:center}.play-button{align-items:center;background:#fff;border-radius:50%;cursor:pointer;display:flex;height:80px;justify-content:center;margin:0 auto 16px;transition:transform .2s;width:80px}.play-button:hover{transform:scale(1.1)}.play-button svg{color:#3b82f6;margin-left:4px}.video-placeholder p{font-size:1.1rem;margin-bottom:4px}.video-placeholder span{font-size:.9rem;opacity:.7}.demo-section{background:#fff;padding:80px 20px}.demo-section h2{color:#1e3a5f;font-size:2rem;margin-bottom:12px;text-align:center}.demo-container{margin:48px auto 0;max-width:900px}.demo-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:32px}.demo-tabs button{background:#f1f5f9;border:none;border-radius:8px;cursor:pointer;font-weight:500;padding:12px 24px;transition:all .2s}.demo-tabs button.active{background:#3b82f6;color:#fff}.demo-content{align-items:center;display:flex;gap:40px}.demo-mockup{flex:2 1}.mockup-window{background:#fff;border-radius:12px;box-shadow:0 8px 32px #00000026;overflow:hidden}.window-header{align-items:center;background:#f1f5f9;display:flex;gap:8px;padding:12px 16px}.dot{border-radius:50%;height:12px;width:12px}.dot.red{background:#ef4444}.dot.yellow{background:#f59e0b}.dot.green{background:#22c55e}.window-title{color:#64748b;font-size:.85rem;margin-left:12px}.window-content{align-items:center;display:flex;justify-content:center;min-height:150px;padding:40px}.mockup-text{color:#1e3a5f;font-size:1.2rem;text-align:center}.mockup-text .gold{background:#fef3c7;border-radius:4px;padding:2px 6px}.mockup-text .pink{background:#fce7f3;border-radius:4px;padding:2px 6px}.demo-description{flex:1 1}.demo-description h3{color:#1e3a5f;margin-bottom:12px}.demo-description p{color:#64748b;line-height:1.6}.pillars-section{background:#f8fafc;padding:80px 20px}.pillars-section h2{color:#1e3a5f;font-size:2rem;margin-bottom:48px;text-align:center}.pillars-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.pillar-card{padding:32px;position:relative;text-align:center}.pillar-card.featured{border:2px solid #3b82f6;transform:scale(1.05)}.featured-badge{background:#3b82f6;border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;left:50%;padding:4px 16px;position:absolute;top:-12px;transform:translateX(-50%)}.pillar-icon{font-size:3rem;margin-bottom:16px}.pillar-card h3{color:#1e3a5f;margin-bottom:16px}.pillar-screenshot{margin-bottom:20px}.screenshot-mock{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;color:#64748b;font-size:.85rem;line-height:1.8;padding:20px}.pillar-card ul{list-style:none;padding:0;text-align:left}.pillar-card li{align-items:center;color:#475569;display:flex;font-size:.9rem;gap:8px;padding:6px 0}.pillar-card li svg{color:#22c55e}.showcase-section{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;padding:60px 20px}.showcase-section h2{margin-bottom:40px;text-align:center}.showcase-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin:0 auto;max-width:1000px}.showcase-item{align-items:center;background:#ffffff26;border-radius:12px;display:flex;flex-direction:column;gap:8px;min-width:120px;padding:20px 24px}.showcase-icon{height:40px;width:40px}.showcase-item span{font-size:.85rem}.testimonials-section-c{background:#fff;padding:80px 20px}.testimonials-section-c h2{color:#1e3a5f;font-size:2rem;margin-bottom:48px;text-align:center}.testimonials-grid-c{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.testimonial-c{padding:32px}.testimonial-header{gap:16px;margin-bottom:16px}.avatar,.testimonial-header{align-items:center;display:flex}.avatar{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;font-weight:600;height:50px;justify-content:center;width:50px}.author-info strong{color:#1e3a5f;display:block}.author-info span{color:#94a3b8;font-size:.85rem}.testimonial-c .rating{margin-bottom:12px}.testimonial-c p{color:#475569;font-style:italic;line-height:1.6}.comparison-section{background:#f8fafc;padding:80px 20px}.comparison-section h2{color:#1e3a5f;font-size:2rem;margin-bottom:48px;text-align:center}.comparison-table{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d;margin:0 auto;max-width:800px;overflow:hidden}.comparison-row{display:grid;grid-template-columns:1fr 1fr 1fr}.comparison-row.header{background:#1e3a5f;color:#fff;font-weight:600}.comparison-cell{border-bottom:1px solid #f1f5f9;padding:16px 20px}.comparison-cell.highlight{background:#f0fdf4;color:#16a34a;font-weight:500}.comparison-row.header .comparison-cell.highlight{background:#22c55e;color:#fff}.visual-cta{background:linear-gradient(135deg,#1e3a5f,#3b82f6)}.cta-content{margin:0 auto;max-width:600px}.cta-icon{color:#fbbf24;margin-bottom:24px}.cta-buttons{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.cta-buttons button{align-items:center;display:flex;gap:8px}.trust-badges{font-size:.9rem;opacity:.8}.drafts-index{background:linear-gradient(180deg,#f8fafc,#fff);min-height:100vh;padding:40px 20px}.drafts-header{margin:0 auto 60px;max-width:800px;text-align:center}.drafts-header h1{color:#1e3a5f;font-size:2.5rem;margin-bottom:16px}.drafts-header p{color:#64748b;font-size:1.1rem;line-height:1.6}.back-home{margin-bottom:24px}.drafts-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(3,1fr);margin:0 auto 60px;max-width:1200px}.draft-preview-card{padding:32px;text-align:center;transition:all .3s}.draft-preview-card:hover{box-shadow:0 20px 40px #0000001a;transform:translateY(-8px)}.draft-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:16px;color:#fff;display:flex;height:64px;justify-content:center;margin:0 auto 20px;width:64px}.draft-preview-card h2{color:#1e3a5f;font-size:1.3rem;margin-bottom:12px}.draft-description{color:#64748b;line-height:1.6;margin-bottom:20px}.draft-strengths{margin-bottom:24px;text-align:left}.draft-strengths strong{color:#1e3a5f;font-size:.85rem}.draft-strengths ul{list-style:none;margin-top:8px;padding:0}.draft-strengths li{color:#22c55e;font-size:.9rem;padding:4px 0}.view-draft-btn{align-items:center;display:flex;gap:8px;justify-content:center;width:100%}.top-features-reminder{background:#f0f9ff;border-radius:16px;margin:0 auto 40px;max-width:800px;padding:32px;text-align:center}.top-features-reminder h3{color:#1e3a5f;margin-bottom:20px}.features-list{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.features-list span{background:#fff;border-radius:20px;box-shadow:0 2px 4px #0000000d;color:#475569;font-size:.9rem;padding:8px 16px}.feedback-section{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:16px;color:#fff;margin:0 auto;max-width:600px;padding:40px;text-align:center}.feedback-section h3{margin-bottom:12px}.feedback-section p{opacity:.9}@media (max-width:1024px){.features-grid{grid-template-columns:repeat(3,1fr)}.audience-cards,.drafts-grid,.pillars-grid,.testimonials,.testimonials-grid-c{grid-template-columns:repeat(2,1fr)}.problem-solution-grid{grid-template-columns:1fr}.demo-content,.hero-split{flex-direction:column}}@media (max-width:768px){.hero-section-draft h1{font-size:2rem}.hero-stats{gap:24px}.hero-cta,.hero-stats{flex-direction:column}.features-grid{grid-template-columns:repeat(2,1fr)}.audience-tabs{flex-direction:column}.audience-cards,.drafts-grid,.pillars-grid,.testimonials,.testimonials-grid-c{grid-template-columns:1fr}.steps-container{flex-direction:column}.step-arrow{transform:rotate(90deg)}.comparison-row{grid-template-columns:1fr}.comparison-row.header{display:none}.comparison-cell:first-child{background:#f8fafc;font-weight:600}.draft-navigation{flex-direction:column}.pillar-card.featured{transform:none}}.draft-preview-card.featured-draft{background:linear-gradient(135deg,#faf5ff,#f5f3ff);border:2px solid #7c3aed;position:relative}.featured-badge-draft{background:linear-gradient(135deg,#7c3aed,#3b82f6);border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;left:50%;padding:4px 16px;position:absolute;top:-12px;transform:translateX(-50%);white-space:nowrap}.drafts-grid{grid-template-columns:repeat(4,1fr)}@media (max-width:1200px){.drafts-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.drafts-grid{grid-template-columns:1fr}}.trial-notice-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:2px solid #f59e0b;padding:12px 20px;text-align:center}.trial-notice-content{align-items:center;display:flex;flex-direction:column;gap:8px;margin:0 auto;max-width:800px}.trial-badge-label{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:20px;color:#fff;display:inline-block;font-size:.8rem;font-weight:700;letter-spacing:.5px;padding:4px 14px;text-transform:uppercase}.trial-notice-content p{color:#92400e;font-size:.9rem;line-height:1.5;margin:0}.waitlist-banner-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2)!important;border:none!important;color:#fff!important;display:inline-flex;font-size:.9rem;font-weight:600;gap:8px;margin-top:12px;padding:8px 18px;transition:transform .2s,box-shadow .2s}.waitlist-banner-button:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}@media (max-width:640px){.trial-notice-banner{padding:10px 16px}.trial-notice-content p{font-size:.85rem}}.draft-label-d{background:linear-gradient(135deg,#7c3aed,#3b82f6);border-radius:20px;box-shadow:0 4px 12px #7c3aed4d;color:#fff;font-size:.85rem;font-weight:600;padding:8px 16px;position:fixed;right:20px;top:20px;z-index:1000}.draft-d{background:linear-gradient(180deg,#f5f3ff,#fff,#eff6ff);min-height:100vh}.hero-section-d{background:linear-gradient(135deg,#667eea,#764ba2 50%,#6b46c1);overflow:hidden;padding:60px 20px 50px;position:relative;text-align:center}.hero-bg-orb{animation:heroFloat 20s ease-in-out infinite;border-radius:50%;filter:blur(80px);opacity:.4;position:absolute}.hero-bg-orb-1{animation-delay:0s;background:#a855f7;height:600px;right:-100px;top:-200px;width:600px}.hero-bg-orb-2{animation-delay:-10s;background:#3b82f6;bottom:-100px;height:400px;left:-100px;width:400px}.hero-bg-orb-3{animation-delay:-5s;background:#ec4899;height:300px;left:50%;top:50%;width:300px}@keyframes heroFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}.hero-section-d:before{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23a)'/%3E%3C/svg%3E");bottom:0;content:"";left:0;opacity:.03;pointer-events:none;position:absolute;right:0;top:0}.hero-content-d{margin:0 auto;max-width:800px;position:relative;z-index:1}.brand-prominent{margin-bottom:32px}.brand-logo{color:#fff;display:block;font-size:3.5rem;font-weight:800;letter-spacing:-2px;margin-bottom:8px;text-shadow:0 4px 20px #0003}.brand-subtitle{color:#fffffff2;display:block;font-size:1.4rem;font-style:italic;font-weight:400;margin-bottom:12px}.brand-tagline{color:#ffffffe6;display:block;font-size:1.1rem;font-weight:500;letter-spacing:2px;text-transform:uppercase}.brand-small-header{color:#fffc;font-size:1rem;font-weight:600;letter-spacing:2px;margin-bottom:24px}.hero-main-headline{color:#fff;font-size:3.5rem;font-weight:800;line-height:1.1;margin-bottom:20px;text-shadow:0 4px 20px #00000026}.hero-main-headline-large{font-size:4rem}.hero-main-headline-large,.hero-main-headline-xl{color:#fff;font-weight:800;line-height:1.05;margin-bottom:24px;text-shadow:0 4px 20px #00000026}.hero-main-headline-xl{font-size:4.5rem}.hero-headline-addon,.hero-tagline-light{color:#ffffffe6;font-size:1.4rem;font-style:italic;font-weight:400;margin-bottom:28px}.hero-tagline-bold{color:#fff;font-size:1.6rem;font-style:italic;font-weight:500;margin-bottom:32px;text-shadow:0 2px 10px #00000026}.hero-tagline-subtle{color:#fffc;font-size:1.3rem;font-style:italic;font-weight:400;margin-bottom:32px}.pain-point-strip{background:#1f2937;padding:20px 24px;text-align:center}.pain-point-strip p{color:#ffffffe6;font-size:1.1rem;line-height:1.5;margin:0}.pain-point-strip strong{color:#fff}.how-it-works-section{background:#f9fafb;padding:60px 24px;text-align:center}.how-it-works-section h2{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:40px}.how-it-works-steps{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;margin:0 auto;max-width:1000px}.step-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;flex:1 1;max-width:320px;min-width:260px;padding:32px 24px;text-align:center}.step-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:48px;justify-content:center;margin:0 auto 20px;width:48px}.step-card h3{color:#1f2937;font-size:1.15rem;font-weight:600;margin-bottom:12px}.step-card p{color:#6b7280;font-size:.95rem;line-height:1.6;margin:0}.hero-value-prop{color:#fffffff2;font-size:1.15rem;line-height:1.6;margin:0 auto;max-width:600px}.hero-value-prop-sm{color:#fffffffa;font-size:1.1rem;line-height:1.6;margin:0 auto;max-width:550px}.hero-value-prop-secondary{color:#ffffffd9;font-size:1rem;line-height:1.5;margin:12px auto 0;max-width:500px}.hero-screenshot{margin:32px auto;max-width:500px;padding:0 20px}.hero-screenshot img{border-radius:12px;box-shadow:0 20px 60px #0000004d,0 8px 20px #0003;width:100%}.hero-screenshot-section{margin:36px auto;max-width:420px;padding:0 20px}.hero-screenshot-heading{color:#fff9;font-size:.85rem;font-weight:500;letter-spacing:2px;margin-bottom:20px;text-transform:uppercase}.hero-screenshots{display:flex;flex-direction:column;gap:16px}.hero-screenshot-img{border-radius:12px;box-shadow:0 16px 50px #0000004d,0 6px 16px #0003;width:100%}.hero-screenshots-premium{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff1f;border-radius:24px;box-shadow:0 8px 32px #0000001a;display:flex;flex-direction:column;gap:16px;padding:20px}.hero-screenshot-main{border-radius:16px;box-shadow:0 25px 60px #00000059,0 10px 24px #00000040;width:100%}.hero-screenshot-feedback{border-radius:12px;box-shadow:0 12px 40px #0000004d,0 6px 16px #0003;width:100%}.device-mockup{display:flex;justify-content:center;margin-bottom:8px}.device-frame{background:#1a1a1a;border-radius:32px;box-shadow:0 30px 80px #0006,0 15px 35px #0000004d,inset 0 1px 0 #ffffff1a;padding:12px;position:relative}.device-notch{background:#333;border-radius:3px;height:6px;margin:0 auto 10px;width:80px}.device-screen{border-radius:20px;display:block;width:100%}.feedback-cards-stack{display:flex;flex-direction:column;gap:10px;padding:0 10px;position:relative}.hero-trust-line{align-items:center;color:#fffc;display:flex;font-size:.95rem;gap:8px;justify-content:center;margin-bottom:0;margin-top:28px}.hero-trust-line:after,.hero-trust-line:before{background:#ffffff4d;content:"";height:1px;width:40px}.hero-premium-row{grid-gap:28px;align-items:center;display:grid;gap:28px;grid-template-columns:1fr 1.3fr 1fr;margin:40px auto 0;max-width:1200px;padding:0 20px}.hero-feedback-card{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#ffffff1f;border:1px solid #fff3;border-radius:24px;box-shadow:0 8px 32px #0000001f,inset 0 1px 0 #fff3;overflow:hidden;padding:28px;position:relative;text-align:left;transition:all .4s ease}.hero-feedback-card:hover{border-color:#ffffff4d;box-shadow:0 20px 50px #0003,inset 0 1px 0 #ffffff4d;transform:translateY(-4px)}.hero-feedback-card:before{border-radius:24px 24px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.hero-strength-card{transform:translateY(20px)}.hero-strength-card:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.hero-improve-card{transform:translateY(20px)}.hero-improve-card:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.hero-improve-card:hover,.hero-strength-card:hover{transform:translateY(16px)}.hero-feedback-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.hero-feedback-icon{align-items:center;border-radius:12px;box-shadow:0 4px 12px #00000026;display:flex;height:40px;justify-content:center;width:40px}.hero-feedback-icon.strength-icon{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff}.hero-feedback-icon.improve-icon{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.hero-feedback-header h3{color:#fff;font-size:.9rem;font-weight:700;letter-spacing:1.5px;margin:0;text-transform:uppercase}.hero-feedback-card p{color:#ffffffe6;font-size:.95rem;line-height:1.7;margin:0}.feedback-highlight{border-radius:6px;font-weight:600;padding:3px 8px}.feedback-highlight.strength-highlight{background:#fbbf244d;color:#fef3c7}.feedback-highlight.improve-highlight{background:#a78bfa4d;color:#ede9fe}.hero-writing-sample{background:#fff;border-radius:24px;box-shadow:0 25px 60px #00000040,0 10px 20px #0000001a;padding:28px;position:relative;z-index:5}.hero-writing-sample:before{background:linear-gradient(135deg,#667eea,#764ba2,#ec4899);border-radius:27px;bottom:-3px;content:"";left:-3px;opacity:.6;position:absolute;right:-3px;top:-3px;z-index:-1}.hero-writing-header{align-items:center;border-bottom:2px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.hero-writing-header h4{align-items:center;color:#1f2937;display:flex;font-size:1rem;font-weight:700;gap:10px;margin:0}.hero-writing-header h4 svg{color:#667eea}.hero-word-count{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:20px;color:#6b7280;font-size:.85rem;font-weight:500;padding:6px 14px}.hero-writing-content{color:#374151;font-size:1rem;line-height:1.9;text-align:left}.hero-writing-content .text-strength{background:linear-gradient(120deg,#fef3c7,#fde68a);border-radius:6px;box-shadow:0 2px 4px #fbbf2433;padding:3px 6px}.hero-writing-content .text-improve{background:linear-gradient(120deg,#ede9fe,#ddd6fe);border-radius:6px;box-shadow:0 2px 4px #8b5cf633;padding:3px 6px}.hero-writing-legend{border-top:2px solid #f3f4f6;display:flex;gap:24px;justify-content:center;margin-top:16px;padding-top:12px}.hero-writing-legend .legend-item{align-items:center;color:#6b7280;display:flex;font-size:.85rem;font-weight:500;gap:10px}.hero-writing-legend .legend-dot{border-radius:4px;box-shadow:0 2px 6px #00000026;height:14px;width:14px}.hero-writing-legend .legend-dot.gold{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.hero-writing-legend .legend-dot.purple{background:linear-gradient(135deg,#a78bfa,#8b5cf6)}.nz-badge-subtle{align-items:center;background:#ffffff26;border-radius:20px;color:#ffffffd9;display:inline-flex;font-size:.8rem;gap:6px;margin-top:8px;padding:6px 14px}.nz-badge-subtle .nz-flag{font-size:1rem}.hero-section-d h1{color:#fff;font-size:2.5rem;font-weight:700;line-height:1.2;margin-bottom:20px}.hero-subtitle-d{color:#ffffffe6;font-size:1.2rem;line-height:1.6;margin-bottom:40px}.hero-stats-d{display:flex;gap:48px;justify-content:center;margin-bottom:40px}.stat-item-d{text-align:center}.stat-number-d{color:#fff;display:block;font-size:2.5rem;font-weight:800}.stat-label-d{color:#fffc;font-size:.9rem}.hero-cta-d{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.primary-btn-d{align-items:center;background:#fff!important;border-radius:50px!important;box-shadow:0 4px 14px #00000026;color:#7c3aed!important;display:flex;font-weight:600;gap:8px;padding:14px 28px;transition:all .3s cubic-bezier(.4,0,.2,1)}.primary-btn-d:hover{background:#f8fafc!important;box-shadow:0 12px 28px #00000040;transform:translateY(-3px)}.primary-btn-d:active{box-shadow:0 6px 16px #0003;transform:translateY(-1px)}.secondary-btn-d{border-color:#fff!important;color:#fff!important;padding:14px 28px}.secondary-btn-d:hover{background:#ffffff1a!important}.hero-cta-d .btn-outline,.hero-cta-d button[variant=outline]{border-radius:50px!important;transition:all .3s cubic-bezier(.4,0,.2,1)}.hero-cta-d button[variant=outline]:hover{background:#ffffff26!important;box-shadow:0 8px 20px #00000026;transform:translateY(-2px)}.outline-btn-d{align-items:center!important;display:flex!important;gap:8px!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important}.outline-btn-d:hover{background:#ffffff26!important;box-shadow:0 8px 20px #00000026;transform:translateY(-2px)}.hero-trust-d{color:#fffc;font-size:.9rem}.expert-section{background:#fff;padding:50px 20px}.expert-content{margin:0 auto;max-width:800px;text-align:center}.expert-icon-wrapper{align-items:center;background:linear-gradient(135deg,#7c3aed,#3b82f6);border-radius:50%;box-shadow:0 8px 32px #7c3aed4d;color:#fff;display:flex;height:100px;justify-content:center;margin:0 auto 24px;width:100px}.expert-section h2{color:#1e1b4b;font-size:2rem;margin-bottom:20px}.expert-description{color:#4c1d95;font-size:1.2rem;font-weight:500;line-height:1.8;margin-bottom:40px}.expert-features{display:flex;flex-wrap:wrap;gap:40px;justify-content:center}.expert-feature{align-items:center;background:linear-gradient(135deg,#f5f3ff,#eff6ff);border-radius:30px;color:#5b21b6;display:flex;font-weight:600;gap:12px;padding:16px 24px}.expert-feature svg{color:#7c3aed}.problems-section-d{background:linear-gradient(135deg,#f5f3ff,#eff6ff);padding:80px 20px 50px}.problems-section-d h2{color:#1e1b4b;font-size:2rem;margin-bottom:48px;text-align:center}.problems-grid-d{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1000px}.problem-card-d{align-items:center;background:#fff;border:1px solid #e9d5ff;display:flex;gap:20px;padding:24px}.problem-side-d,.solution-side-d{flex:1 1;text-align:center}.side-label-d{color:#94a3b8;display:block;font-size:.75rem;font-weight:600;margin-bottom:12px;text-transform:uppercase}.problem-icon-d svg,.problem-side-d{color:#dc2626}.solution-icon-d,.solution-side-d{color:#7c3aed}.arrow-divider-d{color:#7c3aed;font-size:1.5rem}.features-section-d{background:linear-gradient(180deg,#f8fafc,#f0f9ff);padding:16px 20px 30px}.features-section-d h2{color:#1e1b4b;font-size:2rem;margin-bottom:12px;text-align:center}.section-subtitle-d{color:#64748b;margin-bottom:48px;text-align:center}.features-grid-d{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:900px}.feature-card-d{background:#fff;border:1px solid #e9d5ff;border-radius:12px;padding:24px;text-align:center;transition:all .3s ease}.feature-card-d:hover{border-color:#7c3aed;box-shadow:0 12px 24px #7c3aed26;transform:translateY(-4px)}.feature-icon-d{color:#7c3aed;height:48px;margin:0 auto 16px;width:48px}.feature-icon-d svg{height:100%;width:100%}.feature-card-d h3{color:#1e1b4b;font-size:1rem;margin-bottom:8px}.feature-card-d p{color:#64748b;font-size:.85rem;line-height:1.4}.audience-section-d{background:linear-gradient(135deg,#f5f3ff,#eff6ff);padding:80px 20px}.audience-section-d h2{color:#1e1b4b;font-size:2rem;margin-bottom:40px;text-align:center}.audience-tabs-d{display:flex;gap:16px;justify-content:center;margin-bottom:40px}.audience-tabs-d button{background:#fff;border:2px solid #c4b5fd;border-radius:30px;color:#5b21b6;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .2s}.audience-tabs-d button.active{background:linear-gradient(135deg,#7c3aed,#3b82f6);border-color:#0000;color:#fff}.audience-tabs-d button:hover:not(.active){background:#f5f3ff;border-color:#7c3aed}.audience-content-d{background:#fff;border:1px solid #e9d5ff;border-radius:16px;box-shadow:0 4px 20px #7c3aed1a;margin:0 auto;max-width:600px;padding:40px;text-align:center}.audience-content-d h3{color:#1e1b4b;font-size:1.8rem;margin-bottom:24px}.audience-content-d ul{list-style:none;margin:0 0 32px;padding:0;text-align:left}.audience-content-d li{align-items:center;border-bottom:1px solid #f5f3ff;color:#475569;display:flex;gap:12px;padding:12px 0}.audience-content-d li svg{color:#7c3aed;flex-shrink:0}.audience-cta-d{align-items:center;background:linear-gradient(135deg,#7c3aed,#3b82f6)!important;color:#fff!important;display:flex;gap:8px;margin:0 auto}.testimonials-section-d{background:#fff;padding:80px 20px}.testimonials-section-d h2{color:#1e1b4b;font-size:2rem;margin-bottom:48px;text-align:center}.testimonials-grid-d{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.testimonial-card-d{background:linear-gradient(135deg,#faf5ff,#f5f3ff);border:1px solid #e9d5ff;padding:32px;text-align:center}.stars-d{font-size:1.5rem;margin-bottom:16px}.testimonial-card-d p{color:#475569;font-style:italic;line-height:1.6;margin-bottom:16px}.author-d{color:#7c3aed;font-size:.9rem;font-weight:500}.final-cta-d{background:linear-gradient(135deg,#7c3aed,#6366f1 50%,#3b82f6);padding:60px 20px 50px;position:relative;text-align:center}.cta-content-d{margin:0 auto;max-width:600px;position:relative;z-index:1}.cta-brand,.final-cta-d h2{margin-bottom:16px}.final-cta-d h2{color:#fff;font-size:2rem}.final-cta-d p{color:#ffffffe6;font-size:1.1rem;margin-bottom:32px}.final-cta-btn{display:inline-flex;font-size:1.1rem;padding:16px 32px}.trust-text-d{margin-top:16px}.draft-navigation-d{background:#1e1b4b;display:flex;gap:16px;justify-content:center;padding:40px 20px}.draft-navigation-d button{border-color:#ffffff4d;color:#fff}.draft-navigation-d button:hover{background:#ffffff1a;border-color:#fff}@media (max-width:1024px){.features-grid-d{grid-template-columns:repeat(3,1fr);max-width:700px}.testimonials-grid-d{grid-template-columns:repeat(2,1fr)}.problems-grid-d{grid-template-columns:1fr}}@media (max-width:768px){.brand-logo{font-size:2.5rem}.hero-bg-orb{display:none}.hero-section-d{align-items:flex-start;display:flex;margin-top:-1px;min-height:auto;padding:32px 16px 40px}.hero-content-d{padding-top:24px}.hero-premium-row{gap:16px;grid-template-columns:1fr;margin:32px auto 0;padding:0}.hero-improve-card,.hero-strength-card{transform:translateY(0)}.hero-improve-card:hover,.hero-strength-card:hover{transform:translateY(-4px)}.hero-feedback-card{border-radius:20px;padding:20px}.hero-feedback-header{margin-bottom:12px}.hero-feedback-icon{border-radius:10px;height:36px;width:36px}.hero-feedback-header h3{font-size:.8rem}.hero-feedback-card p{font-size:.9rem;line-height:1.6}.hero-writing-sample{border-radius:20px;order:-1;padding:20px}.hero-writing-sample:before{border-radius:23px}.hero-writing-header h4{font-size:.95rem}.hero-word-count{font-size:.8rem;padding:4px 10px}.hero-writing-content{font-size:.95rem;line-height:1.8}.hero-writing-legend{gap:16px}.hero-writing-legend .legend-item{font-size:.8rem}.hero-writing-legend .legend-dot{height:12px;width:12px}.hero-trust-line{font-size:.85rem;line-height:1.5;margin-top:32px;padding:0 8px}.hero-trust-line:after,.hero-trust-line:before{width:20px}.brand-small-header{font-size:1rem;letter-spacing:4px;margin-bottom:32px}.hero-main-headline{font-size:3rem;line-height:1.1;margin-bottom:32px}.hero-main-headline-large{font-size:3.2rem;line-height:1.08;margin-bottom:28px}.hero-main-headline-xl{font-size:2.5rem;line-height:1.15;margin-bottom:20px}.hero-value-prop-sm{font-size:1rem;padding:0 8px}.hero-value-prop-secondary{font-size:.9rem;margin-top:10px;padding:0 8px}.hero-screenshot{margin:28px auto;max-width:100%;padding:0 16px}.hero-screenshot img{border-radius:10px}.hero-screenshot-section{margin:32px auto;max-width:100%;padding:0 20px}.hero-screenshot-heading{font-size:.8rem;letter-spacing:2px}.hero-screenshots{gap:12px}.hero-screenshot-img{border-radius:10px}.hero-screenshots-premium{gap:10px}.hero-screenshot-main{border-radius:14px}.hero-screenshot-feedback{border-radius:10px}.device-frame{border-radius:28px;padding:10px}.device-notch{height:5px;margin-bottom:8px;width:60px}.device-screen{border-radius:18px}.feedback-cards-stack{gap:8px}.hero-tagline-light{font-size:1.5rem;margin-bottom:40px}.hero-tagline-bold{font-size:1.6rem;margin-bottom:44px}.hero-tagline-subtle{font-size:1.15rem;margin-bottom:24px;margin-top:28px}.pain-point-strip{padding:18px 20px}.pain-point-strip p{font-size:1rem}.how-it-works-section{padding:48px 20px}.how-it-works-section h2{font-size:1.6rem;margin-bottom:32px}.how-it-works-steps{align-items:center;flex-direction:column;gap:20px}.step-card{max-width:100%;min-width:100%;padding:28px 20px}.hero-value-prop{font-size:1.25rem;line-height:1.7;margin-bottom:12px;padding:0 4px}.hero-cta-d{margin-bottom:0;margin-top:0!important}.hero-section-d h1{font-size:1.8rem}.hero-stats-d{flex-direction:column;gap:24px}.hero-cta-d{flex-direction:row;flex-wrap:nowrap;gap:10px}.hero-cta-d button{font-size:.9rem!important;min-width:140px!important;padding:10px 16px!important}.features-grid-d{grid-template-columns:repeat(2,1fr);max-width:500px}.audience-tabs-d{flex-direction:column}.testimonials-grid-d{grid-template-columns:1fr}.expert-features{flex-direction:column;gap:16px}.expert-feature{justify-content:center}.draft-navigation-d{flex-direction:column}}@media (max-width:480px){.features-grid-d{grid-template-columns:1fr}.problem-card-d{flex-direction:column}.arrow-divider-d{transform:rotate(90deg)}}.header-d{background:#fff;box-shadow:0 2px 10px #0000000d;padding:12px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-content-d{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.logo-d{color:#7c3aed;font-size:1.5rem;font-weight:800;letter-spacing:-1px}.header-actions-d{align-items:center;display:flex;gap:12px}.header-actions-d button{font-weight:500}.signup-btn-header{background:linear-gradient(135deg,#7c3aed,#3b82f6)!important;color:#fff!important}.signup-btn-header:hover{opacity:.9}.nz-badge{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border:1px solid #ffffff4d;border-radius:20px;color:#fff;display:inline-flex;font-size:.9rem;gap:8px;margin-bottom:16px;padding:8px 16px}.nz-flag{font-size:1.2rem}.how-it-works-d{background:linear-gradient(135deg,#f5f3ff,#eff6ff);padding:50px 20px}.how-it-works-d h2{color:#1e1b4b;font-size:2rem;margin-bottom:12px;text-align:center}.steps-container-d{align-items:center;display:flex;flex-wrap:wrap;gap:32px;justify-content:center;margin:0 auto;max-width:1000px}.step-d{background:#fff;border:1px solid #e9d5ff;border-radius:16px;box-shadow:0 4px 20px #7c3aed1a;max-width:250px;padding:32px 24px;position:relative;text-align:center}.step-number-d{align-items:center;background:linear-gradient(135deg,#7c3aed,#3b82f6);border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:700;height:32px;justify-content:center;left:50%;position:absolute;top:-16px;transform:translateX(-50%);width:32px}.step-d svg{color:#7c3aed;margin-bottom:16px}.step-d h3{color:#1e1b4b;font-size:1.1rem;margin-bottom:8px}.step-d p{color:#64748b;font-size:.9rem;line-height:1.5}.step-arrow-d{color:#7c3aed;font-size:2rem;font-weight:700}.steps-cta{display:flex;justify-content:center;margin-top:40px;text-align:center;width:100%}.community-section-d{background:#fff;padding:30px 20px 50px}.community-section-d h2{color:#1e1b4b;font-size:2rem;margin-bottom:32px;text-align:center}.community-cards-d{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1200px}.community-card-d{background:#fff;border:1px solid #e9d5ff;border-radius:16px;padding:32px;transition:all .3s ease}.community-card-d:hover{box-shadow:0 12px 24px #7c3aed26;transform:translateY(-4px)}.community-card-d.teachers{border-top:4px solid #7c3aed}.community-card-d.students{border-top:4px solid #3b82f6}.community-card-d.parents{border-top:4px solid #10b981}.card-header-d{align-items:center;display:flex;gap:12px;margin-bottom:20px}.emoji-d{font-size:2rem}.card-header-d h3{color:#1e1b4b;font-size:1.3rem;margin:0}.community-card-d ul{list-style:none;margin:0 0 24px;padding:0}.community-card-d li{align-items:center;border-bottom:1px solid #f5f3ff;color:#475569;display:flex;font-size:.95rem;gap:10px;padding:10px 0}.community-card-d li:last-child{border-bottom:none}.community-card-d li svg{color:#7c3aed;flex-shrink:0}.community-card-d button{background:linear-gradient(135deg,#7c3aed,#6366f1)!important;border:none!important;color:#fff!important;width:100%}.emotional-section-d{background:linear-gradient(135deg,#faf5ff,#f5f3ff);padding:40px 20px}.emotional-content-d{margin:0 auto;max-width:700px;text-align:center}.emotional-section-d h2{color:#1e1b4b;font-size:1.8rem;margin-bottom:16px}.emotional-section-d p{color:#475569;font-size:1.1rem;line-height:1.8;margin-bottom:16px}.emphasis-d{color:#7c3aed;font-size:1.15rem}.final-section-d{background:linear-gradient(135deg,#7c3aed,#6366f1 50%,#3b82f6)}.final-cta-content-d{margin:0 auto;max-width:600px;padding:50px 20px 40px;text-align:center}.cta-brand{color:#fff;display:block;font-size:2.5rem;font-weight:800;letter-spacing:-2px;margin-bottom:12px}.final-section-d h2{color:#fff;font-size:2rem;margin-bottom:16px}.final-section-d p{color:#ffffffe6;font-size:1.1rem;margin-bottom:32px}.final-buttons-d{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.final-cta-btn{align-items:center;background:#fff!important;color:#7c3aed!important;display:flex;font-weight:600;gap:8px;padding:14px 28px}.final-cta-btn:hover{background:#f8fafc!important;box-shadow:0 8px 20px #0003;transform:translateY(-2px)}.final-secondary-btn{border-color:#fff!important;color:#fff!important}.final-secondary-btn:hover{background:#ffffff1a!important}.trust-text-d{color:#fffc;font-size:.9rem;margin-bottom:0}.footer-d{background:#1e1b4b;padding:30px 20px}.footer-content-d{margin:0 auto;max-width:1200px;text-align:center}.footer-links-d{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:20px}.footer-link-d{color:#fffc;font-size:.9rem;text-decoration:none;transition:color .2s}.footer-link-d:hover{color:#fff}.footer-separator-d{color:#fff6}.footer-copyright-d{color:#fff9;font-size:.85rem}@media (max-width:1024px){.community-cards-d{grid-template-columns:1fr;max-width:500px}.steps-container-d{flex-direction:column}.step-arrow-d{transform:rotate(90deg)}}@media (max-width:768px){.header-d{padding:10px 16px}.header-actions-d{gap:6px}.header-actions-d button{font-size:.75rem;padding:6px 10px}.header-actions-d button svg{display:none}.final-buttons-d,.footer-links-d{flex-direction:column}.footer-links-d{gap:12px}.footer-separator-d{display:none}}@media (max-width:480px){.header-actions-d{gap:4px}.header-actions-d button{font-size:.7rem;padding:5px 8px}.logo-d{font-size:1.2rem}}.two-modes-section{background:linear-gradient(180deg,#f8fafc,#fff);padding:20px 24px 16px}.two-modes-section h2{color:#1f2937;font-size:2.25rem;font-weight:700;margin:0 0 16px;text-align:center}.two-modes-section .section-subtitle-d{color:#6b7280;font-size:1.1rem;line-height:1.6;margin:0 auto 48px;max-width:700px;text-align:center}.modes-container{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(2,1fr);margin:0 auto;max-width:1000px}.mode-card{border:2px solid #0000;border-radius:20px;overflow:hidden;padding:32px;position:relative;transition:all .3s ease}.mode-card:before{content:"";height:6px;left:0;position:absolute;right:0;top:0}.mode-card.teacher-mode{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border-color:#c4b5fd}.mode-card.teacher-mode:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.mode-card.student-mode{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-color:#86efac}.mode-card.student-mode:before{background:linear-gradient(90deg,#22c55e,#4ade80)}.mode-card:hover{box-shadow:0 12px 40px #0000001f;transform:translateY(-4px)}.mode-header{margin-bottom:20px;text-align:center}.mode-icon{align-items:center;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 16px;width:80px}.mode-icon.teacher-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.mode-icon.student-icon{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.mode-header h3{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0 0 8px}.mode-badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:600;padding:4px 12px}.teacher-mode .mode-badge{background:#ede9fe;color:#7c3aed}.student-mode .mode-badge{background:#dcfce7;color:#16a34a}.mode-description{color:#4b5563;font-size:1rem;line-height:1.6;margin:0 0 24px;text-align:center}.mode-features{list-style:none;margin:0 0 24px;padding:0}.mode-features li{align-items:center;border-bottom:1px solid #0000000f;color:#374151;display:flex;font-size:.95rem;gap:12px;padding:10px 0}.mode-features li:last-child{border-bottom:none}.teacher-mode .mode-features li svg{color:#8b5cf6;flex-shrink:0}.student-mode .mode-features li svg{color:#22c55e;flex-shrink:0}.mode-use-case{background:#ffffffb3;border-radius:12px;color:#4b5563;font-size:.9rem;padding:14px 18px}.mode-use-case strong{color:#1f2937}.modes-summary{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:16px;margin:32px auto 0;max-width:800px;padding:24px 32px;text-align:center}.modes-summary p{color:#78350f;font-size:1rem;line-height:1.6;margin:0}.modes-summary strong{color:#92400e}@media (max-width:768px){.two-modes-section{padding:60px 16px 16px}.two-modes-section h2{font-size:1.75rem}.two-modes-section .section-subtitle-d{font-size:1rem}.modes-container{gap:24px;grid-template-columns:1fr}.mode-card{padding:24px}.mode-icon{height:64px;width:64px}.mode-icon svg{height:32px;width:32px}.mode-header h3{font-size:1.25rem}.modes-summary{margin-top:24px;padding:20px 24px}.modes-summary p{font-size:.95rem}.features-section-d{padding:16px 20px 50px}}.family-view-info-page{background:#f8fafc;min-height:100vh}.fv-header{background:#fff;box-shadow:0 2px 10px #0000000d;padding:12px 20px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.fv-header-content{justify-content:space-between;margin:0 auto;max-width:1200px}.back-btn,.fv-header-content{align-items:center;display:flex}.back-btn{gap:8px}.fv-logo{color:#7c3aed;cursor:pointer;font-size:1.5rem;font-weight:800}.fv-header-actions{display:flex;gap:12px}.fv-header-actions button:last-child{background:linear-gradient(135deg,#7c3aed,#3b82f6);color:#fff}.fv-hero{background:linear-gradient(135deg,#10b981,#059669 50%,#047857);color:#fff;padding:80px 20px;text-align:center}.fv-hero-content{margin:0 auto;max-width:700px}.fv-badge{align-items:center;background:#fff3;border-radius:20px;display:inline-flex;font-size:.9rem;gap:8px;margin-bottom:24px;padding:8px 16px}.fv-hero h1{font-size:3rem;font-weight:800;margin-bottom:20px}.fv-hero-subtitle{font-size:1.2rem;line-height:1.6;margin-bottom:32px;opacity:.95}.fv-hero-cta button{align-items:center;background:#fff!important;color:#059669!important;display:inline-flex;font-weight:600;gap:8px}.fv-what-is{background:#fff;padding:60px 20px}.fv-what-is-content{grid-gap:60px;align-items:center;display:grid;gap:60px;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1100px}.fv-what-is-text h2{color:#1e1b4b;font-size:2rem;margin-bottom:20px}.fv-what-is-text p{color:#475569;line-height:1.8;margin-bottom:16px}.fv-screen-mockup{background:#1e1b4b;border-radius:16px;box-shadow:0 20px 40px #0003;overflow:hidden}.mockup-header{background:#2d2a5b;display:flex;gap:8px;padding:12px 16px}.mockup-header .dot{background:#4c4980;border-radius:50%;height:12px;width:12px}.mockup-content{padding:24px;text-align:center}.mockup-title{color:#fff;font-size:1.2rem;margin-bottom:24px}.mockup-chart{align-items:flex-end;display:flex;gap:12px;height:120px;justify-content:center;margin-bottom:16px}.chart-bar{background:linear-gradient(180deg,#10b981,#059669);border-radius:4px 4px 0 0;width:40px}.mockup-label{color:#ffffffb3;font-size:.9rem}.fv-how-to{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);padding:60px 20px}.fv-how-to h2{color:#1e1b4b;font-size:2rem;margin-bottom:12px;text-align:center}.fv-section-subtitle{color:#64748b;margin-bottom:48px;text-align:center}.fv-steps{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(4,1fr);margin:0 auto 40px;max-width:1000px}.fv-step{background:#fff;border-radius:16px;box-shadow:0 4px 12px #0000000d;padding:24px;text-align:center}.fv-step-number{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;color:#fff;display:flex;font-weight:700;height:40px;justify-content:center;margin:0 auto 16px;width:40px}.fv-step h3{color:#1e1b4b;font-size:1.1rem;margin-bottom:8px}.fv-step p{color:#64748b;font-size:.9rem;line-height:1.5}.fv-pin-note{align-items:flex-start;background:#fff;border-left:4px solid #10b981;border-radius:12px;display:flex;gap:16px;margin:0 auto;max-width:600px;padding:20px}.fv-pin-note svg{color:#10b981;flex-shrink:0;margin-top:2px}.fv-pin-note p{color:#475569;font-size:.95rem;line-height:1.6;margin:0}.fv-features{background:#fff;padding:60px 20px}.fv-features h2{color:#1e1b4b;font-size:2rem;margin-bottom:12px;text-align:center}.fv-features-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1000px}.fv-feature-card{border:1px solid #d1fae5;border-radius:16px;padding:28px;text-align:center;transition:all .3s ease}.fv-feature-card:hover{border-color:#10b981;box-shadow:0 12px 24px #10b98126;transform:translateY(-4px)}.fv-feature-icon{color:#10b981;margin-bottom:16px}.fv-feature-card h3{color:#1e1b4b;font-size:1.1rem;margin-bottom:8px}.fv-feature-card p{color:#64748b;font-size:.9rem;line-height:1.5}.fv-showcase{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);padding:60px 20px}.fv-showcase h2{color:#1e1b4b;font-size:2rem;margin-bottom:48px;text-align:center}.fv-showcase-grid{grid-gap:32px;display:grid;gap:32px;grid-template-columns:repeat(3,1fr);margin:0 auto;max-width:1000px}.fv-showcase-item{text-align:center}.fv-showcase-mockup{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 12px #00000014;margin-bottom:20px;padding:20px}.showcase-header{color:#1e1b4b;font-size:.95rem;font-weight:600;margin-bottom:16px}.showcase-content{min-height:100px}.phase-indicator{align-items:center;color:#64748b;display:flex;font-size:1.2rem;gap:12px;justify-content:center;margin-bottom:12px}.phase-indicator .highlight{color:#10b981;font-weight:700}.phase-indicator .arrow{color:#10b981}.growth-badge{background:#d1fae5;border-radius:20px;color:#059669;display:inline-block;font-size:.85rem;font-weight:600;padding:6px 12px}.goal-item{align-items:center;color:#64748b;display:flex;font-size:.9rem;gap:8px;padding:8px 0}.goal-item.done,.goal-item.done svg{color:#10b981}.feedback-highlight{border-radius:8px;font-size:.85rem;margin-bottom:8px;padding:10px 14px}.feedback-highlight.gold{background:#fef3c7;color:#92400e}.feedback-highlight.pink{background:#fce7f3;color:#9d174d}.fv-showcase-item h3{color:#1e1b4b;font-size:1.1rem;margin-bottom:8px}.fv-showcase-item p{color:#64748b;font-size:.9rem;line-height:1.5}.fv-benefits{background:#fff;padding:60px 20px}.fv-benefits-content{margin:0 auto;max-width:800px}.fv-benefits h2{color:#1e1b4b;font-size:2rem;margin-bottom:40px;text-align:center}.fv-benefits-list{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr)}.fv-benefit{background:#f0fdf4;border-radius:12px;display:flex;gap:16px;padding:20px}.fv-benefit svg{color:#10b981;flex-shrink:0}.fv-benefit h3{color:#1e1b4b;font-size:1rem;margin-bottom:4px}.fv-benefit p{color:#64748b;font-size:.9rem;line-height:1.5;margin:0}.fv-cta{background:linear-gradient(135deg,#10b981,#059669 50%,#047857);color:#fff;padding:80px 20px;text-align:center}.fv-cta-content{margin:0 auto;max-width:600px}.fv-cta svg{margin-bottom:24px;opacity:.9}.fv-cta h2{font-size:2rem;margin-bottom:16px}.fv-cta p{font-size:1.1rem;margin-bottom:24px;opacity:.95}.fv-cta button{align-items:center;background:#fff!important;color:#059669!important;display:inline-flex;font-weight:600;gap:8px}.fv-cta-note{font-size:.9rem;margin-top:16px;opacity:.8}.fv-footer{background:#1e1b4b;padding:32px 20px;text-align:center}.fv-footer-content{margin:0 auto;max-width:1200px}.fv-footer-links{display:flex;gap:12px;justify-content:center;margin-bottom:16px}.fv-footer-links a{color:#fffc;font-size:.9rem;text-decoration:none}.fv-footer-links a:hover{color:#fff}.fv-footer-links span{color:#fff6}.fv-footer p{color:#fff9;font-size:.85rem;margin:0}@media (max-width:1024px){.fv-what-is-content{gap:40px;grid-template-columns:1fr}.fv-features-grid,.fv-steps{grid-template-columns:repeat(2,1fr)}.fv-showcase-grid{grid-template-columns:1fr;max-width:400px}}@media (max-width:768px){.fv-header-actions{display:none}.fv-hero h1{font-size:2rem}.fv-steps{margin:0 auto 40px}.fv-features-grid,.fv-steps{grid-template-columns:1fr;max-width:400px}.fv-benefits-list{grid-template-columns:1fr}.fv-footer-links{flex-direction:column;gap:8px}.fv-footer-links span{display:none}}.fullscreen-help-overlay{animation:overlayFadeIn .3s ease;bottom:0;display:flex;flex-direction:column;left:0;position:fixed;right:0;top:0;z-index:9999}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.fullscreen-help-overlay.light{background:linear-gradient(135deg,#f8fafc,#e0e7ff);color:#1f2937}.fullscreen-help-overlay.dark{background:linear-gradient(135deg,#1e1b4b,#0f172a);color:#f1f5f9}.fsh-header{border-bottom:1px solid #0000001a;display:flex;flex-direction:column;gap:16px;padding:16px 24px}.fullscreen-help-overlay.dark .fsh-header{border-bottom-color:#ffffff1a}.fsh-header-top{align-items:center;display:flex;justify-content:space-between}.fsh-goal-banner{align-items:center;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border:2px solid #c7d2fe;border-radius:12px;display:flex;gap:16px;padding:16px 20px}.fullscreen-help-overlay.dark .fsh-goal-banner{background:linear-gradient(135deg,#6366f126,#4f46e533);border-color:#818cf84d}.fsh-goal-banner .goal-number-badge{align-items:center;background:linear-gradient(135deg,#818cf8,#6366f1);border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:44px;justify-content:center;min-width:44px}.fsh-goal-banner .goal-text-banner{color:#1e1b4b;font-size:1.35rem;font-weight:600;line-height:1.4;margin:0}.fullscreen-help-overlay.dark .fsh-goal-banner .goal-text-banner{color:#e0e7ff}.fsh-context{align-items:center;display:flex;gap:12px}.fsh-context .intention-badge{align-items:center;background:color-mix(in srgb,#6366f1 15%,#0000);background:color-mix(in srgb,var(--accent-color,#6366f1) 15%,#0000);border:1px solid #6366f1;border:1px solid var(--accent-color,#6366f1);border-radius:8px;color:#6366f1;color:var(--accent-color,#6366f1);display:flex;font-size:.875rem;font-weight:600;gap:6px;padding:6px 12px}.fullscreen-help-overlay.dark .fsh-context .intention-badge{background:color-mix(in srgb,#6366f1 25%,#0000);background:color-mix(in srgb,var(--accent-color,#6366f1) 25%,#0000);color:color-mix(in srgb,#6366f1 100%,#fff 30%);color:color-mix(in srgb,var(--accent-color,#6366f1) 100%,#fff 30%)}.fsh-context .phase-badge{background:#6366f11a;border-radius:8px;color:#6366f1;font-size:.875rem;font-weight:600;padding:6px 12px}.fullscreen-help-overlay.dark .fsh-context .phase-badge{background:#6366f14d;color:#a5b4fc}.fsh-context .goal-counter{color:#6b7280;font-size:.875rem}.fullscreen-help-overlay.dark .fsh-context .goal-counter{color:#9ca3af}.fsh-actions{align-items:center;display:flex;gap:4px}.fsh-actions button{color:#6b7280}.fullscreen-help-overlay.dark .fsh-actions button{color:#9ca3af}.fsh-actions button:hover{background:#4f46e51a;color:#4f46e5}.fullscreen-help-overlay.dark .fsh-actions button:hover{background:#a5b4fc1a;color:#a5b4fc}.fsh-actions .bookmark-btn.active{color:#f59e0b}.fsh-actions .close-btn:hover{background:#ef44441a;color:#ef4444}.nav-btn{align-items:center;background:#fff;border:none;border-radius:50%;box-shadow:0 4px 20px #00000026;color:#6366f1;cursor:pointer;display:flex;height:64px;justify-content:center;position:fixed;top:50%;transform:translateY(-50%);transition:all .2s;width:64px;z-index:10}.fullscreen-help-overlay.dark .nav-btn{background:#1e293b;color:#a5b4fc}.nav-btn:hover{box-shadow:0 8px 30px #6366f14d;transform:translateY(-50%) scale(1.1)}.nav-btn.prev{left:24px}.nav-btn.next{right:24px}.fsh-content{align-items:center;flex:1 1;justify-content:flex-start;overflow-y:auto;padding:32px 120px}.fsh-content,.help-sections{display:flex;flex-direction:column}.help-sections{gap:24px;max-width:900px;width:100%}.help-section{animation:sectionSlideIn .4s ease;border-radius:16px;padding:28px 32px}@keyframes sectionSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.help-section:nth-child(2){animation-delay:.1s}.help-section:nth-child(3){animation-delay:.2s}.help-section h2{align-items:center;display:flex;font-size:1rem;font-weight:700;gap:8px;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.help-section p{font-size:1.25rem;line-height:1.7;margin:0}.help-section.definition{background:#fff;border:2px solid #e0e7ff}.fullscreen-help-overlay.dark .help-section.definition{background:#1e293bcc;border-color:#334155}.help-section.definition h2{color:#6366f1}.fullscreen-help-overlay.dark .help-section.definition h2{color:#a5b4fc}.help-section.definition p{color:#374151}.fullscreen-help-overlay.dark .help-section.definition p{color:#e2e8f0}.help-section.example{background:linear-gradient(135deg,#fef3c7,#fef9c3);border-left:4px solid #f59e0b}.fullscreen-help-overlay.dark .help-section.example{background:linear-gradient(135deg,#fbbf2433,#f59e0b26);border-left-color:#fbbf24}.help-section.example h2{color:#b45309}.fullscreen-help-overlay.dark .help-section.example h2{color:#fbbf24}.help-section.example p{color:#78350f;font-style:italic}.fullscreen-help-overlay.dark .help-section.example p{color:#fef3c7}.help-section.tip{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-left:4px solid #10b981}.fullscreen-help-overlay.dark .help-section.tip{background:linear-gradient(135deg,#10b98133,#05966926);border-left-color:#34d399}.help-section.tip h2{color:#059669}.fullscreen-help-overlay.dark .help-section.tip h2{color:#34d399}.help-section.tip p{color:#065f46}.fullscreen-help-overlay.dark .help-section.tip p{color:#d1fae5}.fsh-footer{border-top:1px solid #0000001a;display:flex;justify-content:center;padding:12px 24px}.fullscreen-help-overlay.dark .fsh-footer{border-top-color:#ffffff1a}.keyboard-hints{color:#9ca3af;display:flex;font-size:.875rem;gap:24px}.keyboard-hints span{align-items:center;display:flex;gap:6px}.keyboard-hints kbd{align-items:center;background:#0000000d;border:1px solid #0000001a;border-radius:4px;display:inline-flex;font-family:inherit;font-size:.75rem;height:24px;justify-content:center;min-width:28px;padding:0 6px}.fullscreen-help-overlay.dark .keyboard-hints kbd{background:#ffffff1a;border-color:#ffffff1a}@media print{.fullscreen-help-overlay{background:#fff!important;position:static}.fsh-footer,.fsh-header,.nav-btn{display:none!important}.fsh-content{padding:40px}.help-section{break-inside:avoid;page-break-inside:avoid}}@media (max-width:1024px){.nav-btn{height:48px;width:48px}.nav-btn.prev{left:12px}.nav-btn.next{right:12px}.fsh-content{padding:32px 80px}}@media (max-width:768px){.fsh-header{gap:12px;padding:12px 16px}.fsh-header-top{flex-direction:column;gap:12px}.fsh-context{flex-wrap:wrap;justify-content:center}.fsh-goal-banner{flex-direction:column;gap:10px;padding:12px 16px;text-align:center}.fsh-goal-banner .goal-number-badge{font-size:1rem;height:36px;min-width:36px}.fsh-goal-banner .goal-text-banner{font-size:1.1rem}.nav-btn{bottom:80px;height:44px;top:auto;transform:none;width:44px}.nav-btn:hover{transform:scale(1.1)}.nav-btn.prev{left:16px}.nav-btn.next{right:16px}.fsh-content{padding:24px 16px 100px}.help-section{padding:20px 24px}.help-section p{font-size:1.1rem}.keyboard-hints{display:none}}.teacher-criteria-viewer.progressive{background:linear-gradient(135deg,#f8fafc,#e0e7ff);display:flex;flex-direction:column;min-height:100vh}.tcv-header{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:12px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.tcv-header .back-btn{align-items:center;color:#6b7280;display:flex;gap:8px}.tcv-header .header-title{align-items:center;color:#4f46e5;display:flex;gap:10px}.tcv-header .header-title h1{font-size:1.125rem;font-weight:700;margin:0}.tcv-header .header-actions{display:flex;gap:8px}.tcv-header .header-actions button{align-items:center;display:flex;gap:6px}.tcv-progressive-main{flex:1 1;margin:0 auto;max-width:1400px;padding:24px;width:100%}.selection-row{animation:slideDown .3s ease;margin-bottom:20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.selection-row .row-label{color:#9ca3af;font-size:.7rem;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-align:center;text-transform:uppercase}.phases-row-first{margin-bottom:28px;text-align:center}.phases-centered{display:flex;gap:12px;justify-content:center}.phase-btn-large{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#374151;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:12px;min-width:160px;padding:14px 24px;transition:all .2s ease}.phase-btn-large:hover{background:#f5f3ff;border-color:#6366f1;box-shadow:0 4px 12px #6366f126;transform:translateY(-2px)}.phase-btn-large.selected{background:linear-gradient(135deg,#6366f1,#4f46e5);border-color:#6366f1;box-shadow:0 4px 16px #6366f14d;color:#fff}.phase-num-large{align-items:center;background:#e0e7ff;border-radius:10px;color:#4f46e5;display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:36px;justify-content:center;width:36px}.phase-btn-large.selected .phase-num-large{background:#fff3;color:#fff}.phase-info{align-items:flex-start;display:flex;flex-direction:column;gap:2px}.phase-label-large{font-size:.95rem;font-weight:700;line-height:1.2}.phase-years{color:#6b7280;font-size:.75rem;font-weight:500;line-height:1.2}.phase-btn-large.selected .phase-years{color:#fffc}.intentions-cards-row{margin-bottom:24px}.intentions-cards-container{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(5,1fr);margin:0 auto;max-width:1200px}.intention-card-compact{align-items:center;background:#fff;border:2px solid #0000;cursor:pointer;display:flex;flex-direction:column;padding:16px 12px;text-align:center;transition:all .2s ease}.intention-card-compact:hover{border-color:var(--accent-color);box-shadow:0 6px 20px #0000001a;transform:translateY(-3px)}.intention-card-compact.selected{background:color-mix(in srgb,var(--accent-color) 8%,#fff);border-color:var(--accent-color);box-shadow:0 4px 16px color-mix(in srgb,var(--accent-color) 25%,#0000)}.intention-card-icon{align-items:center;background:color-mix(in srgb,var(--accent-color) 12%,#fff);border-radius:12px;color:var(--accent-color);display:flex;height:48px;justify-content:center;margin-bottom:10px;width:48px}.intention-card-compact.selected .intention-card-icon{background:var(--accent-color);color:#fff}.intention-card-text h3{color:#1f2937;font-size:.8rem;font-weight:700;line-height:1.3;margin:0 0 4px}.intention-card-text p{color:#6b7280;font-size:.7rem;line-height:1.3;margin:0}.intention-card-compact.selected .intention-card-text h3{color:var(--accent-color)}.intention-tooltip-wide{max-width:320px;text-align:left}.intention-tooltip-wide p{font-size:.8rem;line-height:1.5;margin:0}.goals-section{animation:fadeIn .3s ease}.goals-row-label{color:#9ca3af;font-size:.7rem;font-weight:600;letter-spacing:.5px;margin:0 0 16px!important;text-align:center;text-transform:uppercase}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.goals-header{flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px}.goals-context,.goals-header{align-items:center;display:flex}.goals-context{gap:8px}.context-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:.75rem;font-weight:600;gap:5px;padding:5px 10px}.context-badge.phase-badge-sm{background:#e0e7ff;color:#4f46e5}.context-badge.intention-badge-sm{background:color-mix(in srgb,var(--accent-color) 12%,#fff);color:var(--accent-color)}.goals-count{color:#6b7280;font-size:.8rem}.goals-tools{gap:10px}.goals-tools,.search-box{align-items:center;display:flex}.search-box{background:#fff;border:1px solid #e5e7eb;border-radius:8px;gap:8px;min-width:180px;padding:6px 12px}.search-box svg{color:#9ca3af;flex-shrink:0}.search-box input{background:none;border:none;font-size:.8rem;padding:4px 0;width:100%}.search-box input:focus{outline:none}.search-box .clear-search{align-items:center;background:none;border:none;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:2px}.search-box .clear-search:hover{color:#6b7280}.bookmark-filter-btn{align-items:center;display:flex;gap:6px}.goals-category{margin-bottom:24px}.goals-category:last-child{margin-bottom:0}.category-heading{align-items:center;border-bottom:2px solid #e5e7eb;color:#374151;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0 0 12px;padding-bottom:8px}.grammar-category .category-heading{border-bottom-color:#ddd6fe;color:#7c3aed}.grammar-category .goal-card{border-left:3px solid #8b5cf6}.grammar-category .goal-card .goal-number{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.goals-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.goal-card{align-items:flex-start;border:2px solid #0000;cursor:pointer;display:flex;gap:12px;padding:12px 14px;transition:all .2s ease}.goal-card:hover{background:#fafaff;border-color:#6366f1;box-shadow:0 4px 12px #6366f126;transform:translateY(-2px)}.goal-card .goal-number{align-items:center;background:linear-gradient(135deg,#818cf8,#6366f1);border-radius:6px;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:26px;justify-content:center;width:26px}.goal-card .goal-text{color:#374151;flex:1 1;font-size:.85rem;line-height:1.45;margin:0}.goal-card .goal-actions{align-items:center;display:flex;gap:4px;opacity:.5;transition:opacity .2s}.goal-card:hover .goal-actions{opacity:1}.goal-card .bookmark-btn{align-items:center;background:none;border:none;border-radius:5px;color:#9ca3af;cursor:pointer;display:flex;justify-content:center;padding:5px;transition:all .2s}.goal-card .bookmark-btn:hover{background:#f3f4f6;color:#6366f1}.goal-card .bookmark-btn.active{color:#f59e0b}.goal-card .expand-icon{color:#9ca3af}.welcome-message{color:#9ca3af;font-size:.95rem;min-height:120px}.empty-state,.loading-state,.welcome-message{align-items:center;display:flex;justify-content:center}.empty-state,.loading-state{color:#6b7280;flex-direction:column;padding:50px 20px}.loading-state .spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#6366f1;height:32px;margin-bottom:12px;width:32px}@media print{.goal-actions,.goals-tools,.selection-row,.tcv-header,.welcome-message{display:none!important}.teacher-criteria-viewer.progressive{background:#fff}.goals-section{margin-top:0}.goal-card{border:1px solid #e5e7eb;break-inside:avoid;page-break-inside:avoid}}@media (min-width:769px),(orientation:landscape){.phases-centered{flex-wrap:nowrap}.intentions-cards-container{gap:10px;grid-template-columns:repeat(5,1fr)}.intention-card-compact{padding:14px 10px}.intention-card-icon{height:44px;width:44px}.intention-card-text h3{font-size:.75rem}.intention-card-text p{font-size:.65rem}}@media (max-height:500px) and (orientation:landscape){.tcv-header{padding:8px 16px}.tcv-header .header-title h1{font-size:1rem}.tcv-progressive-main{padding:12px 16px}.selection-row{margin-bottom:12px}.selection-row .row-label{font-size:.65rem;margin-bottom:6px}.phases-row-first{margin-bottom:16px}.phase-btn-large{gap:10px;min-width:130px;padding:10px 16px}.phase-num-large{font-size:.95rem;height:30px;width:30px}.phase-label-large{font-size:.8rem}.phase-years{font-size:.65rem}.intentions-cards-container{gap:8px}.intention-card-compact{padding:10px 8px}.intention-card-icon{height:36px;margin-bottom:6px;width:36px}.intention-card-icon svg{height:18px;width:18px}.intention-card-text h3{font-size:.65rem}.intention-card-text p{font-size:.55rem}.goals-header{margin-bottom:10px}.goals-grid{gap:8px}.goal-card{padding:10px 12px}.goal-card .goal-text{font-size:.8rem}.welcome-message{font-size:.85rem;min-height:80px}}@media (min-width:1200px){.tcv-progressive-main{padding:28px 40px}.phase-btn-large{min-width:140px;padding:16px 32px}.intentions-cards-container{gap:16px}.intention-card-compact{padding:18px 14px}.intention-card-icon{height:52px;width:52px}.intention-card-text h3{font-size:.85rem}.intention-card-text p{font-size:.75rem}.goals-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media (max-width:768px) and (orientation:portrait){.tcv-header{padding:10px 16px}.tcv-header .back-text,.tcv-header .btn-text{display:none}.tcv-header .header-title h1{font-size:1rem}.tcv-progressive-main{padding:16px}.phases-centered{flex-wrap:wrap;gap:8px}.phase-btn-large{flex:1 1 45%;min-width:auto;padding:12px 20px}.intentions-cards-container{gap:10px;grid-template-columns:repeat(2,1fr)}.intention-card-compact{padding:14px 10px}.intentions-cards-container>:nth-child(5){grid-column:span 2;justify-self:center;max-width:50%}.goals-header,.goals-tools{align-items:stretch;flex-direction:column}.search-box{min-width:0;min-width:auto}.goals-grid{grid-template-columns:1fr}}.goal-tooltip{background:#1f2937;border-radius:8px;box-shadow:0 4px 12px #00000026;color:#fff;font-size:.9rem;line-height:1.5;max-width:350px;padding:12px 16px;z-index:1000}.goal-tooltip p{margin:0}.teacher-student-preview{background:linear-gradient(135deg,#fef5e7,#e8f4f8 50%,#f0e7f5);min-height:100vh}.preview-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.preview-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-wrap:wrap;justify-content:space-between;padding:12px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.banner-content,.preview-banner{align-items:center;display:flex;gap:12px}.banner-text{font-size:.95rem}.preview-banner .return-btn{background:#fff3;border-color:#ffffff4d;color:#fff}.preview-banner .return-btn:hover{background:#ffffff4d}.preview-content{margin:0 auto;max-width:1100px;padding:32px 24px}.preview-header{margin-bottom:24px}.student-info-header{align-items:center;display:flex;gap:20px}.student-avatar-large{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 12px #667eea4d;color:#fff;display:flex;font-size:2rem;font-weight:700;height:80px;justify-content:center;width:80px}.preview-header h1{color:#1e293b;font-size:2rem;font-weight:700;margin:0}.preview-header .student-username{color:#64748b;font-size:1rem;margin-top:4px}.preview-header .student-class{color:#94a3b8;font-size:.9rem;margin-top:2px}.info-banner{background:linear-gradient(135deg,#e0f2fe,#f0f9ff);border:1px solid #7dd3fc;margin-bottom:24px;padding:16px 20px}.info-banner-content{align-items:flex-start;color:#0369a1;display:flex;gap:12px}.info-banner-content strong{display:block;margin-bottom:4px}.info-banner-content p{color:#0c4a6e;font-size:.9rem;margin:0}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:24px}.stats-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;padding:24px}.stats-card .card-header{align-items:center;color:#667eea;display:flex;gap:10px;margin-bottom:20px}.stats-card .card-header h3{color:#334155;font-size:1.1rem;font-weight:600;margin:0}.stats-content{display:flex;gap:32px}.stat-item{flex-direction:column}.stat-value{color:#667eea;font-size:2rem}.stat-label{font-size:.85rem}.chart-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;padding:20px}.chart-header{flex-direction:column;margin-bottom:16px}.chart-header,.chart-title{align-items:center;display:flex;gap:8px}.chart-title{color:#334155}.chart-title h3{font-size:1.2rem;font-weight:600;margin:0}.trend-badge{border-radius:20px;font-size:.8rem;font-weight:500;padding:4px 12px}.trend-badge.improving{background:#dcfce7;color:#166534}.trend-badge.declining{background:#fee2e2;color:#991b1b}.trend-badge.steady{background:#e0f2fe;color:#0369a1}.rate-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;padding:4px 12px}.chart-container{margin:12px 0}.chart-stats{border-top:1px solid #f1f5f9;display:flex;gap:24px;justify-content:center;margin-top:12px;padding-top:12px}.mini-stat{align-items:center;display:flex;flex-direction:column}.mini-stat .mini-value{color:#334155;font-size:1.25rem;font-weight:700}.mini-stat .mini-label{color:#94a3b8;font-size:.75rem}.mini-stat.highlight .mini-value{color:#667eea}.growth-score-display{padding:20px 16px;text-align:center}.star-rating{display:flex;gap:8px;justify-content:center;margin-bottom:12px}.growth-label{font-size:1.25rem;font-weight:600;margin-bottom:8px}.growth-description{color:#6b7280;font-size:.9rem;line-height:1.5;margin:0 0 16px}.practice-count{align-items:center;background:#f0fdf4;border-radius:20px;color:#059669;display:inline-flex;font-size:.85rem;gap:8px;padding:8px 16px}.chart-note{color:#9ca3af;font-size:.8rem;margin:12px 0 0;text-align:center}.chart-tooltip{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026;font-size:.85rem;padding:8px 12px}.tooltip-date{color:#64748b;margin:0 0 4px}.tooltip-achieved,.tooltip-score{color:#334155;margin:0}.learning-intentions-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;grid-column:1/-1;padding:24px}.learning-intentions-card .card-header{align-items:center;color:#667eea;display:flex;gap:10px;margin-bottom:16px}.learning-intentions-card .card-header h3{color:#334155;font-size:1.1rem;font-weight:600;margin:0}.intentions-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.intention-badge-expanded{border-radius:12px;color:#fff;padding:16px}.intention-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.intention-name{font-size:1rem;font-weight:600}.intention-count{background:#fff3;border-radius:12px;font-size:.85rem;padding:2px 10px}.intention-goals{border-top:1px solid #fff3;margin-top:8px;padding-top:8px}.goals-label{font-size:.8rem;margin-bottom:6px;opacity:.9}.goals-list{font-size:.85rem;margin:0;padding-left:16px}.goals-list li{margin-bottom:4px;opacity:.95}.more-goals{font-style:italic;opacity:.8}.recent-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;grid-column:1/-1;padding:24px}.recent-card .card-header{align-items:center;color:#667eea;display:flex;gap:10px;margin-bottom:16px}.recent-card .card-header h3{color:#334155;font-size:1.1rem;font-weight:600;margin:0}.empty-state{align-items:center;color:#94a3b8;display:flex;flex-direction:column;gap:8px;padding:32px;text-align:center}.empty-subtitle{font-size:.9rem}.assessment-list{display:flex;flex-direction:column;gap:8px}.assessment-item{align-items:center;background:#f8fafc;border-radius:12px;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.assessment-item:hover{background:#f1f5f9}.assessment-icon{align-items:center;background:linear-gradient(135deg,#667eea20,#764ba220);border-radius:8px;color:#667eea;display:flex;height:36px;justify-content:center;width:36px}.assessment-details{flex:1 1}.assessment-title{color:#334155;font-size:.95rem;font-weight:500}.assessment-meta{color:#94a3b8;font-size:.8rem;margin-top:2px}.rating-text-small{color:#64748b}.assessment-right{align-items:center;display:flex;gap:8px}.assessment-stars{display:flex;gap:2px}.chevron{color:#94a3b8}.view-all-link{margin-top:16px;text-align:center}.view-all-text{color:#64748b;font-size:.85rem}.latest-writing-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000d;margin-bottom:24px;padding:24px}.latest-writing-card .card-header{align-items:center;color:#667eea;display:flex;gap:10px;margin-bottom:12px}.latest-writing-card .card-header h3{color:#334155;flex:1 1;font-size:1.1rem;font-weight:600;margin:0}.writing-date{color:#94a3b8;font-size:.85rem;font-weight:400}.writing-meta{display:flex;gap:8px;margin-bottom:16px}.writing-genre,.writing-topic{background:#f1f5f9;border-radius:20px;color:#475569;font-size:.85rem;padding:4px 12px}.writing-preview{background:#fafafa;border-left:4px solid #667eea;border-radius:12px;margin-bottom:16px;padding:20px}.writing-text{color:#334155;font-size:.95rem;line-height:1.7;margin:0;white-space:pre-wrap}.writing-stats{display:flex;gap:12px}.writing-stats .stat-badge{background:#f0fdf4;border-radius:20px;color:#059669;font-size:.85rem;padding:6px 14px}.teacher-note-card{background:linear-gradient(135deg,#fef3c7,#fef9c3);border:1px solid #fcd34d;border-radius:16px;padding:24px}.teacher-note-card h3{color:#92400e;font-size:1.1rem;font-weight:600;margin:0 0 12px}.teacher-note-card p{color:#78350f;line-height:1.6;margin:0 0 16px}.note-actions{display:flex;justify-content:flex-start}@media (max-width:768px){.preview-banner{padding:12px 16px}.preview-banner,.student-info-header{flex-direction:column;text-align:center}.preview-header h1{font-size:1.5rem}.preview-content{padding:20px 16px}.dashboard-grid{grid-template-columns:1fr}.stats-content{gap:24px}.stat-value{font-size:1.5rem}.chart-stats{gap:16px}.intentions-grid{grid-template-columns:1fr}}.data-management-page{background:linear-gradient(135deg,#f8fafc,#e2e8f0);min-height:100vh;padding:24px}.data-management-loading{align-items:center;color:#64748b;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.loading-spinner,.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.data-management-header{margin:0 auto 24px;max-width:900px}.data-management-header h1{align-items:center;color:#1e293b;display:flex;font-size:1.75rem;font-weight:700;gap:12px;margin:16px 0 8px}.data-management-header .subtitle{color:#64748b;margin:0}.warning-banner{align-items:flex-start;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:12px;color:#92400e;display:flex;gap:16px;margin:0 auto 24px;max-width:900px;padding:16px 20px}.warning-banner svg{flex-shrink:0;margin-top:2px}.warning-content strong{display:block;font-size:1rem;margin-bottom:4px}.warning-content p{font-size:.9rem;margin:0}.data-management-content{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:900px}.data-management-content .card-header{align-items:center;color:#334155;display:flex;gap:12px;margin-bottom:16px}.data-management-content .card-header h2{font-size:1.25rem;font-weight:600;margin:0}.overview-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;padding:24px}.overview-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.stat-item{background:#f8fafc;border-radius:12px;gap:12px;padding:16px}.stat-icon,.stat-item{align-items:center;display:flex}.stat-icon{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;height:40px;justify-content:center;width:40px}.stat-info{display:flex;flex-direction:column}.stat-value{color:#1e293b;font-size:1.5rem;font-weight:700}.stat-label{color:#64748b;font-size:.8rem}.privacy-card{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #10b981;border-radius:16px;padding:24px}.privacy-card .card-header{color:#065f46}.policy-text{color:#047857;line-height:1.6;margin-bottom:16px}.policy-benefits{display:flex;flex-direction:column;gap:8px}.benefit{align-items:center;color:#065f46;display:flex;font-size:.9rem;gap:8px}.benefit svg{color:#10b981;flex-shrink:0}.settings-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;padding:24px}.setting-row{align-items:center;display:flex;gap:16px;justify-content:space-between}.setting-info h3{color:#334155;font-size:1rem;font-weight:600;margin:0 0 4px}.setting-info p{color:#64748b;font-size:.85rem;margin:0}.scheduled-info{align-items:center;background:#f8fafc;border-radius:8px;color:#64748b;display:flex;font-size:.9rem;gap:8px;margin-top:16px;padding:12px 16px}.export-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;padding:24px}.export-description{color:#64748b;margin-bottom:20px}.export-section{border-top:1px solid #e2e8f0;padding:16px 0}.export-section:first-of-type{border-top:none;padding-top:0}.export-section h3{color:#334155;font-size:1rem;font-weight:600;margin:0 0 8px}.export-section>p{color:#64748b;font-size:.85rem;margin:0 0 12px}.export-buttons,.export-list{display:flex;gap:8px}.export-list{flex-direction:column;margin-top:12px}.export-item{align-items:center;background:#f8fafc;border-radius:10px;display:flex;justify-content:space-between;padding:12px 16px}.export-name{color:#334155;font-weight:500}.student-export-info{display:flex;flex-direction:column}.export-class{color:#94a3b8;font-size:.8rem}.student-list{max-height:400px;overflow-y:auto}.more-students{color:#64748b;font-size:.85rem;margin:0;padding:12px;text-align:center}.danger-card{background:#fef2f2;border:1px solid #fecaca;border-radius:16px;padding:24px}.danger-card .card-header{color:#991b1b}.danger-description{color:#7f1d1d;margin-bottom:16px}.delete-dialog-title{align-items:center;display:flex;gap:12px}.delete-summary{background:#fef2f2;border-radius:8px;margin:16px 0;padding:16px}.delete-summary p{color:#7f1d1d;font-weight:500;margin:0 0 8px}.delete-summary ul{color:#991b1b;margin:0;padding-left:20px}.delete-summary li{margin:4px 0}@media (max-width:768px){.data-management-page{padding:16px}.data-management-header h1{font-size:1.5rem}.overview-stats{grid-template-columns:repeat(2,1fr)}.export-item,.setting-row{align-items:flex-start;flex-direction:column}.export-item{gap:8px}.export-buttons{justify-content:flex-start;width:100%}.warning-banner{flex-direction:column;gap:8px}}
/*# sourceMappingURL=main.81d8f80b.css.map*/