*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 38 33% 95%;--foreground: 24 10% 10%;--muted: 36 18% 88%;--muted-foreground: 25 6% 42%;--accent: 35 44% 91%;--accent-foreground: 24 10% 10%;--border: 32 15% 86%;--input: 32 15% 86%;--ring: 174 84% 32%;--primary: 174 84% 32%;--primary-foreground: 0 0% 100%;--secondary: 35 26% 93%;--secondary-foreground: 24 10% 10%;--destructive: 350 76% 50%;--destructive-foreground: 0 0% 100%;--radius: .75rem}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.bottom-0{bottom:0}.bottom-1\/4{bottom:25%}.left-1\/4{left:25%}.right-0{right:0}.right-1\/4{right:25%}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-1\/4{top:25%}.top-4{top:1rem}.top-5{top:1.25rem}.z-10{z-index:10}.z-20{z-index:20}.z-\[120\]{z-index:120}.z-\[130\]{z-index:130}.mx-1{margin-left:.25rem;margin-right:.25rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mr-2{margin-right:.5rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.size-4{width:1rem;height:1rem}.size-5{width:1.25rem;height:1.25rem}.size-64{width:16rem;height:16rem}.size-8{width:2rem;height:2rem}.size-96{width:24rem;height:24rem}.h-1\/2{height:50%}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-9{height:2.25rem}.h-\[2px\]{height:2px}.h-\[4px\]{height:4px}.h-\[500px\]{height:500px}.h-\[55\%\]{height:55%}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-20{width:5rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-full{width:100%}.min-w-\[2ch\]{min-width:2ch}.max-w-\[420px\]{max-width:420px}.flex-1{flex:1 1 0%}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-grab{cursor:grab}.cursor-pointer{cursor:pointer}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-evenly{justify-content:space-evenly}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.25rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.whitespace-nowrap{white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-b-full{border-bottom-right-radius:9999px;border-bottom-left-radius:9999px}.rounded-t-full{border-top-left-radius:9999px;border-top-right-radius:9999px}.border{border-width:1px}.border-0{border-width:0px}.border-border{border-color:hsl(var(--border))}.border-border\/60{border-color:hsl(var(--border) / .6)}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-input{border-color:hsl(var(--input))}.border-primary{border-color:hsl(var(--primary))}.border-primary\/20{border-color:hsl(var(--primary) / .2)}.border-red-900\/30{border-color:#7f1d1d4d}.bg-\[\#2D2D2D\]{--tw-bg-opacity: 1;background-color:rgb(45 45 45 / var(--tw-bg-opacity, 1))}.bg-background{background-color:hsl(var(--background))}.bg-background\/95{background-color:hsl(var(--background) / .95)}.bg-destructive{background-color:hsl(var(--destructive))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted\/40{background-color:hsl(var(--muted) / .4)}.bg-primary{background-color:hsl(var(--primary))}.bg-primary-foreground\/10{background-color:hsl(var(--primary-foreground) / .1)}.bg-primary-foreground\/5{background-color:hsl(var(--primary-foreground) / .05)}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-red-950\/10{background-color:#450a0a1a}.bg-secondary{background-color:hsl(var(--secondary))}.bg-teal-600{--tw-bg-opacity: 1;background-color:rgb(13 148 136 / var(--tw-bg-opacity, 1))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-\[linear-gradient\(0deg\,rgba\(0\,0\,0\,\.14\)_0\%\,rgba\(0\,0\,0\,\.08\)_25\%\,rgba\(0\,0\,0\,\.03\)_50\%\,rgba\(0\,0\,0\,0\)_100\%\)\]{background-image:linear-gradient(0deg,#00000024,#00000014,#00000008 50%,#0000)}.bg-\[linear-gradient\(135deg\,rgba\(255\,255\,255\,\.40\)_0\%\,rgba\(255\,255\,255\,\.20\)_20\%\,rgba\(255\,255\,255\,\.08\)_40\%\,rgba\(255\,255\,255\,0\)_65\%\)\]{background-image:linear-gradient(135deg,#fff6,#fff3,#ffffff14 40%,#fff0 65%)}.bg-\[linear-gradient\(180deg\,rgba\(255\,255\,255\,\.45\)_0\%\,rgba\(255\,255\,255\,\.25\)_30\%\,rgba\(255\,255\,255\,\.10\)_60\%\,rgba\(255\,255\,255\,0\)_100\%\)\]{background-image:linear-gradient(180deg,#ffffff73,#ffffff40,#ffffff1a 60%,#fff0)}.bg-\[linear-gradient\(90deg\,rgba\(255\,255\,255\,0\)_0\%\,rgba\(255\,255\,255\,\.95\)_5\%\,\#fff_15\%\,\#fff_85\%\,rgba\(255\,255\,255\,\.95\)_95\%\,rgba\(255\,255\,255\,0\)_100\%\)\]{background-image:linear-gradient(90deg,#fff0,#fffffff2 5%,#fff 15% 85%,#fffffff2 95%,#fff0)}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-primary\/90{--tw-gradient-from: hsl(var(--primary) / .9) var(--tw-gradient-from-position);--tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-primary{--tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), hsl(var(--primary)) var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-primary\/80{--tw-gradient-to: hsl(var(--primary) / .8) var(--tw-gradient-to-position)}.bg-\[size\:20px_20px\]{background-size:20px 20px}.p-1{padding:.25rem}.p-12{padding:3rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pr-10{padding-right:2.5rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-\[15\.5px\]{font-size:15.5px}.text-\[15px\]{font-size:15px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.leading-none{line-height:1}.tracking-normal{letter-spacing:0em}.tracking-tight{letter-spacing:-.025em}.text-\[\#1a1a1a\]{--tw-text-opacity: 1;color:rgb(26 26 26 / var(--tw-text-opacity, 1))}.text-current{color:currentColor}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-primary-foreground\/70{color:hsl(var(--primary-foreground) / .7)}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-teal-600{--tw-text-opacity: 1;color:rgb(13 148 136 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.underline-offset-4{text-underline-offset:4px}.shadow-\[inset_0_0_40px_rgba\(255\,255\,255\,\.22\)\]{--tw-shadow: inset 0 0 40px rgba(255,255,255,.22);--tw-shadow-colored: inset 0 0 40px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-3xl{--tw-blur: blur(64px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-\[\.3px\]{--tw-blur: blur(.3px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur: blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-700{transition-duration:.7s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.bg-grid-white\/\[0\.05\]{background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px)}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.file\:text-foreground::file-selector-button{color:hsl(var(--foreground))}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-gray-300:hover{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.hover\:bg-muted:hover{background-color:hsl(var(--muted))}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:bg-teal-700:hover{--tw-bg-opacity: 1;background-color:rgb(15 118 110 / var(--tw-bg-opacity, 1))}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:underline:hover{text-decoration-line:underline}.focus\:border-primary:focus{border-color:hsl(var(--primary))}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:hsl(var(--primary-foreground))}@media(min-width:768px){.md\:block{display:block}}@media(min-width:1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}:root{--bg:#f7f4ef;--surface:#ffffff;--surface2:#f0ece4;--border:#e2ddd6;--border2:#ccc7be;--ink:#1c1917;--ink2:#57534e;--ink3:#a8a29e;--amber:#d97706;--amber-lt:#fef3c7;--amber-md:#fde68a;--teal:#0d9488;--teal-lt:#ccfbf1;--rose:#e11d48;--rose-lt:#ffe4e6;--slate:#475569;--slate-lt:#f1f5f9;--correct:#059669;--correct-lt:#d1fae5;--wrong:#dc2626;--wrong-lt:#fee2e2;--radius:14px;--shadow:0 1px 4px rgba(0,0,0,.07),0 4px 16px rgba(0,0,0,.05);--shadow-md:0 2px 8px rgba(0,0,0,.1),0 8px 32px rgba(0,0,0,.08)}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--ink);font-family:DM Sans,sans-serif;min-height:100vh;background-image:radial-gradient(ellipse at 80% 0%,rgba(217,119,6,.07) 0%,transparent 55%),radial-gradient(ellipse at 10% 100%,rgba(13,148,136,.05) 0%,transparent 55%)}.screen{display:none;min-height:100vh}.screen.active{display:flex;flex-direction:column}#home-screen{justify-content:center;align-items:center;padding:2.5rem 1.5rem}.home-inner{max-width:860px;width:100%}.top-nav{background:var(--surface);border-bottom:1.5px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:50;box-shadow:0 1px 4px #0000000f}.nav-wordmark{font-family:Fraunces,serif;font-size:1.1rem;font-weight:700;color:var(--ink)}.nav-wordmark span{color:var(--amber)}.nav-spacer{flex:1}.nav-links{display:flex;gap:.3rem}.nav-link{padding:.38rem .82rem;border-radius:9px;font-size:.78rem;font-weight:500;cursor:pointer;border:1.5px solid transparent;color:var(--ink2);transition:all .15s;background:none;font-family:DM Sans,sans-serif}.nav-link:hover{background:var(--surface2);border-color:var(--border)}.nav-link.active-link{background:var(--amber-lt);border-color:var(--amber-md);color:var(--amber)}.nav-hamburger{display:none;padding:.38rem .6rem;border-radius:9px;background:var(--surface2);border:1.5px solid var(--border);cursor:pointer;font-size:1rem}.nav-menu-drop{display:none;position:absolute;top:100%;right:1rem;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:.5rem;min-width:180px;z-index:100}.nav-menu-drop.open{display:flex;flex-direction:column;gap:.2rem}.nav-menu-item{padding:.5rem .85rem;border-radius:9px;font-size:.82rem;font-weight:500;cursor:pointer;color:var(--ink2);transition:all .15s;border:none;background:none;text-align:left;font-family:DM Sans,sans-serif}.nav-menu-item:hover{background:var(--surface2);color:var(--ink)}@media(max-width:600px){.nav-links{display:none}.nav-hamburger{display:block}}.wordmark-row{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1.8rem;padding-bottom:1.2rem;border-bottom:1.5px solid var(--border)}.wm-logo{font-family:Fraunces,serif;font-size:1.4rem;font-weight:700;color:var(--ink)}.wm-logo span{color:var(--amber)}.wm-sub{font-size:.75rem;color:var(--ink3);letter-spacing:.06em;text-transform:uppercase;padding-left:.5rem;border-left:1.5px solid var(--border2)}.wm-badge{margin-left:auto;background:var(--amber-lt);border:1px solid var(--amber-md);border-radius:6px;padding:.18rem .62rem;font-size:.67rem;font-weight:600;color:var(--amber)}.checkin-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.2rem 1.4rem;margin-bottom:1.2rem;box-shadow:var(--shadow)}.ci-top{display:flex;align-items:flex-start;gap:1.2rem;flex-wrap:wrap;margin-bottom:1rem}.ci-streak-block{flex-shrink:0;text-align:center;min-width:72px}.ci-streak-num{font-family:Fraunces,serif;font-size:2.8rem;font-weight:700;line-height:1;color:var(--amber)}.ci-streak-lbl{font-size:.63rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-top:2px}.ci-mid{flex:1;min-width:200px}.ci-title{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink2);margin-bottom:.4rem}.ci-meta{font-size:.68rem;color:var(--ink3);margin-bottom:.6rem}.ci-btn-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.ci-btn{padding:.52rem 1.1rem;background:var(--teal);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:.8rem;cursor:pointer;font-family:DM Sans,sans-serif;white-space:nowrap;transition:all .15s}.ci-btn:hover{background:#0f766e}.ci-btn.done-state{background:var(--teal-lt);color:var(--teal);border:1.5px solid var(--teal)}.ci-hint{font-size:.62rem;color:var(--ink3);text-align:right}.ci-cal-section{border-top:1px solid var(--border);padding-top:.9rem}.ci-cal-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.6rem}.ci-cal-title{font-size:.72rem;font-weight:600;color:var(--ink2);flex:1}.ci-month-nav{display:flex;gap:.3rem;align-items:center}.ci-month-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:7px;padding:.22rem .6rem;cursor:pointer;font-size:.72rem;color:var(--ink2);font-family:DM Sans,sans-serif}.ci-month-btn:hover{border-color:var(--border2);color:var(--ink)}.ci-month-lbl{font-size:.75rem;font-weight:600;color:var(--ink);min-width:90px;text-align:center}.cal-dow{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:2px}.cal-dow-lbl{font-size:.55rem;color:var(--ink3);text-align:center;font-weight:600;text-transform:uppercase}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-day{height:28px;border-radius:5px;border:1px solid var(--border);background:var(--surface2);display:flex;align-items:center;justify-content:center;gap:3px;cursor:default;transition:all .15s;padding:0 2px}.cal-day.clickable{cursor:pointer}.cal-day.done{background:var(--teal-lt);border-color:var(--teal)}.cal-day.done:hover{background:#fee2e2;border-color:var(--rose)}.cal-day.today{border-color:var(--amber);border-width:2px}.cal-day.today.done{background:var(--amber-lt);border-color:var(--amber)}.cal-day.today.done:hover{background:var(--rose-lt);border-color:var(--rose)}.cal-day.empty{background:transparent;border-color:transparent}.cal-day.future{opacity:.35}.cal-day-num{font-size:.6rem;color:var(--ink2);font-weight:600;line-height:1}.cal-day-dot{font-size:.58rem;line-height:1;color:var(--teal)}.cal-day.today .cal-day-num{color:var(--amber)}.pdf-strip{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:.95rem 1.3rem;margin-bottom:1.2rem;box-shadow:var(--shadow);display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}.pdf-icon{font-size:1.35rem}.pdf-text{flex:1}.pdf-label{font-size:.78rem;font-weight:600;color:var(--teal)}.pdf-sub{font-size:.67rem;color:var(--ink3);margin-top:2px}.pdf-import-btn{padding:.4rem .95rem;background:var(--teal);color:#fff;border:none;border-radius:9px;font-size:.75rem;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif}.pdf-import-btn:hover{background:#0f766e}.pdf-loaded-badge{display:none;font-size:.65rem;color:var(--teal);background:var(--teal-lt);border:1px solid rgba(13,148,136,.3);border-radius:6px;padding:.18rem .55rem}#pdf-file-input{display:none}.hero{margin-bottom:1.5rem}.hero-eyebrow{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--ink3);margin-bottom:.4rem}.hero-title{font-family:Fraunces,serif;font-size:clamp(1.9rem,5vw,3rem);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin-bottom:.55rem}.hero-title em{font-style:italic;color:var(--amber)}.hero-sub{font-size:.86rem;color:var(--ink2);line-height:1.6}.stats-row{display:grid;grid-template-columns:repeat(6,minmax(118px,1fr));gap:.65rem;margin-bottom:1.3rem}.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:.85rem 1rem;text-align:center;flex:1;min-width:90px;box-shadow:var(--shadow)}.stat-val{font-family:Fraunces,serif;font-size:1.7rem;font-weight:700;color:var(--amber);line-height:1;display:block}.stat-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-top:3px}.countdown-card{border-color:var(--teal);background:linear-gradient(180deg,#fff,var(--teal-lt))}.countdown-card .stat-val{color:var(--teal)}@media(max-width:860px){.stats-row{grid-template-columns:repeat(2,minmax(0,1fr))}}.config-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1rem;box-shadow:var(--shadow)}.config-section-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.15em;color:var(--ink3);font-weight:600;margin-bottom:1rem}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem;margin-bottom:1.2rem}.mode-btn{background:var(--surface2);border:2px solid var(--border);border-radius:11px;padding:.8rem .95rem;cursor:pointer;transition:all .18s;text-align:left}.mode-btn:hover{border-color:var(--teal);background:var(--teal-lt)}.mode-btn.selected{border-color:var(--amber);background:var(--amber-lt)}.mode-icon{font-size:1.15rem;display:block;margin-bottom:.28rem}.mode-name{font-size:.78rem;font-weight:600;display:block;color:var(--ink)}.mode-desc{font-size:.65rem;color:var(--ink3);margin-top:2px}.config-row{display:flex;align-items:center;gap:.85rem;margin-bottom:.95rem;flex-wrap:wrap}.config-lbl{font-size:.7rem;font-weight:600;color:var(--ink2);min-width:60px;text-transform:uppercase;letter-spacing:.06em}.count-row{display:flex;gap:.38rem;flex-wrap:wrap}.count-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:.3rem .8rem;cursor:pointer;font-size:.78rem;color:var(--ink2);transition:all .15s;font-weight:500}.count-btn:hover{border-color:var(--amber)}.count-btn.selected{background:var(--amber);color:#fff;border-color:var(--amber);font-weight:700}.cat-chips{display:flex;gap:.38rem;flex-wrap:wrap}.cat-chip{background:var(--surface2);border:1.5px solid var(--border);border-radius:100px;padding:.26rem .8rem;font-size:.67rem;cursor:pointer;transition:all .15s;color:var(--ink2);white-space:nowrap;font-weight:500}.cat-chip:hover{border-color:var(--teal);color:var(--teal)}.cat-chip.selected{background:var(--teal-lt);border-color:var(--teal);color:var(--teal);font-weight:600}.start-btn{width:100%;padding:.95rem;background:var(--amber);color:#fff;border:none;border-radius:var(--radius);font-size:.93rem;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;letter-spacing:.03em;transition:all .2s;box-shadow:0 4px 16px #d9770640}.start-btn:hover{background:#b45309;transform:translateY(-1px)}.quick-links{display:flex;gap:.55rem;margin-top:.7rem}.profile-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1rem;box-shadow:var(--shadow)}.profile-top{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem}.profile-title{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-right:auto}.profile-select{background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:.45rem .65rem;font-family:DM Sans,sans-serif;color:var(--ink);font-weight:700}.profile-actions{display:flex;gap:.45rem;flex-wrap:wrap}.profile-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:.44rem .72rem;font-family:DM Sans,sans-serif;font-size:.74rem;font-weight:800;color:var(--ink2);cursor:pointer;transition:all .15s}.profile-btn:hover{border-color:var(--teal);color:var(--teal)}.profile-btn.primary{background:var(--teal-lt);border-color:var(--teal);color:var(--teal)}.profile-note{font-size:.72rem;color:var(--ink3);line-height:1.45}.quick-btn{flex:1;padding:.68rem;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:.73rem;color:var(--ink2);transition:all .15s;font-family:DM Sans,sans-serif;text-align:center;font-weight:500;box-shadow:var(--shadow)}.quick-btn:hover{border-color:var(--teal);color:var(--teal)}.quick-btn .qi{display:block;font-size:.92rem;margin-bottom:.22rem}#quiz-screen{padding:0}.quiz-header{background:var(--surface);border-bottom:1.5px solid var(--border);padding:.9rem 1.4rem;display:flex;align-items:center;gap:.9rem;position:sticky;top:0;z-index:10;box-shadow:0 1px 5px #0000000f;flex-wrap:wrap}.back-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:.36rem .78rem;cursor:pointer;font-size:.75rem;color:var(--ink2);transition:all .15s;font-family:DM Sans,sans-serif;font-weight:500}.back-btn:hover{color:var(--ink)}.prog-wrap{flex:1}.prog-txt{display:flex;justify-content:space-between;font-size:.68rem;color:var(--ink3);margin-bottom:.32rem;font-weight:500}.prog-bar{height:4px;background:var(--surface2);border-radius:100px;overflow:hidden;border:1px solid var(--border)}.prog-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--amber));border-radius:100px;transition:width .4s ease}.quiz-actions{display:flex;gap:.4rem}.icon-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:.4rem .6rem;cursor:pointer;font-size:.92rem;transition:all .15s;color:var(--ink3);font-family:DM Sans,sans-serif;font-weight:700}.icon-btn:hover{border-color:var(--amber);color:var(--amber)}.icon-btn.active{color:var(--amber);border-color:var(--amber);background:var(--amber-lt)}.icon-btn.mark-active{color:var(--rose);border-color:var(--rose);background:var(--rose-lt)}.exam-timer-widget{margin:.95rem 0 1rem;background:var(--slate-lt);border:1.5px solid var(--border);border-radius:14px;padding:.9rem;box-shadow:var(--shadow)}.timer-head{display:flex;align-items:center;gap:.45rem;margin-bottom:.75rem;font-size:.74rem;font-weight:800;color:var(--ink);letter-spacing:.02em}.timer-head-icon{display:inline-flex;width:20px;height:20px;align-items:center;justify-content:center;border-radius:50%;background:var(--teal-lt);color:var(--teal);font-size:.86rem}.timer-area{display:flex;align-items:center;justify-content:center;gap:.28rem;margin-bottom:.85rem}.timer-box{width:62px;text-align:center;background:var(--surface);border:1.5px solid var(--border);border-radius:8px;padding:.45rem .3rem;font-family:DM Sans,monospace;font-size:1.05rem;font-weight:900;color:var(--ink);outline:none}.timer-box:focus{border-color:var(--teal);box-shadow:0 0 0 3px #0d94881f}.timer-box::-webkit-outer-spin-button,.timer-box::-webkit-inner-spin-button{-webkit-appearance:none;appearance:none;margin:0}.timer-box[type=number]{-moz-appearance:textfield}.timer-sep{color:var(--ink3);font-weight:900}.timer-controls{display:grid;grid-template-columns:1fr 1fr;gap:.38rem}.timer-chip{border:1.5px solid var(--border);background:var(--surface);border-radius:8px;padding:.45rem .4rem;font-family:DM Sans,sans-serif;font-size:.67rem;font-weight:800;color:var(--ink2);cursor:pointer;transition:all .15s}.timer-chip:hover{border-color:var(--teal);color:var(--teal)}.timer-chip.primary{background:var(--teal);border-color:var(--teal);color:#fff}.timer-chip.primary.paused{background:var(--amber-lt);border-color:var(--amber-md);color:var(--amber)}.timer-chip.icon-only{font-size:.85rem}@media(max-width:920px){.timer-controls{grid-template-columns:repeat(4,1fr)}.timer-box{min-width:54px}}.question-actions{display:flex;gap:.55rem;flex-wrap:wrap;margin:-.2rem 0 1.1rem}.q-action-btn{border:2px solid var(--border);background:var(--surface);border-radius:12px;padding:.85rem 1rem;font-family:DM Sans,sans-serif;font-size:.84rem;font-weight:800;color:var(--ink2);cursor:pointer;box-shadow:var(--shadow);transition:all .15s;display:inline-flex;align-items:center;gap:.7rem;min-height:64px}.q-action-btn:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-1px)}.q-action-btn.saved{border-color:var(--amber);background:var(--amber-lt);color:var(--amber)}.q-action-btn.marked{border-color:var(--rose);background:var(--rose-lt);color:var(--rose)}.q-action-icon{width:42px;height:42px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;font-size:1.55rem;background:var(--surface2);border:1.5px solid var(--border);flex-shrink:0}.q-action-btn.saved .q-action-icon{background:var(--amber);border-color:var(--amber);color:#fff}.q-action-btn.marked .q-action-icon{background:var(--rose);border-color:var(--rose);color:#fff}.q-action-copy{display:flex;flex-direction:column;align-items:flex-start;line-height:1.12}.q-action-sub{font-size:.64rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);margin-top:.18rem}.quiz-main{flex:1;display:grid;grid-template-columns:minmax(0,860px) 230px;gap:1rem;align-items:start;width:100%;max-width:1160px;margin:0 auto;padding:1.7rem 1.4rem}.quiz-side{position:sticky;top:86px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:.85rem;box-shadow:var(--shadow)}.side-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-bottom:.55rem}.side-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.36rem;margin-bottom:1rem}.side-q{height:32px;border:1.5px solid var(--border);background:var(--surface2);border-radius:8px;font-size:.7rem;font-weight:700;color:var(--ink2);cursor:pointer;position:relative;font-family:DM Sans,sans-serif}.side-q:hover{border-color:var(--teal);color:var(--teal)}.side-q.current{background:var(--teal);border-color:var(--teal);color:#fff}.side-q.done:not(.current){background:var(--correct-lt);border-color:var(--correct);color:var(--correct)}.side-q.saved:before{content:"★";position:absolute;left:4px;top:1px;font-size:.55rem;color:var(--amber)}.side-q.marked:after{content:"";position:absolute;right:4px;top:4px;width:6px;height:6px;background:var(--rose);border-radius:50%}.marked-list{display:flex;flex-direction:column;gap:.38rem}.marked-item{border:1.5px solid var(--rose);background:var(--rose-lt);color:var(--rose);border-radius:8px;padding:.42rem .55rem;font-size:.72rem;font-weight:700;cursor:pointer;text-align:left;font-family:DM Sans,sans-serif}.marked-item:hover{background:#fecdd3}.marked-empty{font-size:.72rem;color:var(--ink3);line-height:1.45}@media(max-width:920px){.quiz-main{display:block;max-width:760px}.quiz-side{position:static;margin-top:1rem}.side-grid{grid-template-columns:repeat(8,1fr)}}.quiz-body{width:100%}.q-meta{display:flex;gap:.42rem;align-items:center;margin-bottom:.95rem;flex-wrap:wrap}.q-num-badge{background:var(--surface2);border:1.5px solid var(--border);border-radius:7px;padding:.16rem .55rem;font-size:.65rem;color:var(--ink3);font-weight:600}.pdf-badge{background:#0d948814;border:1.5px solid rgba(13,148,136,.25);border-radius:7px;padding:.16rem .55rem;font-size:.65rem;color:var(--teal);cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:4px;font-weight:600}.pdf-badge:hover{background:var(--teal-lt)}.pdf-badge.no-pdf{cursor:default;opacity:.4}.cat-pill{border-radius:100px;padding:.18rem .68rem;font-size:.63rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em}.cat-pill.cc{background:#dbeafe;color:#1d4ed8}.cat-pill.sc{background:#fee2e2;color:#b91c1c}.cat-pill.ct{background:#d1fae5;color:#065f46}.cat-pill.bp{background:var(--amber-lt);color:#92400e}.cat-pill.mi{background:#ede9fe;color:#6d28d9}.q-text{font-size:1rem;line-height:1.72;margin-bottom:1.7rem;color:var(--ink)}.options{display:flex;flex-direction:column;gap:.62rem;margin-bottom:1.2rem}.opt{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:.88rem 1.05rem;cursor:pointer;transition:all .15s;display:flex;align-items:flex-start;gap:.65rem;box-shadow:var(--shadow)}.opt:hover:not(.revealed){border-color:var(--teal);background:var(--teal-lt)}.opt-key{background:var(--surface2);border:1.5px solid var(--border);border-radius:7px;width:27px;height:27px;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;flex-shrink:0;transition:all .15s;margin-top:1px;color:var(--ink2)}.opt-text{font-size:.88rem;line-height:1.55;padding-top:2px;color:var(--ink)}.opt.selected{border-color:var(--teal);background:var(--teal-lt)}.opt.selected .opt-key{background:var(--teal);border-color:var(--teal);color:#fff}.opt.correct{border-color:var(--correct);background:var(--correct-lt)}.opt.correct .opt-key{background:var(--correct);border-color:var(--correct);color:#fff}.opt.wrong{border-color:var(--wrong);background:var(--wrong-lt)}.opt.wrong .opt-key{background:var(--wrong);border-color:var(--wrong);color:#fff}.opt.revealed{cursor:default;box-shadow:none}.feedback{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;margin-bottom:1.2rem;display:none;animation:slideUp .22s ease;box-shadow:var(--shadow)}.feedback.show{display:flex;align-items:flex-start;gap:.85rem}.fb-icon{font-size:1.45rem;margin-top:1px}.feedback.fb-correct{border-color:var(--correct);background:var(--correct-lt)}.feedback.fb-wrong{border-color:var(--wrong);background:var(--wrong-lt)}.fb-title{font-weight:700;font-size:.87rem}.feedback.fb-correct .fb-title{color:var(--correct)}.feedback.fb-wrong .fb-title{color:var(--wrong)}.fb-sub{font-size:.76rem;color:var(--ink2);margin-top:3px;line-height:1.55}.pdf-link{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;color:var(--teal);cursor:pointer;margin-top:7px;border:1.5px solid rgba(13,148,136,.3);border-radius:7px;padding:.18rem .62rem;background:#0d948814;transition:all .15s;font-weight:500}.pdf-link:hover{background:var(--teal-lt)}.quiz-nav{display:flex;gap:.65rem}.nav-btn{flex:1;padding:.85rem;border-radius:var(--radius);border:1.5px solid var(--border);cursor:pointer;font-size:.83rem;font-family:DM Sans,sans-serif;font-weight:600;transition:all .15s}.btn-ghost{background:var(--surface);color:var(--ink2)}.btn-ghost:hover{border-color:var(--border2);color:var(--ink)}.btn-next{background:var(--teal);color:#fff;border-color:var(--teal)}.btn-next:hover{background:#0f766e}#progress-screen{flex-direction:column}.list-header{background:var(--surface);border-bottom:1.5px solid var(--border);padding:1rem 1.4rem;display:flex;align-items:center;gap:.9rem;box-shadow:0 1px 4px #0000000d}.list-title{flex:1;font-size:.97rem;font-weight:700;font-family:Fraunces,serif;color:var(--ink)}.week-nav{display:flex;align-items:center;gap:.5rem}.week-nav-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:.27rem .7rem;cursor:pointer;font-size:.74rem;color:var(--ink2);font-family:DM Sans,sans-serif}.week-nav-btn:hover{border-color:var(--border2);color:var(--ink)}.week-lbl{font-size:.7rem;color:var(--ink3);min-width:95px;text-align:center;font-weight:500}.prog-body{flex:1;overflow-y:auto;padding:1.4rem;max-width:820px;width:100%;margin:0 auto}.summary-row{display:flex;gap:.65rem;margin-bottom:1.2rem;flex-wrap:wrap}.s-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:.9rem 1rem;flex:1;min-width:90px;text-align:center;box-shadow:var(--shadow)}.s-num{font-family:Fraunces,serif;font-size:1.65rem;font-weight:700;display:block;line-height:1}.s-num.amber{color:var(--amber)}.s-num.teal{color:var(--teal)}.s-num.rose{color:var(--rose)}.s-num.slate{color:var(--slate)}.s-lbl{font-size:.6rem;text-transform:uppercase;letter-spacing:.09em;color:var(--ink3);margin-top:3px}.chart-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.4rem;margin-bottom:1.15rem;box-shadow:var(--shadow)}.chart-title{font-size:.65rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink3);font-weight:600;margin-bottom:1.3rem}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:140px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;height:100%}.bar-wrap{flex:1;width:100%;display:flex;align-items:flex-end}.bar{width:100%;border-radius:7px 7px 0 0;min-height:4px;transition:height .5s ease;background:linear-gradient(180deg,var(--teal),rgba(13,148,136,.35));position:relative}.bar.today-bar{background:linear-gradient(180deg,var(--amber),rgba(217,119,6,.35))}.bar.zero-bar{background:var(--surface2);border:1.5px solid var(--border);min-height:4px;border-radius:6px}.bar-val{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--ink3);white-space:nowrap;font-weight:600}.bar-val.active{color:var(--teal)}.bar-val.today{color:var(--amber)}.bar-day{font-size:.63rem;color:var(--ink3);font-weight:600;white-space:nowrap}.bar-day.today{color:var(--amber)}.bar-date{font-size:.54rem;color:var(--ink3)}.heatmap-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.3rem;margin-bottom:1.15rem;box-shadow:var(--shadow)}.hm-grid{display:flex;gap:4px;flex-wrap:wrap}.hm-cell{width:21px;height:21px;border-radius:4px;background:var(--surface2);border:1.5px solid var(--border);cursor:default;transition:all .15s;position:relative}.hm-cell:hover:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--ink);color:#fff;border-radius:7px;padding:.25rem .6rem;font-size:.6rem;white-space:nowrap;z-index:10}.hm-cell.lvl1{background:#0d948826;border-color:#0d94884d}.hm-cell.lvl2{background:#0d94884d;border-color:#0d948880}.hm-cell.lvl3{background:#0d94888c;border-color:#0d9488b3}.hm-cell.lvl4{background:var(--teal);border-color:var(--teal)}.hm-cell.today-cell{outline:2.5px solid var(--amber);outline-offset:2px}.hm-legend{display:flex;align-items:center;gap:.45rem;margin-top:.85rem;font-size:.62rem;color:var(--ink3);font-weight:500}.lc{width:15px;height:15px;border-radius:4px;border:1.5px solid var(--border)}.lc.l0{background:var(--surface2)}.lc.l1{background:#0d948826;border-color:#0d94884d}.lc.l2{background:#0d94884d;border-color:#0d948880}.lc.l3{background:#0d94888c;border-color:#0d9488b3}.lc.l4{background:var(--teal);border-color:var(--teal)}.breakdown-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.3rem;margin-bottom:1.15rem;box-shadow:var(--shadow)}.bd-row{display:flex;align-items:center;gap:.8rem;margin-bottom:.75rem}.bd-label{font-size:.74rem;color:var(--ink2);min-width:120px;font-weight:600}.bd-bar-wrap{flex:1;height:8px;background:var(--surface2);border-radius:100px;overflow:hidden;border:1px solid var(--border)}.bd-bar{height:100%;border-radius:100px;transition:width .6s ease}.bd-nums{font-size:.68rem;color:var(--ink3);min-width:82px;text-align:right;font-weight:500}#check-screen{flex-direction:column}.check-body{flex:1;overflow-y:auto;padding:1.5rem;max-width:820px;width:100%;margin:0 auto}.check-hero{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.15rem;box-shadow:var(--shadow)}.check-hero-title{font-family:Fraunces,serif;font-size:1.2rem;font-weight:700;margin-bottom:.35rem}.check-hero-sub{font-size:.8rem;color:var(--ink2);line-height:1.6}.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.15rem}@media(max-width:500px){.check-grid{grid-template-columns:1fr}}.check-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.3rem;box-shadow:var(--shadow)}.check-card.pass{border-color:var(--correct)}.check-card.fail{border-color:var(--wrong)}.check-card.warn{border-color:var(--amber)}.check-status{display:flex;align-items:center;gap:.6rem;margin-bottom:.35rem}.check-icon{font-size:1.3rem}.check-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink2)}.check-value{font-family:Fraunces,serif;font-size:1.6rem;font-weight:700;color:var(--ink);line-height:1}.check-detail{font-size:.7rem;color:var(--ink3);margin-top:3px;line-height:1.5}.check-value.green{color:var(--correct)}.check-value.amber{color:var(--amber)}.check-value.red{color:var(--wrong)}.check-run-btn{width:100%;padding:.9rem;background:var(--teal);color:#fff;border:none;border-radius:var(--radius);font-size:.88rem;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;margin-bottom:1.15rem;transition:all .15s;box-shadow:0 4px 12px #0d948833}.check-run-btn:hover{background:#0f766e}.check-log{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1.2rem;box-shadow:var(--shadow)}.check-log-title{font-size:.65rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink3);font-weight:600;margin-bottom:.85rem}.check-log-item{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.55rem;font-size:.78rem}.log-icon{flex-shrink:0;margin-top:1px}.log-text{color:var(--ink2);line-height:1.5}.log-text strong{color:var(--ink)}#result-screen{justify-content:center;align-items:center;padding:2rem}.result-inner{max-width:550px;width:100%;text-align:center}.score-wrap{position:relative;width:134px;height:134px;margin:0 auto 1.8rem}.score-wrap svg{position:absolute;top:0;left:0;transform:rotate(-90deg)}.score-center{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column}.score-pct{font-family:Fraunces,serif;font-size:2.2rem;font-weight:700;color:var(--teal);line-height:1}.score-lbl{font-size:.63rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-top:2px}.result-title{font-family:Fraunces,serif;font-size:1.5rem;font-weight:700;margin-bottom:.45rem}.result-sub{color:var(--ink3);font-size:.8rem;margin-bottom:1.6rem}.result-stats{display:flex;gap:.65rem;margin-bottom:1.5rem}.rs{flex:1;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:.88rem;box-shadow:var(--shadow)}.rs-num{font-family:Fraunces,serif;font-size:1.55rem;font-weight:700;display:block}.rs-num.g{color:var(--correct)}.rs-num.r{color:var(--wrong)}.rs-num.a{color:var(--amber)}.rs-lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink3)}.result-btns{display:flex;flex-direction:column;gap:.55rem}.res-btn{padding:.85rem;border-radius:var(--radius);border:1.5px solid var(--border);cursor:pointer;font-size:.85rem;font-family:DM Sans,sans-serif;font-weight:600;transition:all .15s}.res-btn.primary{background:var(--amber);color:#fff;border-color:var(--amber)}.res-btn.primary:hover{background:#b45309}.res-btn.ghost{background:var(--surface);color:var(--ink2)}.res-btn.ghost:hover{color:var(--ink);border-color:var(--border2)}.filter-bar{padding:.8rem 1.3rem;display:flex;gap:.38rem;overflow-x:auto;border-bottom:1.5px solid var(--border);background:var(--surface)}.filter-chip{background:var(--surface2);border:1.5px solid var(--border);border-radius:100px;padding:.24rem .78rem;font-size:.66rem;cursor:pointer;white-space:nowrap;color:var(--ink2);transition:all .15s;font-weight:500}.filter-chip:hover{border-color:var(--teal)}.filter-chip.active{background:var(--teal-lt);border-color:var(--teal);color:var(--teal);font-weight:600}.filter-chip-week{border-style:dashed}.list-body{flex:1;overflow-y:auto;padding:1.1rem 1.3rem;max-width:760px;width:100%;margin:0 auto}.q-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:1rem 1.2rem;margin-bottom:.55rem;transition:all .15s;box-shadow:var(--shadow)}.q-card:hover{border-color:var(--teal)}.q-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.65rem;margin-bottom:.42rem}.q-card-txt{font-size:.83rem;line-height:1.5;color:var(--ink);flex:1;cursor:pointer}.q-card-badge{font-size:.6rem;color:var(--ink3);white-space:nowrap;font-weight:500}.q-card-meta{display:flex;gap:.35rem;align-items:center;flex-wrap:wrap}.tag{border-radius:5px;padding:.1rem .46rem;font-size:.61rem;font-weight:700}.tag.wrong-tag{background:var(--wrong-lt);color:var(--wrong)}.tag.bm-tag{background:var(--amber-lt);color:var(--amber)}.tag.pdf-tag{background:var(--teal-lt);color:var(--teal)}.remove-btn{background:none;border:none;cursor:pointer;font-size:.8rem;color:var(--ink3);padding:.1rem .3rem;border-radius:5px;transition:all .15s;flex-shrink:0;margin-left:auto}.remove-btn:hover{background:var(--wrong-lt);color:var(--wrong)}.empty-state{text-align:center;padding:4rem 2rem;color:var(--ink3)}.empty-icon{font-size:3rem;display:block;margin-bottom:1rem}.modal-overlay{display:none;position:fixed;inset:0;background:#1c1917b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;flex-direction:column;align-items:center;justify-content:center;padding:1rem}.modal-overlay.show{display:flex}.modal-box{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);width:100%;max-width:900px;height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-md)}.modal-hdr{display:flex;align-items:center;gap:1rem;padding:.9rem 1.25rem;border-bottom:1.5px solid var(--border)}.modal-ttl{flex:1;font-size:.88rem;font-weight:700}.modal-close{background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:.3rem .68rem;cursor:pointer;font-size:.76rem;color:var(--ink2)}.modal-close:hover{color:var(--ink)}.modal-nav{display:flex;align-items:center;gap:.62rem;padding:.62rem 1.25rem;border-bottom:1.5px solid var(--border);background:var(--bg)}.pg-nav-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:7px;padding:.27rem .72rem;cursor:pointer;font-size:.74rem;color:var(--ink2);font-family:DM Sans,sans-serif}.pg-nav-btn:hover{color:var(--ink)}.pg-input-wrap{display:flex;align-items:center;gap:.42rem;font-size:.74rem;color:var(--ink2)}.pg-input{width:50px;background:var(--surface);border:1.5px solid var(--border);border-radius:6px;padding:.24rem .46rem;color:var(--ink);font-size:.78rem;text-align:center;font-family:DM Sans,sans-serif}.pdf-canvas-wrap{flex:1;overflow:auto;display:flex;align-items:flex-start;justify-content:center;padding:1.2rem;background:#f8f5f0}#pdf-canvas{max-width:100%;border-radius:6px;box-shadow:0 4px 24px #0000001f}.pdf-no-file{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--ink3);gap:1rem;padding:2rem;text-align:center}.pdf-no-file .big-icon{font-size:3rem}.pdf-no-file p{font-size:.84rem;line-height:1.6}.pdf-upload-here{padding:.52rem 1.15rem;background:var(--teal);color:#fff;border:none;border-radius:9px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif}.multi-hint{font-size:.72rem;color:var(--amber);font-weight:600;background:var(--amber-lt);border:1px solid var(--amber-md);border-radius:8px;padding:.3rem .75rem;display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.85rem}.opt.multi-selected{border-color:var(--teal);background:var(--teal-lt)}.opt.multi-selected .opt-key{background:var(--teal);border-color:var(--teal);color:#fff}.opt.multi-correct{border-color:var(--correct);background:var(--correct-lt)}.opt.multi-correct .opt-key{background:var(--correct);border-color:var(--correct);color:#fff}.opt.multi-wrong-sel{border-color:var(--wrong);background:var(--wrong-lt)}.opt.multi-wrong-sel .opt-key{background:var(--wrong);border-color:var(--wrong);color:#fff}.opt.multi-missed{border-color:var(--correct);background:var(--correct-lt);opacity:.7}.multi-submit-btn{width:100%;padding:.82rem;background:var(--teal);color:#fff;border:none;border-radius:var(--radius);font-size:.88rem;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;margin-bottom:.75rem;transition:all .15s;box-shadow:0 3px 10px #0d948833}.multi-submit-btn:hover{background:#0f766e}.multi-submit-btn:disabled{background:var(--border2);cursor:default;box-shadow:none}.comment-section{margin-top:1.1rem;border-top:1.5px dashed var(--border);padding:1rem .9rem .9rem;background:linear-gradient(180deg,#ffffffb8,#f0ece48c);border-radius:14px}.comment-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-bottom:.45rem;display:flex;align-items:center;gap:.45rem}.comment-textarea{width:100%;min-height:170px;background:var(--surface);border:1.5px solid var(--border);border-radius:12px;padding:.9rem 1rem;font-size:.9rem;font-family:DM Sans,sans-serif;color:var(--ink);line-height:1.65;resize:vertical;transition:border-color .15s;outline:none}.comment-textarea:focus{border-color:var(--amber)}.comment-textarea::-moz-placeholder{color:var(--ink3)}.comment-textarea::placeholder{color:var(--ink3)}.comment-actions{display:flex;align-items:center;gap:.5rem;margin-top:.42rem}.comment-save-btn{padding:.3rem .82rem;background:var(--amber);color:#fff;border:none;border-radius:8px;font-size:.73rem;font-weight:700;cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s}.comment-save-btn:hover{background:#b45309}.comment-clear-btn{padding:.3rem .72rem;background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;font-size:.73rem;color:var(--ink3);cursor:pointer;font-family:DM Sans,sans-serif;transition:all .15s}.comment-clear-btn:hover{color:var(--wrong);border-color:var(--wrong)}.comment-saved-badge{font-size:.67rem;color:var(--teal);margin-left:auto;opacity:0;transition:opacity .4s}.comment-saved-badge.show{opacity:1}.comment-snippet{font-size:.7rem;color:var(--ink2);margin-top:.38rem;padding:.28rem .5rem;background:var(--amber-lt);border-left:2.5px solid var(--amber);border-radius:0 5px 5px 0;line-height:1.45;font-style:italic;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.toast{position:fixed;bottom:1.4rem;left:50%;transform:translate(-50%) translateY(100px);background:var(--ink);color:#fff;border-radius:100px;padding:.62rem 1.3rem;font-size:.8rem;z-index:200;transition:transform .3s ease;white-space:nowrap;box-shadow:var(--shadow-md)}.toast.show{transform:translate(-50%) translateY(0)}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.04)}to{transform:scale(1)}}.pop{animation:pop .2s ease}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:100px}
