*,: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}.container{width:100%}@media(min-width:640px){.container{max-width:640px}}@media(min-width:768px){.container{max-width:768px}}@media(min-width:1024px){.container{max-width:1024px}}@media(min-width:1280px){.container{max-width:1280px}}@media(min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.bottom-4{bottom:1rem}.left-2{left:.5rem}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-1\.5{right:.375rem}.right-2{right:.5rem}.start-0{inset-inline-start:0px}.top-1\.5{top:.375rem}.top-1\/2{top:50%}.top-2{top:.5rem}.top-full{top:100%}.-z-10{z-index:-10}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.col-span-full{grid-column:1 / -1}.m-4{margin:1rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.-mr-1{margin-right:-.25rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-16{margin-bottom:4rem}.mb-8{margin-bottom:2rem}.me-4{margin-inline-end:1rem}.ml-16{margin-left:4rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.ml-64{margin-left:16rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-auto{margin-right:auto}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-\[260px\]{height:260px}.h-\[400px\]{height:400px}.h-auto{height:auto}.h-full{height:100%}.h-screen{height:100vh}.min-h-0{min-height:0px}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-64{width:16rem}.w-8{width:2rem}.w-\[220px\]{width:220px}.w-\[600px\]{width:600px}.w-auto{width:auto}.w-px{width:1px}.min-w-0{min-width:0px}.min-w-\[180px\]{min-width:180px}.min-w-fit{min-width:-moz-fit-content;min-width:fit-content}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-\[1400px\]{max-width:1400px}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-screen-xl{max-width:1280px}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.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))}.rotate-180{--tw-rotate: 180deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-\[1\.02\]{--tw-scale-x: 1.02;--tw-scale-y: 1.02;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-pointer{cursor:pointer}.resize-none{resize:none}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.justify-center{justify-content:center}.gap-3{gap:.75rem}.gap-8{gap:2rem}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(1.5rem * var(--tw-space-x-reverse));margin-left:calc(1.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-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.place-self-center{place-self:center}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-none{border-style:none}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.border-charcoal-200{--tw-border-opacity: 1;border-color:rgb(212 216 219 / var(--tw-border-opacity, 1))}.border-gray-100{--tw-border-opacity: 1;border-color:rgb(243 244 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-gray-400{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.border-gray-500\/30{border-color:#6b72804d}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.border-yellow-200{--tw-border-opacity: 1;border-color:rgb(254 240 138 / var(--tw-border-opacity, 1))}.bg-\[\#0078D4\]{--tw-bg-opacity: 1;background-color:rgb(0 120 212 / var(--tw-bg-opacity, 1))}.bg-\[\#515b63\]{--tw-bg-opacity: 1;background-color:rgb(81 91 99 / var(--tw-bg-opacity, 1))}.bg-\[\#faf9f8\]{--tw-bg-opacity: 1;background-color:rgb(250 249 248 / var(--tw-bg-opacity, 1))}.bg-black\/30{background-color:#0000004d}.bg-black\/50{background-color:#00000080}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-indigo-500\/30{background-color:#6366f14d}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-indigo-600\/10{background-color:#4f46e51a}.bg-purple-600{--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/20{background-color:#fff3}.bg-white\/90{background-color:#ffffffe6}.bg-white\/95{background-color:#fffffff2}.bg-yellow-50{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-\[\#1bc3de\]{--tw-gradient-from: #1bc3de var(--tw-gradient-from-position);--tw-gradient-to: rgb(27 195 222 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-gray-700{--tw-gradient-from: #374151 var(--tw-gradient-from-position);--tw-gradient-to: rgb(55 65 81 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-500{--tw-gradient-from: #6366f1 var(--tw-gradient-from-position);--tw-gradient-to: rgb(99 102 241 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-\[\#132442\]{--tw-gradient-to: #132442 var(--tw-gradient-to-position)}.to-gray-800{--tw-gradient-to: #1f2937 var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to: #9333ea var(--tw-gradient-to-position)}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-12{padding-bottom:3rem}.pb-2{padding-bottom:.5rem}.pl-10{padding-left:2.5rem}.pr-4{padding-right:1rem}.pt-2{padding-top:.5rem}.pt-24{padding-top:6rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.font-sans{font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji"}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[10px\]{font-size:10px}.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-extrabold{font-weight:800}.font-light{font-weight:300}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-none{line-height:1}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.text-\[\#0078D4\]{--tw-text-opacity: 1;color:rgb(0 120 212 / var(--tw-text-opacity, 1))}.text-\[\#323130\]{--tw-text-opacity: 1;color:rgb(50 49 48 / var(--tw-text-opacity, 1))}.text-\[\#515b63\]{--tw-text-opacity: 1;color:rgb(81 91 99 / var(--tw-text-opacity, 1))}.text-accent{--tw-text-opacity: 1;color:rgb(41 121 112 / var(--tw-text-opacity, 1))}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.text-charcoal-400{--tw-text-opacity: 1;color:rgb(133 143 151 / var(--tw-text-opacity, 1))}.text-charcoal-500{--tw-text-opacity: 1;color:rgb(103 115 124 / var(--tw-text-opacity, 1))}.text-charcoal-700{--tw-text-opacity: 1;color:rgb(74 88 89 / var(--tw-text-opacity, 1))}.text-charcoal-800{--tw-text-opacity: 1;color:rgb(54 69 79 / var(--tw-text-opacity, 1))}.text-emerald-600{--tw-text-opacity: 1;color:rgb(5 150 105 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/60{color:#fff9}.text-yellow-800{--tw-text-opacity: 1;color:rgb(133 77 14 / var(--tw-text-opacity, 1))}.no-underline{text-decoration-line:none}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-indigo-400{--tw-ring-opacity: 1;--tw-ring-color: rgb(129 140 248 / var(--tw-ring-opacity, 1))}.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)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur: blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-300{transition-duration:.3s}.\[-\:\\\|\\s\]{-: \|s}:root{--color-primary-brand: #297970;--color-primary-brand-hover: #236963;--color-primary-brand-light: rgba(41, 121, 112, .1);--color-accent: #297970;--color-accent-primary: #297970;--color-accent-light: #4a9f9b;--color-charcoal-dark: #36454F;--color-charcoal: #515b63;--color-charcoal-light: #6b7580;--color-bg-primary: #f9fafb;--color-bg-secondary: #f3f4f6;--color-bg-tertiary: #ffffff;--color-bg-card: #ffffff;--color-bg-dark: #1f2937;--color-bg-hover: #e5e7eb;--color-text-primary: #111827;--color-text-secondary: #4b5563;--color-text-muted: #6b7280;--color-text-on-dark: #ffffff;--color-text-on-accent: #ffffff;--color-border: #e5e7eb;--color-border-focus: #008080;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--font-family: "Inter", system-ui, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .3s ease}.dark-theme{--color-bg-primary: #1a1a2e;--color-bg-secondary: #16213e;--color-bg-tertiary: #1f2937;--color-bg-card: #1f2937;--color-bg-hover: #374151;--color-text-primary: #f3f4f6;--color-text-secondary: #d1d5db;--color-text-muted: #9ca3af;--color-border: #374151;--color-charcoal: #2d3748;--color-charcoal-dark: #1a202c;--color-charcoal-light: #4a5568}.dark-theme body,.dark-theme .settings-page,.dark-theme .settings-container,.dark-theme .settings-content,.dark-theme .settings-panel{background-color:var(--color-bg-primary);color:var(--color-text-primary)}.font-size-small{font-size:14px}.font-size-small .settings-panel h2{font-size:16px}.font-size-small .settings-description,.font-size-small .setting-group label{font-size:12px}.font-size-medium{font-size:16px}.font-size-large{font-size:18px}.font-size-large .settings-panel h2{font-size:22px}.font-size-large .settings-description,.font-size-large .setting-group label{font-size:16px}.font-size-xlarge{font-size:20px}.font-size-xlarge .settings-panel h2{font-size:26px}.font-size-xlarge .settings-description,.font-size-xlarge .setting-group label{font-size:18px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-family);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;overflow-x:hidden}a{color:var(--color-primary-brand);text-decoration:none}a:hover{color:var(--color-primary-brand-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm);font-weight:500;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background-color:var(--color-primary-brand);color:var(--color-text-on-dark)}.btn-primary:hover{background-color:var(--color-primary-brand-hover)}.btn-secondary{background-color:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background-color:var(--color-bg-hover)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm)}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);font-weight:600;border-radius:var(--radius-full);background:var(--color-bg-secondary);color:var(--color-text-secondary)}.badge-primary{background:var(--color-primary-brand-light);color:var(--color-primary-brand)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.fade-in{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.hover\:border-blue-200:hover{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.hover\:border-indigo-600:hover{--tw-border-opacity: 1;border-color:rgb(79 70 229 / var(--tw-border-opacity, 1))}.hover\:bg-\[\#005a9e\]:hover{--tw-bg-opacity: 1;background-color:rgb(0 90 158 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-100:hover{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity, 1))}.hover\:bg-emerald-50:hover{--tw-bg-opacity: 1;background-color:rgb(236 253 245 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-50:hover{--tw-bg-opacity: 1;background-color:rgb(238 242 255 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-600\/70:hover{background-color:#4f46e5b3}.hover\:bg-indigo-700:hover{--tw-bg-opacity: 1;background-color:rgb(67 56 202 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-50:hover{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-700:hover{--tw-bg-opacity: 1;background-color:rgb(126 34 206 / var(--tw-bg-opacity, 1))}.hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.hover\:bg-red-700:hover{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity, 1))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/20:hover{background-color:#fff3}.hover\:bg-white\/5:hover{background-color:#ffffff0d}.hover\:text-blue-700:hover{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.hover\:text-indigo-600:hover{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow-lg:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-indigo-500:focus{--tw-border-opacity: 1;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:bg-white:focus{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-4: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(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-300:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(147 197 253 / var(--tw-ring-opacity, 1))}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.focus\:ring-gray-100:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(243 244 246 / var(--tw-ring-opacity, 1))}.focus\:ring-indigo-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(99 102 241 / var(--tw-ring-opacity, 1))}.group:hover .group-hover\:text-indigo-600{--tw-text-opacity: 1;color:rgb(79 70 229 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:opacity-100{opacity:1}@media(min-width:640px){.sm\:mt-0{margin-top:0}.sm\:block{display:block}.sm\:text-center{text-align:center}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media(min-width:768px){.md\:order-2{order:2}.md\:me-6{margin-inline-end:1.5rem}.md\:block{display:block}.md\:flex{display:flex}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:space-x-0>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(0px * var(--tw-space-x-reverse));margin-left:calc(0px * calc(1 - var(--tw-space-x-reverse)))}.md\:px-8{padding-left:2rem;padding-right:2rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}}@media(min-width:1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-5{grid-column:span 5 / span 5}.lg\:col-span-7{grid-column:span 7 / span 7}.lg\:mb-16{margin-bottom:4rem}.lg\:mb-8{margin-bottom:2rem}.lg\:mt-0{margin-top:0}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:gap-8{gap:2rem}.lg\:py-16{padding-top:4rem;padding-bottom:4rem}.lg\:pb-24{padding-bottom:6rem}.lg\:pt-32{padding-top:8rem}.lg\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media(min-width:1280px){.xl\:gap-0{gap:0px}.xl\:text-6xl{font-size:3.75rem;line-height:1}}.rtl\:space-x-reverse:where([dir=rtl],[dir=rtl] *)>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 1}@media(prefers-color-scheme:dark){.dark\:bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.dark\:text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2c3539,#36454f,#4a5859);padding:1rem}.login-container{width:100%;max-width:400px;background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.login-header p{color:#64748b;margin:0}.login-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e2e8f0}.login-divider span{font-size:.8rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.social-login{display:flex;gap:.75rem}.btn-social{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#fff;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;font-weight:500;color:#475569;cursor:pointer;transition:all .2s}.btn-social:hover{background:#f8fafc;border-color:#cbd5e1}.btn-social.google:hover,.btn-social.microsoft:hover{border-color:#297970}.login-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:#64748b}.login-footer a{color:#297970;text-decoration:none;font-weight:500}.login-footer a:hover{text-decoration:underline}.signup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2c3539,#36454f,#4a5859);padding:1rem}.signup-container{width:100%;max-width:420px;background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 20px 60px #0000004d}.success-container{text-align:center}.success-icon{width:80px;height:80px;background:#dcfce7;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#16a34a;margin:0 auto 1.5rem}.success-container h2{color:#16a34a;margin:0 0 .5rem}.success-container p{color:#64748b}.signup-header{text-align:center;margin-bottom:2rem}.signup-header h1{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.signup-header p{color:#64748b;margin:0}.signup-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:1.5rem}.signup-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-size:.875rem;font-weight:500;color:#475569}.input-wrapper{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;transition:all .2s}.input-wrapper:focus-within{border-color:#297970;background:#fff;box-shadow:0 0 0 3px #0080801a}.input-wrapper svg{color:#94a3b8;flex-shrink:0}.input-wrapper input{flex:1;border:none;background:transparent;font-size:.9rem;color:#1e293b;outline:none}.input-wrapper input::-moz-placeholder{color:#94a3b8}.input-wrapper input::placeholder{color:#94a3b8}.toggle-password{background:none;border:none;padding:0;cursor:pointer;color:#94a3b8;display:flex}.toggle-password:hover{color:#64748b}.btn-primary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;background:linear-gradient(135deg,#297970,#4a9f9b);color:#fff;border:none;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #00808066}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.signup-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:#64748b}.signup-footer a{color:#297970;text-decoration:none;font-weight:500}.signup-footer a:hover{text-decoration:underline}.toast-container{position:fixed;top:80px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;background:#fff;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;min-width:280px;max-width:400px}.toast-success{border-left:4px solid #10b981}.toast-success .toast-icon{color:#10b981}.toast-error{border-left:4px solid #ef4444}.toast-error .toast-icon{color:#ef4444}.toast-warning{border-left:4px solid #f59e0b}.toast-warning .toast-icon{color:#f59e0b}.toast-info{border-left:4px solid #3b82f6}.toast-info .toast-icon{color:#3b82f6}.toast-icon{flex-shrink:0}.toast-message{flex:1;font-size:14px;color:#374151;line-height:1.4}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:#9ca3af;cursor:pointer;border-radius:4px;transition:all .2s}.toast-close:hover{background:#f3f4f6;color:#374151}.toast-enter{animation:toastSlideIn .3s ease-out forwards}.toast-exit{animation:toastSlideOut .3s ease-in forwards}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toastSlideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}@media(max-width:480px){.toast-container{left:10px;right:10px;max-width:none}.toast{min-width:auto;max-width:none}}.home-page{padding-bottom:var(--spacing-2xl)}.hero{position:relative;text-align:center;padding:100px var(--spacing-lg);margin-bottom:var(--spacing-xl);background:var(--color-bg-dark);color:var(--color-text-on-dark);border-radius:var(--radius-xl);overflow:hidden;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--shadow-xl)}.hero-video-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1}.hero-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.3}.hero-video-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#000c,#0009);z-index:2}.hero-content{position:relative;z-index:3;width:100%;max-width:800px}.hero-logo-img{height:80px;margin-bottom:var(--spacing-md);filter:drop-shadow(0 4px 6px rgba(0,0,0,.3));animation:fadeSlideDown .8s ease-out}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.hero-title{font-size:3.5rem;font-weight:800;margin-bottom:var(--spacing-sm);line-height:1.1;color:var(--color-text-on-dark);text-shadow:0 2px 4px rgba(0,0,0,.3)}.hero-subtitle{font-size:1.25rem;color:#ffffffe6;max-width:600px;margin:0 auto var(--spacing-xl);font-weight:300}.search-container{position:relative;max-width:800px;width:100%;margin:0 auto;border-radius:8px!important}.search-icon{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);font-size:1.25rem;pointer-events:none;color:var(--color-text-muted)}.search-input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 3rem;font-size:var(--font-size-base);border-radius:8px;background:var(--color-bg-primary);border:2px solid transparent}.search-input:focus{border-color:var(--color-primary-brand);box-shadow:0 0 0 3px var(--color-primary-brand-light)}.stats{display:flex;justify-content:center;gap:var(--spacing-lg);margin:calc(-1 * var(--spacing-lg)) auto var(--spacing-xl);max-width:600px;position:relative;z-index:1}.stat-card{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:120px;box-shadow:var(--shadow-md)}.stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary-brand)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.modules-section{margin-top:var(--spacing-md)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-title{margin-bottom:0;font-size:var(--font-size-lg);color:var(--color-text-primary)}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.modules-grid>a,.modules-grid>div,.modules-grid>.group,.modules-grid>.draggable-module-card{display:block;height:260px}.modules-grid>a>div,.modules-grid>div>a>div,.modules-grid>.group>div,.modules-grid>.draggable-module-card>a>div,.draggable-module-card>a>div{display:flex;flex-direction:column;width:100%;height:260px!important;box-sizing:border-box}.module-card-header{height:96px;flex-shrink:0}.module-card-body{flex:1;display:flex;flex-direction:column;padding:16px;min-height:0}.module-card-category{height:16px;flex-shrink:0;overflow:hidden}.module-card-title{height:48px;flex-shrink:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2}.module-card-description{height:40px;flex-shrink:0;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2}.module-card-footer{margin-top:auto;flex-shrink:0}.module-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;animation:fadeIn .3s ease-out both;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5rem;transition:all var(--transition-normal)}.module-card:hover{border-color:var(--color-primary-brand);box-shadow:var(--shadow-md);transform:translateY(-2px)}.module-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.module-sequence{font-size:.6rem;font-weight:700;color:var(--color-primary-brand);letter-spacing:.05em;background:var(--color-primary-brand-light);padding:.1rem .3rem;border-radius:3px}.module-title{font-size:.85rem;font-weight:600;margin-bottom:.25rem;color:var(--color-text-primary);line-height:1.25}.module-description{font-size:.7rem;color:var(--color-text-secondary);margin-bottom:.35rem;flex:1;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;overflow:hidden}.module-footer{margin-top:auto;padding-top:.35rem;border-top:1px solid var(--color-border)}.module-progress-text{font-size:.65rem;color:var(--color-text-muted);margin-top:.25rem;display:block}.skeleton-card{padding:var(--spacing-lg);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-height:200px}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--color-text-muted);background:var(--color-bg-secondary);border-radius:var(--radius-lg)}.error-message{text-align:center;padding:var(--spacing-xl);color:var(--color-error);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);background:#dc35451a;border-radius:var(--radius-lg)}.quick-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}@media(max-width:768px){.hero{padding:var(--spacing-xl) var(--spacing-md);border-radius:0;margin:0 calc(-1 * var(--spacing-lg)) var(--spacing-xl)}.hero-title{font-size:1.75rem}.stats{flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.stat-card{min-width:90px;padding:var(--spacing-sm) var(--spacing-md)}.modules-grid{grid-template-columns:1fr}}.category-section{margin-bottom:4rem;animation:fadeIn .5s ease-out}.category-header{display:flex;align-items:center;border-bottom:2px solid var(--color-border);padding-bottom:.5rem;margin-bottom:1.5rem}.category-title{font-size:1.75rem;font-weight:700;margin:0;color:var(--color-text-primary)}.subcategory-section{margin-left:1rem;margin-bottom:2rem;padding-left:1rem;border-left:2px solid var(--color-border)}.subcategory-title{font-size:1.25rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:1rem;display:flex;align-items:center}.empty-subcategory{padding:1rem;background:var(--color-bg-secondary);border-radius:var(--radius-sm);color:var(--color-text-muted)}.mb-6{margin-bottom:1.5rem}.main-layout{display:flex;max-width:100%;margin:0 auto;padding:0 1rem;gap:2rem;min-height:500px}.sidebar-panel{width:360px!important;min-width:360px!important;flex-shrink:0;position:sticky;top:80px;height:calc(100vh - 100px);overflow-y:auto;border-right:1px solid var(--color-border);padding-right:2rem}.content-panel{flex:1;min-width:0}.sidebar-header{display:flex;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.sidebar-header h3{font-weight:800;text-transform:uppercase;font-size:.9rem;letter-spacing:.05em;margin:0;color:var(--color-text-primary)}.category-tree,.tree-node-wrapper{display:flex;flex-direction:column}.tree-node{display:flex;align-items:center;padding:.35rem .5rem;cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text-secondary);transition:background-color .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.tree-node:hover{background-color:var(--color-bg-secondary);color:var(--color-text-primary)}.tree-node.selected{background-color:var(--color-primary-brand-light);color:var(--color-primary-brand);font-weight:600}.node-toggle{width:24px;height:24px;display:flex;align-items:center;justify-content:center;margin-right:.25rem;border-radius:4px;color:var(--color-text-muted);cursor:pointer}.node-toggle:hover{background-color:#0000000d}.node-toggle.empty{width:24px}.node-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.95rem}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border);padding-bottom:1rem}.panel-header h2{margin:0;font-size:1.5rem}@media(max-width:800px){.main-layout{flex-direction:column;padding:0 1rem}.sidebar-panel{width:100%;border-right:none;border-bottom:1px solid var(--color-border);padding-right:0;padding-bottom:1rem;margin-bottom:1rem}}.hero{padding:50px var(--spacing-lg)!important;min-height:300px}.hero-title{font-size:3rem}.module-title{color:#1a1a1a!important;font-size:1.1rem;line-height:1.4;display:block;min-height:1.4em}.breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;font-size:.9rem;color:var(--color-text-secondary);margin-bottom:.5rem}.crumb-item{cursor:pointer;transition:color .15s}.crumb-item:hover{color:var(--color-primary-brand);text-decoration:underline}.crumb-item.active{font-weight:600;color:var(--color-text-primary);cursor:default}.crumb-item.active:hover{text-decoration:none}.crumb-wrapper{display:flex;align-items:center}.crumb-separator{margin:0 .5rem;color:var(--color-text-muted)}.panel-header-column{display:flex;flex-direction:column;padding-bottom:1rem;border-bottom:1px solid var(--color-border);margin-bottom:1.5rem}.header-row{display:flex;justify-content:space-between;align-items:center;width:100%;margin-top:.5rem}.header-row h2{margin:0;font-size:1.5rem}.mt-4{margin-top:1rem}.hero{background:linear-gradient(135deg,#1c2826,#2c3e3e)!important;position:relative;padding:1.5rem 3rem!important;border-radius:0 0 var(--radius-xl) var(--radius-xl)!important;margin-bottom:2rem!important;box-shadow:0 10px 30px #00000026;overflow:hidden;min-height:auto!important;display:flex!important;flex-direction:column}.hero-video-overlay{background:linear-gradient(to right,#0f172a,#0f172a99 60%,#0f172a1a)!important}.hero-content{display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;position:relative;z-index:10;width:100%}.hero-brand-group{display:flex;align-items:center;gap:1.5rem}.hero-logo-img{height:60px!important;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));margin:0!important;animation:none!important}.hero-text{text-align:left}.hero-title{font-family:Outfit,sans-serif;font-size:1.75rem!important;font-weight:700;color:#fff;margin:0!important;letter-spacing:-.02em}.hero-subtitle{font-size:.95rem!important;color:#ffffffb3;margin:0!important;font-weight:400}.search-container{position:relative;width:400px!important;height:48px;background:#ffffff1a;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.2);border-radius:9999px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;margin:0!important}.search-container:focus-within{background:#ffffff26;border-color:#ffffff80;box-shadow:0 4px 20px #0003;transform:translateY(-1px)}.search-icon{position:absolute;left:16px!important;top:50%;transform:translateY(-50%);color:#fff9!important;width:18px!important;height:18px!important;pointer-events:none;transition:color .3s}.search-container:focus-within .search-icon{color:#fff!important}.search-input{width:100%;height:100%;background:transparent!important;border:none!important;padding:0 16px 0 48px!important;font-size:.95rem;color:#fff;font-weight:400;outline:none;box-shadow:none!important}.search-input::-moz-placeholder{color:#ffffff80}.search-input::placeholder{color:#ffffff80}@media(max-width:900px){.hero{padding:2rem!important;border-radius:0!important}.hero-content{flex-direction:column!important;gap:1.5rem!important;align-items:center!important}.hero-brand-group{flex-direction:column;gap:1rem;text-align:center}.hero-text{text-align:center}.search-container{width:100%!important;max-width:400px}}.line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.module-card-wrapper{height:260px;position:relative}.module-card-wrapper a{display:block;height:260px}.draggable-module-card{height:260px;position:relative}.draggable-module-card a{display:block;height:260px}.draggable-module-card[style*="visibility: hidden"]{min-height:260px}.draggable-module-card .drag-handle{position:absolute;top:8px;left:8px;z-index:20;padding:6px;background:#00000080;border-radius:4px;cursor:grab;opacity:0;transition:opacity .2s,background-color .2s}.draggable-module-card:hover .drag-handle{opacity:1}.draggable-module-card .drag-handle:hover{background:#6366f1e6}.draggable-module-card .drag-handle:active{cursor:grabbing}.modules-grid .draggable-module-card,.modules-grid .draggable-module-card>a,.modules-grid .draggable-module-card>a>div{height:260px!important}.draggable-module-card>div:only-child:not(:has(a)){background-color:#f9fafb!important;border:2px dashed #d1d5db!important}.draggable-module-card[data-dragging=true]{background:transparent!important}.module-page-new{display:flex;height:calc(100vh - 64px);background:var(--color-bg-secondary, #f9fafb);overflow:hidden}.module-page-new .sections-nav-panel{background:#fff;border-right:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;transition:width .3s ease;flex-shrink:0;height:100%;overflow:hidden}.module-page-new .sections-nav-panel.open{width:280px;min-width:280px}.module-page-new .sections-nav-panel.collapsed{width:48px;min-width:48px}.module-page-new .sections-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid var(--color-border, #e5e7eb);min-height:56px}.module-page-new .sections-panel-header h3{font-size:14px;font-weight:600;color:#374151;margin:0;white-space:nowrap}.module-page-new .panel-toggle-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:#6b7280;cursor:pointer;border-radius:6px;transition:all .2s}.module-page-new .panel-toggle-btn:hover{background:#f3f4f6;color:#111827}.module-page-new .sections-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.module-page-new .sections-list::-webkit-scrollbar{width:6px}.module-page-new .sections-list::-webkit-scrollbar-track{background:transparent}.module-page-new .sections-list::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:3px}.module-page-new .section-nav-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;text-decoration:none;color:#6b7280;transition:all .2s;margin-bottom:4px}.module-page-new .section-nav-item:hover{background:#f3f4f6;color:#111827}.module-page-new .section-nav-item.active{background:#4f46e5;color:#fff}.module-page-new .section-nav-number{font-size:12px;font-weight:600;color:#9ca3af;flex-shrink:0;width:24px}.module-page-new .section-nav-title{font-size:13px;line-height:1.4;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.module-page-new .section-nav-status{color:#d1d5db;flex-shrink:0}.module-page-new .empty-sections-msg{padding:20px;text-align:center;color:#9ca3af;font-size:13px}.module-main-content{flex:1;min-width:0;height:100%;overflow-y:auto;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.module-main-content::-webkit-scrollbar{width:8px}.module-main-content::-webkit-scrollbar-track{background:transparent}.module-main-content::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.module-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#fff;border-bottom:1px solid var(--color-border, #e5e7eb);position:sticky;top:0;z-index:100;flex-shrink:0}.module-toolbar .breadcrumb{display:flex;align-items:center;gap:8px;font-size:14px;margin:0}.module-toolbar .breadcrumb a{color:#6b7280;text-decoration:none}.module-toolbar .breadcrumb a:hover{color:#4f46e5}.module-toolbar .breadcrumb span:last-child{color:#111827;font-weight:500}.module-toolbar .breadcrumb-separator{color:#d1d5db}.module-toolbar .toolbar-actions{display:flex;align-items:center;gap:6px}.module-toolbar .toolbar-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:1px solid var(--color-border, #e5e7eb);border-radius:5px;background:#fff;color:#6b7280;cursor:pointer;transition:all .2s}.module-toolbar .toolbar-btn:hover{background:#f3f4f6;color:#111827;border-color:#d1d5db}.module-toolbar .toolbar-btn.active{background:#4f46e5;color:#fff;border-color:#4f46e5}.module-content-area{padding:24px;flex:1}.module-hero{background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:24px;margin-bottom:16px}.module-meta{display:flex;align-items:center;gap:10px;margin-bottom:8px}.module-sequence-badge{font-size:12px;font-weight:700;color:#4f46e5;padding:4px 10px;background:#4f46e51a;border-radius:6px}.badge.badge-primary{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;padding:4px 8px;background:#4f46e5;border-radius:4px}.badge.badge-version{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:#059669;padding:4px 8px;background:#0596691a;border-radius:4px;border:1px solid rgba(5,150,105,.2)}.version-selector-wrapper{position:relative}.badge.badge-version.clickable{cursor:pointer;transition:all .15s}.badge.badge-version.clickable:hover{background:#05966933;border-color:#05966966}.badge.badge-version.clickable.active{background:#05966940;border-color:#059669}.version-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:200px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #00000026;z-index:100;overflow:hidden}.version-dropdown-header{padding:10px 12px;font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.version-option{display:flex;flex-direction:column;gap:2px;width:100%;padding:10px 12px;border:none;background:transparent;text-align:left;cursor:pointer;transition:background .1s}.version-option:hover{background:#f3f4f6}.version-option.active{background:#ecfdf5}.version-option-main{display:flex;align-items:center;gap:8px}.version-option .version-label{font-size:13px;font-weight:600;color:#111827}.version-option .version-status{font-size:10px;font-weight:500;padding:2px 6px;border-radius:4px}.version-option .version-status.published{color:#059669;background:#d1fae5}.version-option .version-status.draft{color:#d97706;background:#fef3c7}.version-option .version-date{font-size:11px;color:#9ca3af}.module-version-info{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;margin-bottom:16px}.module-version-info svg{color:#9ca3af}.module-title{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px;line-height:1.3}.module-description{font-size:15px;color:#6b7280;line-height:1.5;margin-bottom:16px;max-width:700px}.module-progress-bar{max-width:400px;margin-bottom:16px}.progress-info{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px;color:#6b7280}.progress-percent{font-weight:600;color:#4f46e5}.progress-track{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#6366f1);border-radius:4px;transition:width .3s ease}.module-actions{display:flex;gap:12px;flex-wrap:wrap}.module-actions .btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none}.module-actions .btn-primary{background:#4f46e5;color:#fff;border:none;box-shadow:0 2px 4px #4f46e533}.module-actions .btn-primary:hover{background:#4338ca;box-shadow:0 4px 8px #4f46e54d;transform:translateY(-1px)}.module-actions .btn-secondary{background:#fff;color:#374151;border:2px solid #e5e7eb}.module-actions .btn-secondary:hover{background:#f9fafb;border-color:#4f46e5;color:#4f46e5}.module-actions .btn-lg{padding:12px 24px;font-size:14px}.module-stats-bar{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.stat-item{display:flex;align-items:center;gap:6px;color:#64748b}.stat-item svg{color:#4f46e5;flex-shrink:0}.stat-item .stat-value{font-size:14px;font-weight:600;color:#1e293b}.stat-item .stat-label{font-size:13px;color:#64748b}.stat-divider{width:1px;height:20px;background:#cbd5e1}.module-page-new .ai-panel-inline{width:0;min-width:0;height:100%;background:#fff;border-left:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;transition:width .3s ease,min-width .3s ease;overflow:hidden;flex-shrink:0}.module-page-new .ai-panel-inline.open{width:400px;min-width:400px}.module-page-new .ai-panel-header{padding:14px 16px;border-bottom:1px solid var(--color-border, #e5e7eb);display:flex;justify-content:space-between;align-items:center;background:#f8fafc;color:#374151;flex-shrink:0}.module-page-new .ai-panel-header-title{display:flex;align-items:center;gap:10px}.module-page-new .ai-panel-header h3{margin:0;font-size:.95rem;font-weight:600;color:#374151}.module-page-new .ai-panel-header-title svg{color:#4f46e5}.module-page-new .ai-panel-close{border:none;background:transparent;cursor:pointer;color:#6b7280;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.module-page-new .ai-panel-close:hover{background:#e5e7eb;color:#374151}.module-page-new .ai-panel-context{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#f8fafc;border-bottom:1px solid var(--color-border, #e5e7eb);font-size:.8rem;color:#64748b;flex-shrink:0}.module-page-new .ai-panel-context svg{color:#4f46e5;flex-shrink:0}.module-page-new .ai-panel-context-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.module-page-new .ai-panel-scope-tabs{display:flex;border-bottom:1px solid var(--color-border, #e5e7eb);padding:0 8px;gap:2px;flex-shrink:0;background:#fafafa}.module-page-new .ai-scope-tab{background:none;border:none;padding:10px;font-size:.75rem;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:4px;transition:color .2s,border-color .2s;white-space:nowrap}.module-page-new .ai-scope-tab:hover:not(:disabled){color:#334155}.module-page-new .ai-scope-tab.active{color:#4f46e5;border-bottom-color:#4f46e5}.module-page-new .ai-scope-tab:disabled{opacity:.5;cursor:not-allowed}.module-page-new .ai-panel-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.module-page-new .ai-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;padding:30px 16px;color:#64748b}.module-page-new .ai-welcome-icon{color:#4f46e5;margin-bottom:12px;opacity:.8}.module-page-new .ai-welcome h4{margin:0 0 6px;color:#334155;font-size:1rem}.module-page-new .ai-welcome p{margin:0 0 16px;font-size:.85rem;line-height:1.4}.module-page-new .ai-suggestions{display:flex;flex-direction:column;gap:6px;width:100%}.module-page-new .ai-suggestions button{background:#f1f5f9;border:1px solid #e2e8f0;padding:8px 12px;border-radius:6px;font-size:.8rem;color:#475569;cursor:pointer;text-align:left;transition:background .2s,border-color .2s}.module-page-new .ai-suggestions button:hover{background:#e2e8f0;border-color:#cbd5e1}.module-page-new .ai-message{display:flex;gap:8px;animation:aiMessageSlide .2s ease-out}.module-page-new .ai-message.user{flex-direction:row-reverse}.module-page-new .ai-message-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#4338ca);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.module-page-new .ai-message-content{max-width:85%;padding:10px 14px;border-radius:10px;font-size:.85rem;line-height:1.5}.module-page-new .ai-message.user .ai-message-content{background:#4f46e5;color:#fff;border-bottom-right-radius:4px}.module-page-new .ai-message.assistant .ai-message-content{background:#f1f5f9;color:#334155;border-bottom-left-radius:4px}.module-page-new .ai-message-content p{margin:0;white-space:pre-wrap}.module-page-new .ai-sources{margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.1);display:flex;flex-wrap:wrap;gap:4px;align-items:center}.module-page-new .ai-sources-label{font-size:.7rem;color:#64748b;font-weight:500}.module-page-new .ai-source-tag{font-size:.65rem;padding:2px 6px;background:#4f46e51a;color:#4f46e5;border-radius:10px;font-weight:500}.module-page-new .ai-loading-spinner{animation:spin 1s linear infinite;color:#4f46e5}.module-page-new .ai-panel-input{padding:12px 16px;border-top:1px solid var(--color-border, #e5e7eb);background:#f8fafc;display:flex;gap:8px;flex-shrink:0}.module-page-new .ai-panel-input input{flex:1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:20px;font-size:.85rem;background:#fff;transition:border-color .2s,box-shadow .2s}.module-page-new .ai-panel-input input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.module-page-new .ai-panel-input button{width:40px;height:40px;border-radius:50%;border:none;background:#4f46e5;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .1s;flex-shrink:0}.module-page-new .ai-panel-input button:hover:not(:disabled){background:#4338ca}.module-page-new .ai-panel-input button:disabled{opacity:.5;cursor:not-allowed}.module-page-new .error-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;border:1px solid var(--color-border, #e5e7eb);margin:32px}.module-page-new .error-state h2{margin-bottom:12px;color:#111827}.module-page-new .error-state p{margin-bottom:24px;color:#6b7280}@media(max-width:1200px){.module-page-new .ai-panel-inline.open{width:350px;min-width:350px}}@media(max-width:1024px){.module-page-new .sections-nav-panel.open{width:220px;min-width:220px}.module-content-area,.module-hero{padding:20px}.module-page-new .ai-panel-inline.open{width:320px;min-width:320px}.module-stats-bar{gap:12px;padding:10px 14px}}@media(max-width:768px){.module-page-new{flex-direction:column;height:auto;min-height:calc(100vh - 64px)}.module-page-new .sections-nav-panel{width:100%!important;min-width:100%!important;height:auto;max-height:none;border-right:none;border-bottom:1px solid var(--color-border, #e5e7eb)}.module-page-new .sections-nav-panel.open{max-height:250px}.module-page-new .sections-nav-panel.collapsed{max-height:56px}.module-main-content{height:auto;flex:none}.module-stats-bar{flex-wrap:wrap;gap:10px}.stat-divider{display:none}.module-actions{flex-direction:column}.module-actions .btn{width:100%;justify-content:center}.module-page-new .ai-panel-inline{position:fixed;top:0;right:-100%;width:100%;min-width:100%;height:100vh;z-index:1000}.module-page-new .ai-panel-inline.open{right:0;width:100%;min-width:100%}}@media(max-width:500px){.module-content-area,.module-hero{padding:16px}.module-title{font-size:20px}.module-stats-bar{padding:10px 12px}.stat-item .stat-value{font-size:13px}.stat-item .stat-label{font-size:12px}}.module-page-new .skeleton{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:8px}.toc-sidebar{position:sticky;top:80px;background:var(--color-bg-card, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:var(--radius-lg, 12px);overflow:hidden;max-height:calc(100vh - 120px);display:flex;flex-direction:column;transition:all .3s ease}.toc-sidebar.collapsed{width:48px;min-width:48px}.toc-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border, #e5e7eb);background:var(--color-bg-tertiary, #f9fafb)}.toc-title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text-primary, #111827)}.toc-sidebar.collapsed .toc-title span{display:none}.toc-toggle{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--color-text-muted, #9ca3af);cursor:pointer;border-radius:4px;transition:all .2s}.toc-toggle:hover{background:var(--color-bg-tertiary, #f3f4f6);color:var(--color-text-primary, #111827)}.toc-nav{flex:1;overflow-y:auto;padding:8px 0;position:relative}.toc-list{list-style:none;margin:0;padding:0}.toc-item{margin:0}.toc-link{display:flex;align-items:center;padding:8px 16px;color:var(--color-text-secondary, #6b7280);text-decoration:none;font-size:13px;line-height:1.4;border-left:2px solid transparent;transition:all .15s ease;overflow:hidden}.toc-link:hover{background:var(--color-bg-tertiary, #f9fafb);color:var(--color-text-primary, #111827)}.toc-link.active{background:#29797014;color:var(--color-accent-primary, #297970);border-left-color:var(--color-accent-primary, #297970);font-weight:500}.toc-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toc-item.level-1 .toc-link{font-weight:600;font-size:14px}.toc-item.level-2 .toc-link{font-weight:500}.toc-item.level-3 .toc-link,.toc-item.level-4 .toc-link,.toc-item.level-5 .toc-link,.toc-item.level-6 .toc-link{font-size:12px;color:var(--color-text-muted, #9ca3af)}.toc-item.level-3 .toc-link:hover,.toc-item.level-4 .toc-link:hover,.toc-item.level-5 .toc-link:hover,.toc-item.level-6 .toc-link:hover{color:var(--color-text-secondary, #6b7280)}.toc-progress{position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--color-bg-tertiary, #f3f4f6)}.toc-progress-bar{width:100%;background:var(--color-accent-primary, #297970);transition:height .3s ease}.toc-nav::-webkit-scrollbar{width:4px}.toc-nav::-webkit-scrollbar-track{background:transparent}.toc-nav::-webkit-scrollbar-thumb{background:var(--color-border, #e5e7eb);border-radius:2px}.toc-nav::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted, #9ca3af)}@media(max-width:1200px){.toc-sidebar{display:none}}@media(max-width:900px){.toc-sidebar.mobile-open{display:flex;position:fixed;inset:60px 0 0;z-index:50;border-radius:0;max-height:none}}.flowchart-viewer{display:flex;flex-direction:column;height:100%;max-width:100%;border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff}.flowchart-toolbar{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:#f8fafc;border-bottom:1px solid #e5e7eb;gap:8px;flex-wrap:nowrap;min-height:40px;flex-shrink:0;position:relative;z-index:10}.flowchart-viewer.compact-mode .flowchart-toolbar{padding:4px 12px;min-height:36px}.flowchart-toolbar-title{font-size:13px;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;margin-right:8px}.flowchart-toolbar-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.flowchart-toolbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.flowchart-render-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:500;color:#fff;background:#71797e;border:none;border-radius:4px;cursor:pointer;transition:all .15s;flex-shrink:0}.flowchart-render-btn:hover:not(:disabled){background:#5a6268}.flowchart-render-btn:disabled{opacity:.7;cursor:not-allowed}.flowchart-cached-badge{display:flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:10px;font-weight:500;color:#059669;background:#d1fae5;border-radius:50%;border:1px solid #10b981;flex-shrink:0}.flowchart-preview-badge{display:flex;align-items:center;gap:4px;padding:5px 12px;font-size:12px;font-weight:500;color:#7c3aed;background:#ede9fe;border-radius:16px;flex-shrink:0}.flowchart-preview-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.flowchart-save-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;color:#fff;background:#22c55e;border:none;border-radius:6px;cursor:pointer;transition:all .15s}.flowchart-save-btn:hover:not(:disabled){background:#16a34a}.flowchart-save-btn:disabled{opacity:.7;cursor:not-allowed}.flowchart-cancel-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;color:#6b7280;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .15s}.flowchart-cancel-btn:hover:not(:disabled){background:#fee2e2;color:#dc2626;border-color:#fecaca}.flowchart-retry-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;border-radius:6px;cursor:pointer;transition:all .15s}.flowchart-retry-btn:hover:not(:disabled){background:#e0e7ff}.flowchart-rerender-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 10px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;flex-shrink:0}.flowchart-rerender-btn:hover:not(:disabled){background:#fef3c7;color:#b45309;border-color:#fcd34d}.flowchart-rerender-btn:disabled{opacity:.5;cursor:not-allowed}.flowchart-rerender-btn .rerender-label{display:inline}@media(max-width:640px){.flowchart-rerender-btn .rerender-label{display:none}.flowchart-rerender-btn{padding:6px}}.flowchart-v2-btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 10px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:6px;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;flex-shrink:0}.flowchart-v2-btn:hover:not(:disabled){background:linear-gradient(135deg,#4338ca,#6d28d9);box-shadow:0 2px 8px #4f46e566}.flowchart-v2-btn:disabled{opacity:.5;cursor:not-allowed}.flowchart-v2-btn .v2-label{display:inline}@media(max-width:640px){.flowchart-v2-btn .v2-label{display:none}.flowchart-v2-btn{padding:6px}}.flowchart-export-actions{display:flex;align-items:center;gap:2px;padding:3px;background:#e5e7eb;border-radius:6px}.flowchart-copy-btn,.flowchart-download-btn{display:flex;align-items:center;justify-content:center;width:28px;height:26px;background:transparent;border:none;border-radius:4px;color:#6b7280;cursor:pointer;transition:all .15s}.flowchart-copy-btn:hover,.flowchart-download-btn:hover{background:#fff;color:#111827}.flowchart-copy-btn:has(svg[data-lucide=check]),.flowchart-copy-btn svg[class*=check]{color:#059669}.flowchart-copy-btn[title="Copied!"]{color:#059669;background:#d1fae5}.flowchart-zoom-controls{display:flex;align-items:center;gap:2px;padding:3px;background:#e5e7eb;border-radius:6px}.flowchart-zoom-controls.svg-zoom{background:#dbeafe}.flowchart-zoom-controls.ascii-zoom{background:#f3f4f6}.flowchart-zoom-controls button{display:flex;align-items:center;justify-content:center;width:28px;height:26px;background:transparent;border:none;border-radius:4px;color:#6b7280;cursor:pointer;transition:all .15s}.flowchart-zoom-controls button svg{width:14px;height:14px;flex-shrink:0}.flowchart-zoom-controls button:hover{background:#fff;color:#111827}.flowchart-zoom-controls .zoom-level{font-size:11px;color:#6b7280;min-width:38px;text-align:center}.flowchart-edit-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;transition:all .15s}.flowchart-edit-btn:hover{background:#e0e7ff;color:#4f46e5;border-color:#c7d2fe}.flowchart-edit-actions{display:flex;align-items:center;gap:4px}.flowchart-autofix-btn{display:flex;align-items:center;justify-content:center;width:32px;height:28px;background:#fef3c7;border:1px solid #fcd34d;border-radius:6px;color:#b45309;cursor:pointer;transition:all .15s}.flowchart-autofix-btn:hover{background:#fde68a}.flowchart-view-toggle{display:flex;background:#e5e7eb;border-radius:6px;padding:3px}.flowchart-view-toggle button{display:flex;align-items:center;justify-content:center;width:32px;height:28px;background:transparent;border:none;border-radius:4px;color:#6b7280;cursor:pointer;transition:all .15s}.flowchart-view-toggle button svg{width:18px;height:18px;flex-shrink:0}.flowchart-view-toggle button:hover{color:#111827}.flowchart-view-toggle button.active{background:#fff;color:#4f46e5;box-shadow:0 1px 2px #0000000d}.flowchart-view-toggle button:disabled{opacity:.4;cursor:not-allowed}.flowchart-view-toggle button:disabled:hover{color:#6b7280}.flowchart-error{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fef2f2;color:#dc2626;font-size:13px;border-bottom:1px solid #fecaca;flex-shrink:0}.flowchart-error-dismiss{margin-left:auto;padding:4px 10px;font-size:12px;color:#dc2626;background:#fff;border:1px solid #fecaca;border-radius:4px;cursor:pointer}.flowchart-error-dismiss:hover{background:#fef2f2}.flowchart-content{display:flex;flex:1;min-height:0;overflow:hidden}.flowchart-content.view-ascii,.flowchart-content.view-svg{flex-direction:column}.flowchart-content.view-both{flex-direction:row}.flowchart-ascii-panel{flex:1;background:#1e1e2e;overflow:auto;min-height:0}.flowchart-content.view-both .flowchart-ascii-panel{flex:0 0 50%;border-right:1px solid #333}.flowchart-ascii-panel pre{margin:0;padding:20px;min-width:-moz-fit-content;min-width:fit-content}.flowchart-ascii-panel code{font-family:JetBrains Mono,Fira Code,Consolas,Monaco,monospace;font-size:13px;line-height:1.3;letter-spacing:0;word-spacing:0;color:#c0caf5;white-space:pre;display:block}.flowchart-ascii-panel.editing{background:#1a1b26}.flowchart-ascii-editor{width:100%;height:100%;min-height:300px;padding:20px;margin:0;border:none;outline:none;resize:none;background:transparent;color:#c0caf5;font-family:JetBrains Mono,Fira Code,Consolas,Monaco,monospace;font-size:13px;line-height:1.3;white-space:pre;overflow:auto}.flowchart-ascii-editor:focus{outline:none;box-shadow:inset 0 0 0 2px #4f46e54d}.flowchart-svg-panel{flex:1;display:flex;align-items:flex-start;justify-content:center;background:#fafafa;overflow:auto;min-height:0;padding:24px;position:relative}.flowchart-content.view-both .flowchart-svg-panel{flex:0 0 50%}.flowchart-svg-container{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:16px;cursor:grab}.flowchart-svg-container svg{max-width:100%;height:auto;display:block}.flowchart-svg-panel.preview-mode{background:#faf5ff}.flowchart-svg-panel.preview-mode .flowchart-svg-container{border:2px solid #a78bfa;position:relative}.flowchart-svg-panel.preview-mode .flowchart-svg-container:before{content:"Preview - not saved";position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#7c3aed;color:#fff;font-size:11px;padding:2px 10px;border-radius:10px;z-index:1}.flowchart-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#6b7280;font-size:14px}.flowchart-checking-badge{display:flex;align-items:center;gap:6px;padding:5px 12px;font-size:12px;color:#6b7280;background:#f3f4f6;border-radius:16px}.flowchart-svg-panel.dragging{cursor:grabbing!important}.flowchart-svg-panel.dragging .flowchart-svg-container{cursor:grabbing!important;-webkit-user-select:none;-moz-user-select:none;user-select:none}.animate-spin{animation:flowchart-spin 1s linear infinite}@keyframes flowchart-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.flowchart-content.view-both{flex-direction:column}.flowchart-content.view-both .flowchart-ascii-panel,.flowchart-content.view-both .flowchart-svg-panel{flex:none;height:50%}.flowchart-content.view-both .flowchart-ascii-panel{border-right:none;border-bottom:1px solid #333}.flowchart-toolbar{flex-wrap:wrap}.flowchart-toolbar-left{flex:1 1 100%;margin-bottom:6px}.flowchart-toolbar-right{flex:1 1 100%;justify-content:flex-end}.flowchart-toolbar-title{max-width:200px}}.flowchart-tabs-container{display:flex;flex-direction:column;height:100%;min-height:400px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;overflow:hidden;margin:0}.flowchart-tabs-header{display:flex;align-items:flex-start;gap:4px;padding:6px 8px;background:#f1f5f9;border-bottom:1px solid #e5e7eb;flex-shrink:0;flex-wrap:wrap}.flowchart-tabs-scroll-btn{display:none}.flowchart-tabs-list{display:flex;flex-wrap:wrap;gap:4px;flex:1;padding:2px;max-height:70px;overflow-y:auto}.flowchart-tabs-list::-webkit-scrollbar{width:4px;height:4px}.flowchart-tabs-list::-webkit-scrollbar-track{background:transparent}.flowchart-tabs-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:2px}.flowchart-tab{display:flex;align-items:center;gap:4px;padding:3px 8px;background:#fff;border:1px solid #e5e7eb;border-radius:4px;color:#6b7280;font-size:11px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}.flowchart-tab:hover{background:#f9fafb;color:#374151}.flowchart-tab.active{background:#4f46e5;border-color:#4f46e5;color:#fff}.flowchart-tab-number{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:#00000014;border-radius:3px;font-size:9px;font-weight:600}.flowchart-tab.active .flowchart-tab-number{background:#fff3}.flowchart-tab-title{max-width:150px;overflow:hidden;text-overflow:ellipsis}.flowchart-tabs-counter{padding:4px 10px;background:#e5e7eb;border-radius:12px;font-size:11px;font-weight:500;color:#6b7280;flex-shrink:0;align-self:flex-start;margin-left:auto}.flowchart-tabs-content{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}.flowchart-tabs-viewer{flex:1;overflow:hidden;min-height:0;display:flex;flex-direction:column}.flowchart-tabs-viewer .flowchart-viewer{height:100%;margin:0;border:none;border-radius:0;flex:1;display:flex;flex-direction:column}.flowchart-tabs-viewer .flowchart-content{flex:1;min-height:0}.flowchart-tabs-viewer .flowchart-svg-panel,.flowchart-tabs-viewer .flowchart-ascii-panel{max-height:none;height:100%;overflow:auto}.flowchart-tabs-footer{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:#f8fafc;border-top:1px solid #e5e7eb;flex-shrink:0}.flowchart-nav-btn{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#fff;border:1px solid #e5e7eb;border-radius:4px;color:#374151;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.flowchart-nav-btn:hover:not(:disabled){background:#f3f4f6}.flowchart-nav-btn:disabled{opacity:.4;cursor:not-allowed}.flowchart-nav-current{font-size:12px;color:#9ca3af;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.flowchart-single-container{margin:16px 0}.flowchart-single-container .flowchart-viewer{max-height:calc(100vh - 250px)}@media(max-width:768px){.flowchart-tabs-container{height:calc(100vh - 200px);min-height:400px}.flowchart-tab-title{max-width:100px}.flowchart-tabs-header{padding:6px 8px}.flowchart-nav-current{display:none}}@media(max-width:480px){.flowchart-tab-title{display:none}.flowchart-tab{padding:6px 10px}}.section-page-new{display:flex;margin:-24px;width:calc(100% + 48px);height:calc(100vh - 64px);background:var(--color-bg-secondary, #f9fafb);overflow:hidden;box-sizing:border-box}.sections-nav-panel{background:#fff;border-right:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;transition:width .3s ease;flex-shrink:0;height:100%;overflow:hidden}.sections-nav-panel.open{width:280px;min-width:280px}.sections-nav-panel.collapsed{width:48px;min-width:48px}.sections-panel-header{display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:#f3f4f6;border-bottom:1px solid var(--color-border, #e5e7eb);min-height:42px;height:42px;flex-shrink:0}.sections-panel-header h3{font-size:13px;font-weight:600;color:#374151;margin:0;white-space:nowrap}.panel-toggle-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:#6b7280;cursor:pointer;border-radius:6px;transition:all .15s}.panel-toggle-btn svg{width:14px;height:14px}.panel-toggle-btn:hover{background:#f3f4f6;color:#111827}.sections-list{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.sections-list::-webkit-scrollbar{width:6px}.sections-list::-webkit-scrollbar-track{background:transparent}.sections-list::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:3px}.sections-list::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}.section-nav-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:8px;text-decoration:none;color:#6b7280;transition:all .2s;margin-bottom:4px}.section-nav-item:hover{background:#f3f4f6;color:#111827}.section-nav-item.active{background:#4f46e5;color:#fff}.section-nav-item.active .section-nav-number{color:#ffffffb3}.section-nav-number{font-size:12px;font-weight:600;color:#9ca3af;flex-shrink:0;width:24px}.section-nav-title{font-size:13px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.section-main-content{flex:1;min-width:0;width:0;height:100%;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.section-main-content:has(.flowchart-page-layout){overflow:hidden}.section-main-content.editing{overflow:hidden}.section-main-content::-webkit-scrollbar{width:8px}.section-main-content::-webkit-scrollbar-track{background:transparent}.section-main-content::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:4px}.section-main-content::-webkit-scrollbar-thumb:hover{background-color:#9ca3af}.section-content-wrapper{padding:12px 16px;flex:1;min-height:0;min-width:0;width:100%;max-width:100%;overflow:auto;box-sizing:border-box}.section-content-wrapper.editing{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0;width:100%;max-width:100%;padding:12px 16px;overflow:hidden;box-sizing:border-box}.section-content-wrapper:has(.flowchart-mode){padding:12px 16px}.section-toolbar{display:flex;justify-content:space-between;align-items:center;padding:0 8px;background:#f8fafc;border-bottom:1px solid var(--color-border, #e5e7eb);position:sticky;top:0;z-index:100;flex-shrink:0;min-height:44px;height:auto;width:100%;box-sizing:border-box;gap:8px}.section-toolbar .breadcrumb{margin:0;display:flex;align-items:center;gap:4px;font-size:11px;flex:1;min-width:0;overflow:hidden}.section-toolbar .breadcrumb a{color:#6b7280;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.section-toolbar .breadcrumb a:hover{color:#4f46e5}.section-toolbar .breadcrumb span:last-child{color:#374151;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:120px}.section-main-content.editing .section-toolbar .breadcrumb{display:none}.breadcrumb-separator{color:#d1d5db;font-size:10px;flex-shrink:0}.toolbar-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;margin-left:8px}.toolbar-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;border-radius:5px;background:transparent;color:#64748b;cursor:pointer;transition:color .2s ease}.toolbar-btn svg{width:14px;height:14px;stroke-width:2;flex-shrink:0;display:block}.toolbar-btn svg path,.toolbar-btn svg line,.toolbar-btn svg polyline,.toolbar-btn svg circle,.toolbar-btn svg rect{stroke:currentColor}.toolbar-btn.active{color:#4f46e5}.toolbar-btn.tts-btn{color:#64748b}.toolbar-btn.tts-btn:hover{color:#4f46e5}.toolbar-btn.tts-btn.playing{color:#ef4444;animation:pulse-playing 1.5s ease-in-out infinite}.toolbar-btn.tts-btn.paused,.toolbar-btn.bookmarked{color:#f59e0b}.toolbar-btn:disabled{opacity:.3;cursor:not-allowed}.toolbar-btn.nav-icon-btn{color:#64748b}.toolbar-btn.nav-icon-btn:hover:not(:disabled){color:#4f46e5}.toolbar-btn.nav-icon-btn:disabled{color:#d1d5db}.toolbar-btn.complete-btn{color:#10b981}.toolbar-btn.complete-btn:hover{color:#059669}.toolbar-btn.save-btn{color:#10b981}.toolbar-btn.save-btn:hover{color:#059669}.toolbar-btn.cancel-btn{color:#ef4444}.toolbar-btn.cancel-btn:hover{color:#dc2626}.toolbar-divider{width:1px;height:16px;background:var(--color-border, #d1d5db);margin:0 2px}@keyframes pulse-playing{0%,to{opacity:1}50%{opacity:.7}}.content-layout{display:flex;gap:24px;flex:1;min-height:0;min-width:0;width:100%;max-width:100%}.content-layout.editing{display:flex;flex-direction:column;min-width:0;width:100%;max-width:100%}.content-layout.with-toc{display:grid;grid-template-columns:220px 1fr;gap:24px}.content-layout.with-toc.editing{display:flex;flex-direction:column}.section-toc{position:sticky;top:24px;max-height:calc(100vh - 150px);overflow-y:auto;background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:16px}.section-article{flex:1;min-width:0;width:100%;max-width:100%;background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:24px 28px;overflow-x:auto;transition:opacity .15s ease-out;box-sizing:border-box}.section-article.transitioning{opacity:.6;pointer-events:none}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--color-border, #e5e7eb);transition:opacity .15s ease-out}.section-number,.section-number-inline{font-size:11px;font-weight:600;color:#fff;background:#4f46e5;padding:3px 10px;border-radius:4px;white-space:nowrap;flex-shrink:0}.section-header h1{font-size:17px;font-weight:600;color:#111827;margin:0;line-height:1.3}.flowchart-page-layout{display:flex;flex-direction:column;height:100%;overflow:hidden;padding:12px 16px 0}.section-header-fixed{display:flex;align-items:center;gap:12px;padding:12px 16px;margin-bottom:8px;background:#fff;border:1px solid var(--color-border, #e5e7eb);border-radius:8px;flex-shrink:0}.section-header-fixed h1{font-size:17px;font-weight:600;color:#111827;margin:0;line-height:1.3}.flowchart-full-container{flex:1;min-height:0;overflow:hidden}.flowchart-full-container .flowchart-tabs-container{height:100%;max-height:none}.markdown-content{font-size:14px;line-height:1.8;color:#374151;max-width:100%;overflow-x:hidden}.markdown-content>*{max-width:100%}.markdown-content h2{font-size:20px;margin-top:32px;margin-bottom:16px;color:#111827;font-weight:600}.markdown-content h3{font-size:16px;margin-top:24px;margin-bottom:12px;color:#111827;font-weight:600}.markdown-content h4{font-size:14px;margin-top:20px;margin-bottom:10px;color:#111827;font-weight:600}.markdown-content p{margin-bottom:16px}.markdown-content ul,.markdown-content ol{margin-bottom:16px;padding-left:24px}.markdown-content li{margin-bottom:8px}.markdown-content strong{color:#111827;font-weight:600}.markdown-content code{font-family:Fira Code,Consolas,monospace;font-size:.9em;background:#f3f4f6;padding:2px 6px;border-radius:4px;color:#7c3aed}.markdown-content pre{background:#1f2937;border-radius:8px;padding:16px;overflow-x:auto;margin:16px 0}.markdown-content pre code{background:transparent;padding:0;color:#e5e7eb}.markdown-content blockquote{border-left:4px solid #4f46e5;padding-left:16px;margin:16px 0;color:#6b7280;font-style:italic}.markdown-content hr{border:none;border-top:1px solid var(--color-border, #e5e7eb);margin:32px 0}.markdown-content table{width:100%;border-collapse:collapse;margin:16px 0}.markdown-content th,.markdown-content td{border:1px solid var(--color-border, #e5e7eb);padding:4px 8px;text-align:left;line-height:1.3}.markdown-content th{background:#f9fafb;font-weight:600}.empty-content{text-align:center;padding:60px 20px;color:#6b7280}.empty-content p{margin:8px 0}.empty-content .text-muted{font-size:14px;color:#9ca3af}.content-block.flowchart-section{display:flex;flex-direction:column;min-height:calc(100vh - 180px)}.content-block.flowchart-section .flowchart-tabs-container{margin-left:-8px;margin-right:-8px;width:calc(100% + 16px);flex:1;height:auto;min-height:calc(100vh - 200px)}.section-nav{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:40px;padding:24px 0;border-top:2px solid var(--color-border, #e5e7eb)}.section-nav .btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s}.section-nav .btn-primary{background:#4f46e5;color:#fff;border:none;box-shadow:0 2px 4px #4f46e533}.section-nav .btn-primary:hover{background:#4338ca;box-shadow:0 4px 8px #4f46e54d;transform:translateY(-1px)}.section-nav .btn-secondary{background:#fff;color:#374151;border:2px solid #e5e7eb}.section-nav .btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#4f46e5;color:#4f46e5}.section-nav .btn-secondary:disabled{opacity:.4;cursor:not-allowed;background:#f3f4f6}.nav-btn{min-width:140px;justify-content:center}.section-article.editing{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0;width:100%;max-width:100%;overflow:hidden;padding:16px;box-sizing:border-box}.markdown-content.editing{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;width:100%;max-width:100%;overflow:hidden}.markdown-editor-container{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0;width:100%;max-width:100%;border:1px solid var(--color-border, #e5e7eb);border-radius:8px;overflow:hidden;background:#f9fafb;box-sizing:border-box}.markdown-editor{flex:1;width:100%;max-width:100%;min-height:0;padding:16px;border:none;border-radius:0;background:#f9fafb;color:#111827;font-family:Fira Code,Consolas,monospace;font-size:14px;line-height:1.6;resize:none;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;word-wrap:break-word;white-space:pre-wrap}.markdown-editor:focus{outline:none;background:#fff}.editor-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-top:1px solid var(--color-border, #e5e7eb);flex-shrink:0}.editor-actions-left{display:flex;gap:8px}.editor-actions-right{display:flex;gap:12px}.editor-actions .btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer}.editor-actions .btn-media{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:6px;font-weight:500;font-size:13px;cursor:pointer;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;transition:all .2s}.editor-actions .btn-media:hover{background:#e0e7ff;color:#4f46e5;border-color:#c7d2fe}.editor-actions .btn-media svg{width:16px;height:16px}.editor-actions .btn-secondary{background:#fff;color:#374151;border:1px solid var(--color-border, #e5e7eb)}.editor-actions .btn-primary{background:#4f46e5;color:#fff;border:none}.editor-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.skeleton{background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.error-state{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;border:1px solid var(--color-border, #e5e7eb)}.ai-panel-inline{width:0;min-width:0;height:100%;background:#fff;border-left:1px solid var(--color-border, #e5e7eb);display:flex;flex-direction:column;transition:width .3s ease,min-width .3s ease;overflow:hidden;flex-shrink:0}.ai-panel-inline.open{width:400px;min-width:400px}.ai-panel-header{padding:14px 16px;border-bottom:1px solid var(--color-border, #e5e7eb);display:flex;justify-content:space-between;align-items:center;background:#f8fafc;color:#374151;flex-shrink:0}.ai-panel-header-title{display:flex;align-items:center;gap:10px}.ai-panel-header h3{margin:0;font-size:.875rem;font-weight:600;color:#374151}.ai-panel-header-title svg{color:#4f46e5}.ai-panel-close{border:none;background:transparent;cursor:pointer;color:#6b7280;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.ai-panel-close:hover{background:#e5e7eb;color:#374151}.ai-panel-model-selector{padding:8px 12px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.ai-model-select{width:100%;padding:6px 10px;font-size:11px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;color:#374151;cursor:pointer;outline:none}.ai-model-select:hover{border-color:#d1d5db}.ai-model-select:focus{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e51a}.ai-panel-context{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#f8fafc;border-bottom:1px solid var(--color-border, #e5e7eb);font-size:.75rem;color:#64748b;flex-shrink:0}.ai-panel-context svg{color:#4f46e5;flex-shrink:0}.ai-panel-context-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-panel-scope-tabs{display:flex;border-bottom:1px solid var(--color-border, #e5e7eb);padding:0 8px;gap:2px;flex-shrink:0;background:#fafafa}.ai-scope-tab{background:none;border:none;padding:10px;font-size:.7rem;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:4px;transition:color .2s,border-color .2s;white-space:nowrap}.ai-scope-tab:hover:not(:disabled){color:#334155}.ai-scope-tab.active{color:#4f46e5;border-bottom-color:#4f46e5}.ai-scope-tab:disabled{opacity:.5;cursor:not-allowed}.ai-panel-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;scrollbar-width:thin;scrollbar-color:#d1d5db transparent}.ai-panel-messages::-webkit-scrollbar{width:6px}.ai-panel-messages::-webkit-scrollbar-track{background:transparent}.ai-panel-messages::-webkit-scrollbar-thumb{background-color:#d1d5db;border-radius:3px}.ai-welcome{display:flex;flex-direction:column;align-items:center;text-align:center;padding:30px 16px;color:#64748b}.ai-welcome-icon{color:#4f46e5;margin-bottom:12px;opacity:.8}.ai-welcome h4{margin:0 0 6px;color:#334155;font-size:.9rem}.ai-welcome p{margin:0 0 16px;font-size:.8rem;line-height:1.4}.ai-suggestions{display:flex;flex-direction:column;gap:6px;width:100%}.ai-suggestions button{background:#f1f5f9;border:1px solid #e2e8f0;padding:8px 12px;border-radius:6px;font-size:.75rem;color:#475569;cursor:pointer;text-align:left;transition:background .2s,border-color .2s}.ai-suggestions button:hover{background:#e2e8f0;border-color:#cbd5e1}.ai-message{display:flex;gap:8px;animation:aiMessageSlide .2s ease-out}@keyframes aiMessageSlide{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-message-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#4f46e5,#4338ca);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ai-message-content{max-width:85%;padding:10px 14px;border-radius:10px;font-size:.8rem;line-height:1.5}.ai-message.user .ai-message-content{background:#4f46e5;color:#fff;border-bottom-right-radius:4px}.ai-message.assistant .ai-message-content{background:#f1f5f9;color:#334155;border-bottom-left-radius:4px}.ai-message-content p{margin:0;white-space:pre-wrap}.ai-sources{margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.1);display:flex;flex-wrap:wrap;gap:4px;align-items:center}.ai-sources-label{font-size:.65rem;color:#64748b;font-weight:500}.ai-source-tag{font-size:.6rem;padding:2px 6px;background:#4f46e51a;color:#4f46e5;border-radius:10px;font-weight:500}.ai-loading-spinner{animation:spin 1s linear infinite;color:#4f46e5}.ai-panel-input{padding:12px 16px;border-top:1px solid var(--color-border, #e5e7eb);background:#f8fafc;display:flex;gap:8px;flex-shrink:0}.ai-panel-input input{flex:1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:20px;font-size:.8rem;background:#fff;transition:border-color .2s,box-shadow .2s}.ai-panel-input input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.ai-panel-input input:disabled{background:#f1f5f9}.ai-panel-input button{width:40px;height:40px;border-radius:50%;border:none;background:#4f46e5;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .1s;flex-shrink:0}.ai-panel-input button:hover:not(:disabled){background:#4338ca}.ai-panel-input button:active:not(:disabled){transform:scale(.95)}.ai-panel-input button:disabled{opacity:.5;cursor:not-allowed}.fade-in{animation:fadeIn .3s ease}@media(max-width:1200px){.ai-panel-inline.open{width:350px;min-width:350px}}@media(max-width:1024px){.sections-nav-panel.open{width:220px;min-width:220px}.section-main-content{padding:16px 20px}.section-article{padding:24px}.ai-panel-inline.open{width:320px;min-width:320px}}@media(max-width:768px){.section-page-new{display:flex;flex-direction:column;height:calc(100vh - 64px);min-height:calc(100vh - 64px);overflow:hidden}.sections-nav-panel{display:none!important}.section-main-content{flex:1;width:100%;min-height:0;overflow-y:auto;overflow-x:hidden}.section-content-wrapper{padding:12px;min-height:100%}.section-article{padding:16px;border-radius:8px;min-height:200px}.content-layout{flex-direction:column}.content-layout.with-toc{display:flex;grid-template-columns:none}.section-toc{display:none}.section-toolbar{flex-direction:row;flex-wrap:wrap;gap:6px;align-items:center;padding:8px 12px;min-height:auto}.toolbar-actions{display:flex;gap:4px;flex-wrap:wrap}.section-nav{flex-direction:column}.nav-btn{width:100%;justify-content:center}.ai-panel-inline{position:fixed;top:0;right:-100%;width:100%;min-width:100%;height:100vh;z-index:1000}.ai-panel-inline.open{right:0;width:100%;min-width:100%}}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none}.btn-primary{background:#4f46e5;color:#fff;border:none}.btn-primary:hover{background:#4338ca}.btn-secondary{background:#fff;color:#374151;border:1px solid var(--color-border, #e5e7eb)}.btn-secondary:hover:not(:disabled){background:#f3f4f6}.btn-danger{background:#ef4444;color:#fff;border:none}.btn-danger:hover{background:#dc2626}.btn-warning{background:#f59e0b;color:#fff;border:none}.btn-warning:hover{background:#d97706}.mr-2{margin-right:8px}.ml-2{margin-left:8px}.text-muted{color:#9ca3af}.modal-overlay{position:fixed;inset:0;background:#0f172abf;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modalFadeIn .15s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(148,163,184,.3);border-radius:16px;width:680px;min-width:680px;max-width:680px;height:560px;min-height:560px;max-height:560px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:modalSlideIn .2s ease-out;overflow:hidden}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.modal-tab.active{background:#fff;color:#4f46e5;font-weight:600;box-shadow:0 1px 3px #0000001a}.browser-container{display:flex;flex-direction:column;height:350px;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb}.browser-header{padding:8px 12px;border-bottom:1px solid #e5e7eb;background:#f3f4f6;display:flex;gap:8px;align-items:center}.breadcrumbs{display:flex;gap:4px;font-size:13px;color:#1f2937;overflow-x:auto;white-space:nowrap;align-items:center}.breadcrumb-item:hover{background:#e5e7eb;color:#111827}.browser-list{flex:1;overflow-y:auto;padding:4px}.file-item{display:flex;align-items:center;gap:12px;padding:8px 12px;cursor:pointer;border-radius:6px;color:#6b7280;font-size:13px;transition:background .15s}.file-item:hover{background:#fff;color:#111827}.file-item.selected{background:#e0e7ff;color:#4f46e5;font-weight:500}.url-input-container{display:flex;flex-direction:column;gap:8px}.url-input-container label{font-weight:500;color:#374151;font-size:14px}.url-input-container input{padding:10px 14px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px}.url-input-container input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.url-helper{font-size:12px;color:#9ca3af}.file-drop-area{border:2px dashed #e5e7eb;border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .2s;background:#fafafa}.file-drop-area:hover{border-color:#4f46e5;background:#f5f3ff}.selected-file-badge{margin-top:16px;padding:8px 16px;background:#e0e7ff;color:#4f46e5;border-radius:20px;font-size:13px}.modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px;background:#f9fafb;flex-shrink:0}.modal-footer .btn-secondary{padding:10px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;font-size:14px;font-weight:500;cursor:pointer}.modal-footer .btn-secondary:hover{background:#f3f4f6}.modal-footer .btn-primary{padding:10px 20px;background:#4f46e5;border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer}.modal-footer .btn-primary:hover:not(:disabled){background:#4338ca}.modal-footer .btn-primary:disabled{background:#9ca3af;cursor:not-allowed}.browser-table-header{display:flex;padding:12px;border-bottom:2px solid #e5e7eb;background:#f9fafb;font-weight:600;font-size:13px;color:#6b7280}.file-row{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background-color .15s;font-size:13px}.file-row:hover{background-color:#f9fafb}.file-row.selected{background-color:#e0e7ff}.col-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:16px}.col-date{width:120px;color:#9ca3af;font-size:12px}.col-size{width:80px;text-align:right;color:#9ca3af;font-size:12px;font-family:monospace}.error-text{color:#ef4444;font-size:13px}.info-box{padding:12px 16px;border-radius:8px;font-size:13px}.info-box.warning{background:#fff3cd;color:#856404;border:1px solid #ffeeba}.embedded-video-container{margin:1.5rem 0;border-radius:8px;overflow:hidden;background:#000;box-shadow:0 4px 12px #00000026}.embedded-video-container video{width:100%;max-height:500px;display:block}.embedded-video-container video::-webkit-media-controls-panel{background:linear-gradient(transparent,#000000b3)}.embedded-video-container video:focus{outline:2px solid var(--color-primary, #6366f1);outline-offset:2px}.ai-message-actions{display:flex;gap:4px;margin-top:8px;opacity:0;transition:opacity .2s ease}.ai-message:hover .ai-message-actions{opacity:1}.ai-action-btn{padding:4px 8px;border:none;background:transparent;color:#94a3b8;cursor:pointer;border-radius:4px;display:flex;align-items:center;gap:4px;font-size:.7rem;transition:all .15s ease}.ai-action-btn:hover{background:#e2e8f0;color:#475569}.ai-action-btn.copied{color:#10b981}.ai-action-btn.playing{color:#4f46e5}.ai-mic-btn{width:36px;height:36px;min-width:36px;border-radius:50%;border:none;background:#e2e8f0;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.ai-mic-btn:hover{background:#cbd5e1;color:#475569}.ai-mic-btn:disabled{opacity:.5;cursor:not-allowed}.ai-mic-btn.recording{background:#ef4444;color:#fff;animation:micPulse 1s infinite}@keyframes micPulse{0%,to{transform:scale(1);box-shadow:0 0 #ef444466}50%{transform:scale(1.05);box-shadow:0 0 0 8px #ef444400}}.ai-message-content h1,.ai-message-content h2,.ai-message-content h3,.ai-message-content h4{margin:.5em 0 .25em;font-size:.95em;font-weight:600}.ai-message-content h1{font-size:1.1em}.ai-message-content h2{font-size:1.05em}.ai-message-content h3{font-size:1em}.ai-message-content p{margin:.4em 0;line-height:1.5}.ai-message-content p:first-child{margin-top:0}.ai-message-content p:last-child{margin-bottom:0}.ai-message-content ul,.ai-message-content ol{margin:.5em 0;padding-left:1.5em}.ai-message-content li{margin:.25em 0;line-height:1.4}.ai-message-content code{background:#00000014;padding:2px 5px;border-radius:3px;font-size:.85em;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.ai-message-content pre{background:#1e293b;color:#e2e8f0;padding:10px 14px;border-radius:6px;overflow-x:auto;font-size:.8em;margin:.5em 0}.ai-message-content pre code{background:transparent;padding:0;color:inherit}.ai-message-content blockquote{border-left:3px solid #cbd5e1;padding-left:12px;margin:.5em 0;color:#64748b;font-style:italic}.ai-message-content strong{font-weight:600}.ai-message-content em{font-style:italic}.ai-message-content a{color:#4f46e5;text-decoration:underline}.ai-message-content a:hover{color:#4338ca}.ai-message.user .ai-message-content code{background:#fff3}.ai-message.user .ai-message-content pre{background:#0000004d}.ai-message.user .ai-message-content a{color:#c7d2fe}.ai-message.user .ai-message-content blockquote{border-left-color:#fff6;color:#fffc}.coach-page{height:calc(100vh - 200px);min-height:500px}.coach-layout{display:grid;grid-template-columns:1fr 280px;gap:var(--spacing-lg);height:100%}.chat-container{display:flex;flex-direction:column;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary)}.chat-header-info{display:flex;align-items:center;gap:var(--spacing-md)}.coach-avatar{font-size:2rem}.chat-header h2{font-size:var(--font-size-lg);margin:0}.coach-status{display:flex;align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-success);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.messages-container{flex:1;overflow-y:auto;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.message{display:flex;gap:var(--spacing-sm);max-width:80%}.message.user{margin-left:auto;flex-direction:row-reverse}.message-avatar{width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}.message-content{background:var(--color-bg-tertiary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-lg)}.message.user .message-content{background:var(--color-accent-primary);color:#fff}.message-content p{margin:0;line-height:1.5}.message-sources{margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:var(--spacing-xs);align-items:center}.sources-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.source-badge{font-size:var(--font-size-xs);padding:2px 8px;background:#29797033;color:var(--color-accent-primary);border-radius:var(--radius-full)}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--color-text-muted);animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.chat-input-form{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);background:var(--color-bg-secondary)}.chat-input{flex:1;border-radius:var(--radius-xl)}.send-btn{padding:var(--spacing-sm) var(--spacing-lg)}.coach-sidebar{display:flex;flex-direction:column;gap:var(--spacing-md)}.sidebar-section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md)}.sidebar-section h4{font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.suggested-questions{display:flex;flex-direction:column;gap:var(--spacing-xs)}.suggestion-btn{text-align:left;padding:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg-tertiary);border:1px solid transparent;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.suggestion-btn:hover{background:var(--color-bg-hover);border-color:var(--color-accent-primary);color:var(--color-text-primary)}.tips-list{padding-left:var(--spacing-md);margin:0}.tips-list li{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}@media(max-width:900px){.coach-layout{grid-template-columns:1fr;height:auto}.chat-container{min-height:500px}.coach-sidebar{flex-direction:row;flex-wrap:wrap}.sidebar-section{flex:1;min-width:200px}}.category-manager{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;overflow:hidden;border:1px solid #E5E7EB}.cm-header{background:#fff;border-bottom:1px solid #E5E7EB;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center}.cm-header h3{margin:0;color:#1f2937;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.cm-content{padding:.75rem;background:#fafbfc;max-height:500px;overflow-y:auto}.tree-list{list-style:none;padding:0;margin:0}.tree-item{position:relative}.tree-content{display:flex;align-items:center;padding:.5rem .75rem;background:transparent;border-radius:6px;margin-bottom:2px;transition:all .15s ease;gap:.5rem}.tree-content:hover{background:#46a5a514}.tree-label{flex:1;font-size:.9rem;color:#374151;font-weight:500;cursor:default}.tree-children{padding-left:1.5rem;position:relative;margin-left:.5rem;border-left:1px solid #E5E7EB}.tree-toggle{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:#9ca3af;cursor:pointer;border-radius:4px;transition:all .15s ease;flex-shrink:0}.tree-toggle:hover{background:#e5e7eb;color:#374151}.tree-toggle.empty{visibility:hidden}.cm-input{border:none;background:#fff;padding:.35rem .5rem;font-size:.9rem;color:#1f2937;flex:1;border:1px solid var(--color-accent);border-radius:4px;outline:none}.cm-input:focus{box-shadow:0 0 0 2px #46a5a533}.cm-actions{display:flex;gap:2px;margin-left:auto;opacity:0;transition:opacity .15s ease}.tree-content:hover .cm-actions{opacity:1}.btn-icon-xs{padding:4px;border-radius:4px;color:#9ca3af;cursor:pointer;background:transparent;border:none;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.btn-icon-xs:hover{background:#f3f4f6;color:var(--color-accent)}.btn-icon-xs.danger:hover{color:#ef4444;background:#ef44441a}.btn-add-root{background:var(--color-accent);color:#fff;border:none;padding:.4rem .75rem;border-radius:6px;font-size:.75rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px;transition:all .15s ease}.btn-add-root:hover{background:#3b8a8a;transform:translateY(-1px)}.add-sub-form{display:flex;gap:.5rem;padding:.5rem .75rem .5rem 2.5rem;background:#46a5a50d;border-radius:6px;margin-bottom:2px}.add-sub-form input{flex:1;padding:.35rem .5rem;border:1px solid #D1D5DB;border-radius:4px;font-size:.85rem}.add-sub-form input:focus{outline:none;border-color:var(--color-accent)}.add-sub-form button{padding:.35rem .75rem;border-radius:4px;font-size:.8rem;font-weight:500;cursor:pointer;border:none}.add-sub-form .btn-save{background:var(--color-accent);color:#fff}.add-sub-form .btn-cancel{background:#f3f4f6;color:#6b7280}.cm-empty{padding:2rem;text-align:center;color:#9ca3af;font-size:.9rem}.use-case-config{height:100%;display:flex;flex-direction:column}.use-case-header{padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb;background:#fff}.use-case-header h2{font-size:1rem;font-weight:600;color:#111827;margin:0}.use-case-header p{font-size:.875rem;color:#6b7280;margin:.25rem 0 0}.message{display:flex;align-items:center;gap:.5rem;margin:1rem 1.5rem;padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem}.message.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.message.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.config-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;padding:1rem 1.5rem;flex:1;overflow-y:auto}.config-column{border:1px solid #d1d5db;border-radius:.5rem;background:#fff;display:flex;flex-direction:column;max-height:calc(100vh - 400px)}.config-column.effective-column{background:#f9fafb}.column-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb}.header-title{display:flex;align-items:center;gap:.5rem}.header-title h3{font-size:.875rem;font-weight:600;color:#111827;margin:0}.header-title .badge{font-size:.625rem;font-weight:500;padding:.125rem .375rem;border-radius:.25rem;background:#f3f4f6;color:#6b7280}.header-title .badge.blue{background:#dbeafe;color:#2563eb}.column-header svg{color:#6b7280}.org-column .column-header svg{color:var(--color-primary-brand, #1e40af)}.user-column .column-header svg{color:#2563eb}.button-group{display:flex;gap:.5rem}.save-btn{display:flex;align-items:center;gap:.25rem;padding:.375rem .625rem;font-size:.75rem;font-weight:500;border:none;border-radius:.375rem;cursor:pointer;transition:all .2s}.save-btn.primary{background:var(--color-primary-brand, #1e40af);color:#fff}.save-btn.primary:hover:not(:disabled){background:#1e3a8a}.save-btn.blue{background:#2563eb;color:#fff}.save-btn.blue:hover:not(:disabled){background:#1d4ed8}.save-btn:disabled{opacity:.5;cursor:not-allowed}.reset-btn{display:flex;align-items:center;gap:.25rem;padding:.375rem .5rem;font-size:.75rem;font-weight:500;background:#fff;color:#6b7280;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;transition:all .2s}.reset-btn:hover:not(:disabled){background:#f9fafb;color:#374151}.reset-btn:disabled{opacity:.5;cursor:not-allowed}.config-form{padding:.75rem 1rem;overflow-y:auto;flex:1}.form-group{margin-bottom:.75rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;color:#6b7280;margin-bottom:.375rem}.form-group select,.form-group input{width:100%;padding:.5rem .75rem;font-size:.875rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%236b7280%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E);background-repeat:no-repeat;background-position:right .7rem top 50%;background-size:.65rem auto}.form-group select:focus,.form-group input:focus{outline:none;border-color:var(--color-primary-brand, #1e40af);box-shadow:0 0 0 2px #1e40af1a}.effective-config{padding:1rem}.effective-item{margin-bottom:.75rem}.effective-item:last-child{margin-bottom:0}.effective-item label{display:block;font-size:.6875rem;font-weight:600;text-transform:uppercase;color:#9ca3af;margin-bottom:.25rem}.effective-item .value{font-size:.875rem;font-weight:500;color:#111827;margin:0}@media(max-width:1024px){.config-grid{grid-template-columns:1fr}.config-column{max-height:none}}.ai-settings-panel{display:flex;flex-direction:column;height:100%;background:#fff;min-height:600px}.ai-settings-tabs{border-bottom:1px solid #e5e7eb;background:#f9fafb;flex-shrink:0}.ai-settings-tab-nav{display:flex;gap:.125rem;padding:0 1rem;overflow-x:auto;scrollbar-width:thin}.ai-settings-tab-nav::-webkit-scrollbar{height:4px}.ai-settings-tab-nav::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:2px}.ai-settings-tab{display:flex;align-items:center;gap:.375rem;padding:.625rem .875rem;font-size:.8125rem;font-weight:500;color:#6b7280;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;white-space:nowrap;transition:all .15s;position:relative}.ai-settings-tab:hover{color:#374151;background:#f3f4f6}.ai-settings-tab.active{color:#4f46e5;border-bottom-color:#4f46e5;background:#fff}.ai-settings-tab .tab-icon{flex-shrink:0}.ai-settings-tab .tab-label{display:inline}.tab-configured-dot{width:6px;height:6px;background:#10b981;border-radius:50%;flex-shrink:0}.ai-settings-description{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#f0f9ff;border-bottom:1px solid #bae6fd;flex-shrink:0}.ai-settings-description .info-icon{color:#0284c7;flex-shrink:0}.ai-settings-description p{font-size:.8125rem;color:#0369a1;margin:0}.ai-settings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.ai-settings-loading .spin{color:#4f46e5;animation:spin 1s linear infinite}.ai-settings-loading p{font-size:.875rem;color:#6b7280}.ai-settings-error{display:flex;align-items:center;gap:.75rem;margin:1rem;padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#991b1b}.ai-settings-error p{flex:1;margin:0;font-size:.875rem}.ai-settings-error .retry-btn{padding:.375rem .75rem;font-size:.8125rem;font-weight:500;color:#dc2626;background:#fff;border:1px solid #fecaca;border-radius:.375rem;cursor:pointer;transition:all .15s}.ai-settings-error .retry-btn:hover{background:#fef2f2;border-color:#f87171}.ai-settings-content{flex:1;overflow-y:auto;padding:0}.general-models-view{padding:1rem}.models-filters{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;margin-bottom:1.25rem}.filter-group{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#374151}.filter-group label{display:flex;align-items:center;gap:.375rem;cursor:pointer}.filter-group select{padding:.375rem .5rem;font-size:.8125rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff}.filter-group input[type=checkbox]{width:14px;height:14px;cursor:pointer}.models-count{margin-left:auto;font-size:.75rem;color:#6b7280}.ai-models-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.ai-models-empty .empty-icon{color:#d1d5db;margin-bottom:1rem}.ai-models-empty h3{font-size:1rem;font-weight:600;color:#374151;margin:0 0 .5rem}.ai-models-empty p{font-size:.875rem;color:#6b7280;margin:0 0 1rem}.ai-models-empty .refresh-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#4f46e5;background:#eef2ff;border:1px solid #c7d2fe;border-radius:.375rem;cursor:pointer}.ai-provider-section{margin-bottom:1.5rem}.provider-title{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;color:#111827;margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid #e5e7eb}.provider-icon{width:8px;height:8px;border-radius:50%}.provider-icon.provider-google{background:#4285f4}.provider-icon.provider-anthropic{background:#d97757}.provider-icon.provider-azure{background:#0078d4}.provider-icon.provider-openai{background:#10a37f}.provider-count{font-size:.75rem;font-weight:400;color:#9ca3af;margin-left:.25rem}.provider-models{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.ai-model-card{border:1px solid #e5e7eb;border-radius:.5rem;padding:.875rem;background:#fff;transition:all .15s}.ai-model-card:hover{border-color:#c7d2fe;box-shadow:0 2px 8px #4f46e514}.ai-model-card.default{border-color:#818cf8;background:linear-gradient(135deg,#eef2ff,#fff)}.ai-model-card.deprecated{opacity:.6;border-style:dashed}.ai-model-card.inactive{background:#f9fafb}.model-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.25rem}.model-name{font-size:.875rem;font-weight:600;color:#111827;line-height:1.3}.model-badges{display:flex;gap:.25rem;flex-shrink:0}.model-badges .badge{font-size:.625rem;font-weight:600;text-transform:uppercase;padding:.125rem .375rem;border-radius:.25rem}.badge.default{color:#4f46e5;background:#e0e7ff}.badge.deprecated{color:#b45309;background:#fef3c7}.badge.inactive{color:#6b7280;background:#f3f4f6}.model-id{font-size:.6875rem;font-family:SF Mono,Monaco,Consolas,monospace;color:#6b7280;margin:0 0 .5rem;word-break:break-all}.model-stats{display:flex;gap:.75rem;font-size:.6875rem;color:#6b7280;margin-bottom:.5rem}.model-stats strong{color:#374151}.model-capabilities{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem;min-height:1.25rem}.model-capabilities .cap{font-size:.5625rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;padding:.125rem .375rem;border-radius:.1875rem}.cap.vision{background:#f3e8ff;color:#7c3aed}.cap.audio{background:#fce7f3;color:#db2777}.cap.functions{background:#ffedd5;color:#c2410c}.cap.streaming{background:#dcfce7;color:#15803d}.model-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.5rem;border-top:1px solid #f3f4f6}.model-cost{font-size:.6875rem;font-weight:500;color:#059669}.use-case-count{font-size:.625rem;color:#6b7280;background:#f3f4f6;padding:.125rem .375rem;border-radius:.25rem}@media(max-width:768px){.ai-settings-tab .tab-label{display:none}.ai-settings-tab{padding:.75rem}.models-filters{flex-wrap:wrap;gap:.75rem}.provider-models{grid-template-columns:1fr}}.admin-page{padding-bottom:var(--spacing-2xl)}.admin-header{margin-bottom:var(--spacing-xl)}.admin-header h1{margin-bottom:var(--spacing-xs)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:var(--font-size-sm)}.alert-success{background:#10b98126;border:1px solid var(--color-success);color:var(--color-success)}.alert-error{background:#ef444426;border:1px solid var(--color-error);color:var(--color-error)}.admin-section{margin-bottom:var(--spacing-md)}.admin-section h2{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm);font-weight:600}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.action-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);text-align:center}.action-icon{font-size:2.5rem;display:block;margin-bottom:var(--spacing-sm)}.action-card h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-xs)}.action-card p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.stats-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.stat-box{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-md) var(--spacing-lg);min-width:120px;text-align:center}.stat-box.success{border-left:3px solid var(--color-success)}.stat-box.warning{border-left:3px solid var(--color-warning)}.stat-box.error{border-left:3px solid var(--color-error)}.stat-box.info{border-left:3px solid var(--color-info)}.stat-number{display:block;font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.jobs-table-container{overflow-x:auto;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.jobs-table{width:100%;border-collapse:collapse}.jobs-table th,.jobs-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--color-border)}.jobs-table th{background:var(--color-bg-secondary);font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.jobs-table td{font-size:var(--font-size-sm)}.jobs-table tr:last-child td{border-bottom:none}.jobs-table tr:hover td{background:var(--color-bg-tertiary)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.badge-error{background:#ef444426;color:var(--color-error)}.badge-info{background:#3b82f626;color:var(--color-info)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md)}.info-item{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md);display:flex;flex-direction:column}.info-item .info-label{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--spacing-xs)}.info-item .info-value{color:var(--color-text-primary);font-family:monospace}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-4{gap:1rem}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.w-full{width:100%}.sticky{position:sticky}.top-0{top:0}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mt-3{margin-top:.75rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.pb-4{padding-bottom:1rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.font-medium{font-weight:500}.text-muted{color:var(--color-text-muted)}.text-danger{color:var(--color-error)}.border{border:1px solid var(--color-border)}.rounded{border-radius:var(--radius-md)}.bg-card{background:var(--color-bg-card)}.bg-secondary{background:var(--color-bg-secondary)}.bg-highlight{background:rgba(var(--primary-rgb),.1)}.bg-success-light{background:#10b9811a}.compact-table td,.compact-table th{padding:.35rem .5rem}.btn-icon{background:none;border:none;cursor:pointer;padding:2px}.btn-icon:hover{opacity:.8}.text-primary{color:var(--color-primary)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.mobile-nav-bar{display:none;position:fixed;bottom:0;left:0;right:0;height:56px;background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -2px 10px #0000001a;z-index:1000;padding:0 8px;align-items:center;justify-content:space-around;gap:4px}@media(max-width:768px){.mobile-nav-bar{display:flex}.viewer-content,.slide-container{padding-bottom:64px!important}}.mobile-nav-btn{display:flex;align-items:center;justify-content:center;min-width:44px;height:44px;padding:8px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:10px;color:#374151;cursor:pointer;transition:all .15s ease}.mobile-nav-btn:hover:not(:disabled){background:#e5e7eb}.mobile-nav-btn:active:not(:disabled){transform:scale(.95)}.mobile-nav-btn:disabled{opacity:.4;cursor:not-allowed}.mobile-nav-btn.sections-btn{flex:1;max-width:120px;gap:6px}.section-indicator{font-size:12px;font-weight:600;color:#6b7280}.mobile-nav-btn.tts-btn{background:#f3f4f6}.mobile-nav-btn.tts-btn.playing{background:#3b82f6;border-color:#3b82f6;color:#fff}.mobile-nav-btn.tts-stop-btn{background:#fef2f2;border-color:#fecaca;color:#dc2626}.mobile-nav-btn.tts-stop-btn:hover{background:#fee2e2}@supports (padding-bottom: env(safe-area-inset-bottom)){.mobile-nav-bar{padding-bottom:calc(8px + env(safe-area-inset-bottom));height:calc(56px + env(safe-area-inset-bottom))}}.mobile-sections-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;animation:fadeIn .2s ease}.mobile-sections-panel{position:absolute;left:0;top:0;bottom:0;width:85%;max-width:320px;background:#fff;display:flex;flex-direction:column;animation:slideIn .25s ease;box-shadow:4px 0 20px #00000026}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.mobile-sections-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.mobile-sections-title{font-size:16px;font-weight:600;color:#111827;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(100% - 48px)}.mobile-sections-close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:8px;color:#6b7280;cursor:pointer}.mobile-sections-close:hover{background:#f3f4f6;color:#374151}.mobile-sections-list{flex:1;overflow-y:auto;padding:8px;-webkit-overflow-scrolling:touch}.mobile-section-item{display:flex;align-items:center;width:100%;padding:12px;background:transparent;border:none;border-radius:8px;text-align:left;cursor:pointer;transition:background .15s ease;gap:12px}.mobile-section-item:hover{background:#f3f4f6}.mobile-section-item.active{background:#eff6ff}.mobile-section-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#e5e7eb;border-radius:6px;font-size:12px;font-weight:600;color:#6b7280;flex-shrink:0}.mobile-section-item.active .mobile-section-number{background:#3b82f6;color:#fff}.mobile-section-title{flex:1;font-size:14px;color:#374151;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.mobile-section-item.active .mobile-section-title{color:#1d4ed8;font-weight:500}.mobile-section-check{color:#3b82f6;flex-shrink:0}@supports (padding-top: env(safe-area-inset-top)){.mobile-sections-header{padding-top:calc(16px + env(safe-area-inset-top))}}.tts-floating{position:fixed;bottom:24px;right:24px;z-index:900;display:flex;flex-direction:column;align-items:flex-end;gap:8px}@media(max-width:768px){.tts-floating{bottom:76px;right:16px}}.tts-fab{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #3b82f666;transition:all .2s ease}.tts-fab:hover{transform:scale(1.05);box-shadow:0 6px 16px #3b82f680}.tts-fab:active{transform:scale(.95)}.tts-fab.playing{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b98166;animation:pulse 2s infinite}.tts-fab.loading{background:linear-gradient(135deg,#6b7280,#4b5563)}@keyframes pulse{0%,to{box-shadow:0 4px 12px #10b98166}50%{box-shadow:0 4px 20px #10b98199}}.tts-floating-panel{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:12px;min-width:200px;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.tts-progress{height:3px;background:#e5e7eb;border-radius:2px;margin-bottom:10px;overflow:hidden}.tts-progress-bar{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:2px;transition:width .3s ease}.tts-controls-row{display:flex;align-items:center;gap:6px}.tts-control-btn{width:36px;height:36px;border-radius:8px;background:#f3f4f6;border:1px solid #e5e7eb;color:#374151;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.tts-control-btn:hover:not(:disabled){background:#e5e7eb}.tts-control-btn:disabled{opacity:.4;cursor:not-allowed}.tts-control-btn.primary{background:#3b82f6;border-color:#3b82f6;color:#fff}.tts-control-btn.primary:hover:not(:disabled){background:#2563eb}.tts-control-btn.primary.active{background:#10b981;border-color:#10b981}.tts-control-btn.voice-btn{width:auto;padding:0 8px;gap:4px}.tts-voice-selector{position:relative}.tts-voice-menu{position:absolute;bottom:100%;right:0;margin-bottom:8px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;padding:4px;min-width:150px;max-height:200px;overflow-y:auto;animation:fadeIn .15s ease}.tts-voice-option{display:block;width:100%;padding:8px 12px;background:transparent;border:none;border-radius:6px;text-align:left;font-size:13px;color:#374151;cursor:pointer}.tts-voice-option:hover{background:#f3f4f6}.tts-voice-option.selected{background:#eff6ff;color:#2563eb;font-weight:500}.tts-speed-select{height:36px;padding:0 8px;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:8px;font-size:13px;color:#374151;cursor:pointer}.tts-speed-select:hover{background:#e5e7eb}.tts-chunk-indicator{font-size:11px;color:#6b7280;text-align:center;margin-top:8px}.tts-collapse-btn{position:absolute;top:4px;right:4px;width:24px;height:24px;background:transparent;border:none;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px}.tts-collapse-btn:hover{background:#f3f4f6;color:#6b7280}.tts-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.tts-control-btn .tts-spinner{border:2px solid rgba(59,130,246,.3);border-top-color:#3b82f6}.tts-floating.hidden{display:none}.code-block{position:relative;margin:var(--spacing-md) 0;border-radius:var(--radius-md);overflow:hidden}.code-block pre{margin:0;padding:var(--spacing-md);background:#1e1e2e;overflow-x:auto}.code-block code{font-family:JetBrains Mono,Fira Code,Consolas,Monaco,monospace;font-size:13px;line-height:1.5;color:#cdd6f4;background:transparent;padding:0;white-space:pre;display:block}.code-block__language{position:absolute;top:0;right:0;padding:var(--spacing-xs) var(--spacing-sm);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#ffffff80;background:#0000004d;border-bottom-left-radius:var(--radius-sm)}.ascii-viewer-container{position:relative;height:600px;background-color:#0f111a;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;margin:var(--spacing-lg) 0;box-shadow:0 12px 36px #0006}.ascii-controls{position:absolute;bottom:24px;right:24px;display:flex;gap:8px;background:#0f111ab3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:6px 10px;border-radius:50px;border:1px solid rgba(255,255,255,.08);z-index:10;align-items:center;box-shadow:0 8px 16px #0000004d}.icon-btn{background:transparent;border:none;color:#fffc;cursor:pointer;padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-btn:hover{background:#ffffff1a;color:#fff;transform:scale(1.1)}.icon-btn:active{transform:scale(.95)}.ascii-controls .divider{width:1px;height:16px;background:#fff3;margin:0 4px}.icon-indicator{color:#fff9;display:flex;align-items:center;padding:0 4px;cursor:grab}.ascii-canvas{width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;position:relative}.ascii-content{transition:transform .1s ease-out;will-change:transform}.ascii-content pre{background:transparent;padding:0;margin:0;overflow:hidden;border:none;box-shadow:none}.ascii-viewer-container ::-webkit-scrollbar{display:none}.ascii-viewer-container{scrollbar-width:none}.ascii-viewer-container code{font-family:JetBrains Mono,Fira Code,Consolas,Monaco,monospace;font-size:13px;font-weight:500;line-height:1.3;color:#c0caf5;letter-spacing:0;font-variant-ligatures:none;text-shadow:none}.code-block--mermaid{background:var(--color-bg-card);border:1px solid var(--color-border);padding:var(--spacing-md);display:flex;justify-content:center;align-items:center;overflow-x:auto}.code-block--mermaid svg{max-width:100%;height:auto}.code-block--loading{background:var(--color-bg-tertiary);padding:var(--spacing-lg);text-align:center;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-md)}.code-block--error{background:#2d1f1f;border:1px solid #dc3545}.code-block--error .code-block__header{padding:var(--spacing-sm) var(--spacing-md);background:#dc354533;color:#f87171;font-size:var(--font-size-sm);font-weight:500}.code-block--error pre{background:transparent}.code-block--error code{color:#fca5a5}.inline-code{background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);font-family:Consolas,Monaco,Courier New,monospace;font-size:.85em;color:var(--color-primary-brand)}.viewer-page{height:100vh;max-height:100vh;display:flex;flex-direction:column;background:var(--color-bg-secondary);overflow:hidden;box-sizing:border-box}.viewer-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md)}.spinner{width:40px;height:40px;border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-primary-brand);border-radius:50%;animation:spin 1s linear infinite}.viewer-toolbar{display:flex;align-items:center;justify-content:space-between;height:40px;padding:0 .75rem;background:#fff;border-bottom:1px solid #E5E7EB;box-shadow:0 1px 2px #0000000a;flex-shrink:0}.toolbar-left{display:flex;align-items:center;gap:1rem}.toolbar-logo{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--color-text-primary);text-decoration:none}.toolbar-logo .logo-icon{font-size:1.25rem}.toolbar-divider{width:1px;height:24px;background:#e5e7eb}.module-title{font-size:.9rem;color:#6b7280;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.toolbar-center{display:flex;align-items:center;gap:.5rem;flex:1;justify-content:center;min-width:0}.nav-btn{width:22px!important;height:22px!important;min-width:22px;min-height:22px;padding:0;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border:1px solid #D1D5DB;border-radius:4px;color:#374151;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .15s ease;flex:0 0 22px!important}.nav-btn:hover:not(:disabled){background:#e5e7eb;border-color:var(--color-accent);color:var(--color-text-primary)}.toolbar-section-info{width:600px;max-width:600px;flex:0 1 600px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:12px;padding:.25rem .5rem;background:#f3f4f6;border:1px solid #E5E7EB;border-radius:8px;overflow:hidden;min-width:0}.toolbar-slide-indicator{font-size:.85rem;color:#6b7280;font-weight:500;white-space:nowrap;flex-shrink:0}.toolbar-section-title{font-size:.95rem;font-weight:600;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left;display:block;margin:0;line-height:normal;min-width:0}@media(max-width:1024px){.toolbar-section-title{max-width:200px}}@media(max-width:768px){.toolbar-section-title{max-width:120px}}.toolbar-right{display:flex;align-items:center;gap:.5rem}.progress-mini{width:80px;height:4px;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-mini-fill{height:100%;background:var(--color-accent);transition:width .3s ease}.toolbar-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:5px;cursor:pointer;transition:color .2s ease;text-decoration:none;color:#64748b}.toolbar-btn svg{width:15px;height:15px;stroke-width:2}.toolbar-btn:hover{color:#1e293b}.toolbar-btn.active{color:var(--color-accent, #46a5a5)}.tts-controls{display:flex;align-items:center;gap:.5rem;padding:0 .5rem;margin-left:.5rem}.tts-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:5px;cursor:pointer;transition:color .2s ease;color:#64748b}.tts-btn svg{width:15px;height:15px;stroke-width:2}.tts-btn:hover{color:var(--color-accent, #46a5a5)}.tts-btn.playing{color:#ef4444;animation:pulse-playing 1.5s ease-in-out infinite}.tts-btn.paused{color:#f59e0b}@keyframes pulse-playing{0%,to{opacity:1}50%{opacity:.6}}.viewer-body{display:flex;flex:1;overflow:hidden;min-height:0}.viewer-nav{width:260px;background:#fff;border-right:1px solid #E5E7EB;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;min-height:0}.nav-title{padding:1rem 1.25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#6b7280;border-bottom:1px solid #E5E7EB;background:#fafbfc}.nav-list{flex:1;overflow-y:auto;padding:.5rem}.nav-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem .75rem;margin-bottom:2px;background:transparent;border:none;border-radius:6px;text-align:left;cursor:pointer;transition:all .15s ease}.nav-item:hover{background:#f3f4f6}.nav-item.active{background:#e0f2fe;border-left:3px solid #0369A1}.nav-item.completed{opacity:.85}.nav-item-number{font-size:.75rem;font-weight:700;color:#374151;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#f3f4f6;border-radius:4px}.nav-item.active .nav-item-number{color:#0369a1;background:#bfdbfe}.nav-item-title{flex:1;font-size:.85rem;color:#374151;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-item.active .nav-item-title{color:#0369a1;font-weight:600}.viewer-breadcrumbs{display:flex;align-items:center;gap:6px;margin-left:var(--spacing-md);font-size:.85rem;color:#fff9}.breadcrumb-item{color:#fffc;text-decoration:none}.breadcrumb-item:hover{color:#fff;text-decoration:underline}.breadcrumb-separator{color:#fff6;font-size:10px}.breadcrumb-current{color:#fff;font-weight:500}.ai-suggestions button{padding:6px 12px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.85rem;color:var(--color-primary-brand);font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.ai-suggestions button:hover{background:var(--color-bg-secondary);border-color:var(--color-primary-brand);transform:translateY(-1px)}.nav-item-check{font-size:var(--font-size-xs);color:var(--color-success)}.viewer-content{flex:1;display:flex;flex-direction:column;padding:.75rem;overflow:hidden;min-width:0;min-height:0}.slide{flex:1;display:flex;flex-direction:column;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);min-height:0}.slide-header{padding:.5rem 1rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);flex-shrink:0}.slide-breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:.35rem;padding:.5rem 1rem;background:#f8fafc;border-bottom:1px solid #E5E7EB;font-size:.8rem}.crumb-link{color:#0369a1;text-decoration:none;font-weight:600;padding:.15rem .35rem;border-radius:3px;transition:all .15s ease}.crumb-link:hover{color:#0c4a6e;background:#e0f2fe;text-decoration:underline}.crumb-segment{display:flex;align-items:center;gap:.35rem}.crumb-separator{color:#9ca3af;font-size:.75rem}.crumb-text{color:#374151;font-weight:500}.crumb-current{color:#1f2937;font-weight:600;background:#e5e7eb;padding:.15rem .5rem;border-radius:3px;font-size:.75rem}.slide-number{font-size:.65rem;font-weight:600;color:var(--color-accent);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.15rem}.slide-title{font-size:1.1rem;margin:0;line-height:1.3;color:var(--color-text-primary)}.slide-body{flex:1;padding:var(--spacing-lg);overflow-y:auto;line-height:1.7}.slide-body h2{font-size:var(--font-size-lg);margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm);color:var(--color-text-primary)}.slide-body h3{font-size:var(--font-size-base);margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm);color:var(--color-primary-brand)}.slide-body h4{font-size:var(--font-size-sm);margin-top:var(--spacing-sm);margin-bottom:var(--spacing-xs);color:var(--color-text-primary)}.slide-body p{margin-bottom:var(--spacing-sm);color:var(--color-text-secondary)}.slide-body ul{margin-bottom:var(--spacing-sm);padding-left:var(--spacing-xl);list-style-type:disc}.slide-body ol{margin-bottom:var(--spacing-sm);padding-left:var(--spacing-xl);list-style-type:decimal}.slide-body li{margin-bottom:var(--spacing-xs);color:var(--color-text-secondary);padding-left:.25rem}.slide-body strong{color:var(--color-text-primary);font-weight:600}.slide-body code{background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);font-family:Consolas,Monaco,Courier New,monospace;font-size:.85em;color:var(--color-primary-brand)}.slide-body pre{background:#1e1e2e;color:#cdd6f4;border-radius:var(--radius-md);padding:1.5rem;overflow-x:auto;overflow-y:auto;margin:var(--spacing-md) 0;font-size:11px;line-height:1.3;max-height:600px;border:1px solid var(--color-border);box-sizing:border-box}.slide-body pre code{background:transparent;padding:0;color:inherit;font-family:JetBrains Mono,Fira Code,Consolas,Monaco,monospace;font-size:inherit;white-space:pre;display:block;letter-spacing:0;word-spacing:0}.slide-body blockquote{border-left:3px solid var(--color-primary-brand);padding-left:var(--spacing-md);margin:var(--spacing-sm) 0;font-style:italic;color:var(--color-text-secondary);padding:var(--spacing-sm) var(--spacing-md);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.slide-body table{width:auto;max-width:100%;margin:1.5rem 0;border-collapse:collapse;font-size:.95rem;color:#1f2937;background:#fff;border:1px solid #e5e7eb;display:table}.slide-body table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.slide-body table th{padding:.75rem 1rem;text-align:left;color:var(--color-text-primary)}.slide-body tr:nth-child(2n){background-color:var(--color-bg-tertiary)}.slide-footer{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-top:1px solid #E5E7EB;background:#fff;flex-shrink:0}.slide-footer .btn-secondary{padding:.4rem .85rem;background:#fff;border:2px solid #D1D5DB;border-radius:6px;color:#374151;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.slide-footer .btn-secondary:hover:not(:disabled){background:#f3f4f6;border-color:var(--color-accent);color:var(--color-text-primary)}.slide-footer .btn-secondary:disabled{opacity:.4;cursor:not-allowed}.slide-footer .btn-primary{padding:.4rem 1rem;background:var(--color-accent);border:none;border-radius:6px;color:#fff;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem;box-shadow:0 2px 4px #0000001a}.slide-footer .btn-primary:hover{background:#3b8a8a;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.viewer-ai{width:350px;background:var(--color-bg-card);border-left:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0;transition:width .3s ease,transform .3s ease;position:relative}.viewer-ai.collapsed{width:0;overflow:hidden;border-left:none}.viewer-toc{width:240px;background:var(--color-bg-card);border-left:1px solid var(--color-border);flex-shrink:0;overflow:hidden}.viewer-toc .toc-sidebar{border:none;border-radius:0;position:relative;top:0;max-height:100%;height:100%}.video-player-wrapper{margin:1rem 0;border:1px solid #E5E7EB;border-radius:12px;overflow:hidden;background:#000;box-shadow:0 4px 12px #00000026;box-sizing:border-box;padding-bottom:12px}.video-player-wrapper:fullscreen{border-radius:0}.video-player-header{background:#1f2937;padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;border-bottom:1px solid #374151;color:#9ca3af;font-size:.85rem}.video-player-header span{flex:1}.video-player-header svg{color:#60a5fa}.fullscreen-btn{background:transparent;border:1px solid #4B5563;border-radius:4px;color:#9ca3af;padding:.25rem .5rem;cursor:pointer;font-size:1rem;transition:all .15s ease}.fullscreen-btn:hover{background:#374151;color:#fff;border-color:#60a5fa}.player-container{position:relative;width:auto;margin:0 12px;padding-top:56.25%;background:#000}.video-player-wrapper:fullscreen .player-container{padding-top:0;height:calc(100vh - 40px);max-height:none}.react-player{position:absolute;top:0;left:0;width:100%!important;height:100%!important}.image-wrapper{margin:1rem 0;text-align:center}.markdown-image{max-width:100%;max-height:50vh;border-radius:8px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.markdown-image.no-shadow{border-radius:0;box-shadow:none;border:none}.editor-actions{display:flex;gap:.5rem;padding:1rem 0;border-top:1px solid #E5E7EB;margin-top:.5rem}.editor-actions .btn-secondary{padding:.6rem 1rem;background:#fff;border:2px solid #D1D5DB;border-radius:8px;color:#374151;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.5rem}.editor-actions .btn-secondary:hover{background:#f3f4f6;border-color:#0369a1;color:#0369a1}.editor-actions .btn-primary{padding:.6rem 1.25rem;background:#0369a1;border:none;border-radius:8px;color:#fff;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 4px #0000001a}.editor-actions .btn-primary:hover{background:#0c4a6e;transform:translateY(-1px)}.editor-actions .btn-primary:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.ai-header{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border)}.ai-avatar{font-size:1.25rem}.ai-header h3{font-size:var(--font-size-sm);margin:0}.ai-status{font-size:var(--font-size-xs);color:var(--color-text-muted)}.ai-messages{flex:1;padding:var(--spacing-sm);overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-sm)}.ai-welcome{text-align:center;padding:var(--spacing-md)}.ai-welcome p{color:var(--color-text-muted);font-size:var(--font-size-sm);margin-bottom:var(--spacing-sm)}.ai-suggestions{display:flex;flex-direction:column;gap:var(--spacing-xs)}.ai-suggestions button{padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.ai-suggestions button:hover{background:var(--color-bg-hover);border-color:var(--color-primary-brand);color:var(--color-text-primary)}.ai-message{display:flex;gap:var(--spacing-xs);align-items:flex-start}.ai-message.user{flex-direction:row-reverse}.ai-msg-avatar{flex-shrink:0;font-size:.875rem}.ai-message p{background:var(--color-bg-tertiary);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);max-width:85%;margin:0;line-height:1.4}.ai-message.user p{background:var(--color-primary-brand);color:var(--color-text-on-accent)}.typing-dots{display:flex;gap:3px;padding:var(--spacing-xs) var(--spacing-sm);background:var(--color-bg-tertiary);border-radius:var(--radius-md)}.typing-dots span{width:5px;height:5px;background:var(--color-text-muted);border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.ai-input-form{display:flex;gap:var(--spacing-sm);padding:1rem;background:#fafbfc;border-top:1px solid var(--color-border)}.ai-input-form input{flex:1;padding:.75rem 1rem;font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:6px;background:#fff;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.ai-input-form input:focus{outline:none;border-color:var(--color-primary-brand);box-shadow:0 0 0 3px var(--color-primary-brand-light)}.ai-input-form button{padding:0 1.25rem;background:var(--color-primary-brand);border:none;border-radius:6px;color:var(--color-text-on-accent);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.ai-input-form button:hover:not(:disabled){background:var(--color-primary-brand-hover)}.ai-input-form button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1100px){.viewer-nav{width:180px}.viewer-ai{width:240px}}@media(max-width:900px){.viewer-nav,.viewer-ai{display:none}.slide{border-radius:0;border:none}.viewer-content{padding:0}}.modal-overlay{position:fixed;inset:0;background:#0f172abf;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid rgba(148,163,184,.3);border-radius:16px;width:680px;min-width:680px;max-width:680px;height:560px;min-height:560px;max-height:560px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a inset;animation:modalSlideIn .2s ease-out;overflow:hidden}.modal-content.large{width:780px;min-width:780px;max-width:780px;height:600px;min-height:600px;max-height:600px}@keyframes modalSlideIn{0%{transform:translateY(-20px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(to bottom,#fff,#f8fafc);flex-shrink:0}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b;letter-spacing:-.01em}.modal-close-btn{background:transparent;border:none;color:#64748b;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.modal-close-btn:hover{background:#f1f5f9;color:#334155}.modal-body{padding:20px 24px;overflow-y:auto;flex:1;display:flex;flex-direction:column}.modal-tabs{display:flex;gap:4px;margin-bottom:20px;padding:4px;background:#f1f5f9;border-radius:10px;flex-shrink:0}.modal-tab{flex:1;padding:10px 16px;cursor:pointer;border-radius:8px;color:#64748b;font-weight:500;font-size:.875rem;transition:all .15s ease;display:flex;align-items:center;justify-content:center;gap:8px;border:none;background:transparent}.modal-tab:hover{color:#334155;background:#ffffff80}.modal-tab.active{background:#fff;color:#0078d4;font-weight:600;box-shadow:0 1px 3px #0000001a}.browser-container{display:flex;flex-direction:column;height:350px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-tertiary)}.browser-header{padding:var(--spacing-sm);border-bottom:1px solid var(--color-border);background:var(--color-bg-secondary);display:flex;gap:var(--spacing-sm);align-items:center}.breadcrumbs{display:flex;gap:var(--spacing-xs);font-size:var(--font-size-sm);color:#1f2937;overflow-x:auto;white-space:nowrap;align-items:center}.breadcrumb-item{cursor:pointer;padding:2px 4px;border-radius:4px}.breadcrumb-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.browser-list{flex:1;overflow-y:auto;padding:var(--spacing-xs)}.file-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);cursor:pointer;border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);transition:background var(--transition-fast)}.file-item:hover{background:var(--color-bg-card);color:var(--color-text-primary)}.file-item.selected{background:var(--color-primary-brand-light);color:var(--color-primary-brand);font-weight:500}.file-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}.file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.url-input-container{display:flex;flex-direction:column;gap:var(--spacing-sm)}.url-helper{font-size:var(--font-size-xs);color:var(--color-text-muted)}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #E5E7EB;display:flex;justify-content:flex-end;gap:.75rem;background:#f9fafb;border-radius:0 0 12px 12px}.modal-footer .btn-secondary{padding:.6rem 1.25rem;background:#fff;border:2px solid #D1D5DB;border-radius:8px;color:#374151;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease}.modal-footer .btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.modal-footer .btn-primary{padding:.6rem 1.5rem;background:#0369a1;border:none;border-radius:8px;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 4px #0000001a}.modal-footer .btn-primary:hover:not(:disabled){background:#0c4a6e;transform:translateY(-1px)}.modal-footer .btn-primary:disabled{background:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.browser-table-header{display:flex;padding:.75rem;border-bottom:2px solid var(--color-border);background:var(--color-bg-tertiary);font-weight:600;font-size:.875rem;color:var(--color-text-secondary)}.browser-list.table-view{padding:0}.file-row{display:flex;align-items:center;padding:.5rem .75rem;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background-color .2s;font-size:.9rem}.file-row:hover{background-color:var(--color-bg-tertiary)}.file-row.selected{background-color:var(--color-primary-brand-light);border-color:var(--color-primary-brand)}.col-icon{width:30px;display:flex;align-items:center}.col-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:1rem}.col-date{width:120px;color:var(--color-text-muted);font-size:.8rem}.col-size{width:80px;text-align:right;color:var(--color-text-muted);font-size:.8rem;font-family:monospace}@media(max-width:768px){.tts-floating{display:none}.slide-body{padding-bottom:80px}.slide-footer{padding-bottom:72px}.toolbar-right .tts-btn,.toolbar-right .toolbar-btn[title*=Auto-advance]{display:none}.viewer-toolbar{padding:0 .5rem}.toolbar-left .toolbar-logo span{display:none}.module-title{max-width:150px;font-size:.8rem}.toolbar-section-info{max-width:200px;flex:0 1 200px;gap:6px;padding:.2rem .4rem}.toolbar-slide-indicator{font-size:.75rem}.toolbar-section-title{font-size:.8rem;max-width:100px}.slide-breadcrumbs{padding:.4rem .75rem;font-size:.7rem}.crumb-current{font-size:.65rem}}@media(max-width:480px){.toolbar-left .toolbar-divider,.module-title{display:none}.toolbar-section-info{max-width:140px;flex:0 1 140px}.toolbar-section-title{max-width:70px}.slide-footer{padding:.75rem 1rem;padding-bottom:72px}.slide-footer .btn-secondary,.slide-footer .btn-primary{padding:.35rem .6rem;font-size:.75rem}}@media(min-width:769px){.tts-floating{display:flex}}.category-page{padding:2rem;max-width:1400px;margin:0 auto}.page-breadcrumbs{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;padding:1rem 1.25rem;background:#fff;border:1px solid #E5E7EB;border-radius:10px;font-size:.9rem}.page-breadcrumbs .crumb-link{display:flex;align-items:center;gap:.35rem;color:var(--color-accent);text-decoration:none;font-weight:500;transition:all .15s ease}.page-breadcrumbs .crumb-link:hover{color:#2d7a7a;text-decoration:underline}.page-breadcrumbs .crumb-segment{display:flex;align-items:center;gap:.5rem}.page-breadcrumbs .crumb-separator{color:#9ca3af}.page-breadcrumbs .crumb-current{color:#1f2937;font-weight:600}.category-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #E5E7EB;border-radius:12px}.header-icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:#46a5a51a;border-radius:12px;color:var(--color-accent)}.header-content h1{margin:0 0 .25rem;font-size:1.75rem;font-weight:700;color:#1f2937}.module-count{margin:0;color:#6b7280;font-size:.9rem}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.25rem}.module-card{display:flex;flex-direction:column;text-decoration:none;color:inherit;background:#fff;border:1px solid #E5E7EB;border-radius:12px;overflow:hidden;transition:all .2s ease}.module-card:hover{border-color:var(--color-accent);box-shadow:0 8px 24px #00000014;transform:translateY(-4px)}.module-visual{position:relative;height:96px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:linear-gradient(135deg,#8b8b8b,#6e6e6e)}.module-visual.visual-0,.module-visual.visual-1,.module-visual.visual-2,.module-visual.visual-3{background:linear-gradient(135deg,#8b8b8b,#6e6e6e)}.module-visual.visual-0{background:linear-gradient(135deg,#46a5a5,#5cb8b8)}.module-visual.visual-1{background:linear-gradient(135deg,#2c3e3e,#3d5454)}.module-visual.visual-2{background:linear-gradient(135deg,#6b7280,#9ca3af)}.module-visual.visual-3{background:linear-gradient(135deg,#3b8a8a,#46a5a5)}.visual-icon-wrapper{width:56px;height:56px;display:flex;align-items:center;justify-content:center;background:#fff3;border-radius:50%;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.visual-icon{color:#fff}.module-sequence{position:absolute;top:.75rem;left:.75rem;padding:.25rem .6rem;background:#ffffffe6;border-radius:4px;font-size:.7rem;font-weight:700;color:#374151}.module-content{padding:1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}.category-tag{font-size:.7rem;font-weight:600;color:var(--color-accent);text-transform:uppercase;letter-spacing:.05em}.module-title{margin:0;font-size:.95rem;font-weight:600;color:#1f2937;line-height:1.3}.module-description{margin:0;font-size:.75rem;color:#6b7280;line-height:1.5;flex:1}.module-footer{display:flex;align-items:center;justify-content:space-between;padding-top:.75rem;margin-top:.5rem;border-top:1px solid #F3F4F6}.meta-info{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:#9ca3af}.view-link{font-size:.85rem;font-weight:600;color:var(--color-accent)}.empty-state{text-align:center;padding:4rem 2rem;background:#fafbfc;border-radius:12px;border:1px dashed #D1D5DB}.empty-icon{color:#d1d5db;margin-bottom:1rem}.empty-state h3{margin:0 0 .5rem;color:#374151}.empty-state p{margin:0 0 1.5rem;color:#6b7280}.loading-state,.error-state{text-align:center;padding:4rem;color:#6b7280}.error-state p{margin-bottom:1rem}@media(max-width:768px){.category-page{padding:1rem}.modules-grid{grid-template-columns:1fr}.category-header{flex-direction:column;text-align:center}}.settings-page{max-width:900px;margin:0 auto}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--color-border, #e5e7eb)}.settings-title{display:flex;align-items:center;gap:12px}.settings-title h1{font-size:24px;font-weight:700;color:var(--color-text-primary, #111827);margin:0}.settings-title svg{color:var(--color-accent-primary, #297970)}.save-btn{display:flex;align-items:center;gap:8px}.settings-container{display:flex;gap:24px;background:var(--color-bg-card, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:12px;overflow:hidden}.settings-tabs{width:200px;background:var(--color-bg-tertiary, #f9fafb);padding:16px 0;border-right:1px solid var(--color-border, #e5e7eb)}.settings-tab{display:flex;align-items:center;gap:10px;width:100%;padding:12px 20px;border:none;background:transparent;color:var(--color-text-secondary, #6b7280);font-size:14px;font-weight:500;text-align:left;cursor:pointer;transition:all .2s}.settings-tab:hover{background:var(--color-bg-secondary, #f3f4f6);color:var(--color-text-primary, #111827)}.settings-tab.active{background:var(--color-bg-card, #ffffff);color:var(--color-accent-primary, #297970);border-right:2px solid var(--color-accent-primary, #297970)}.settings-tab svg{flex-shrink:0}.settings-content{flex:1;padding:24px;min-height:500px}.settings-panel h2{font-size:18px;font-weight:600;color:var(--color-text-primary, #111827);margin:0 0 8px}.settings-description{color:var(--color-text-muted, #9ca3af);font-size:14px;margin-bottom:24px}.setting-group{margin-bottom:20px}.setting-group label{display:block;font-size:14px;font-weight:500;color:var(--color-text-primary, #111827);margin-bottom:8px}.setting-group input[type=text],.setting-group input[type=email],.setting-group input[type=password],.setting-group select{width:100%;max-width:400px;padding:10px 12px;border:1px solid var(--color-border, #e5e7eb);border-radius:8px;font-size:14px;color:var(--color-text-primary, #111827);background:var(--color-bg-card, #ffffff);transition:border-color .2s}.setting-group input:focus,.setting-group select:focus{outline:none;border-color:var(--color-accent-primary, #297970);box-shadow:0 0 0 3px #2979701a}.setting-group input:disabled{background:var(--color-bg-tertiary, #f9fafb);color:var(--color-text-muted, #9ca3af);cursor:not-allowed}.setting-hint{display:block;font-size:12px;color:var(--color-text-muted, #9ca3af);margin-top:6px}.setting-group input[type=range]{width:100%;max-width:400px;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--color-bg-tertiary, #e5e7eb);border-radius:3px;cursor:pointer}.setting-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;background:var(--color-accent-primary, #297970);border-radius:50%;cursor:pointer;-webkit-transition:transform .2s;transition:transform .2s}.setting-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.range-labels{display:flex;justify-content:space-between;max-width:400px;font-size:11px;color:var(--color-text-muted, #9ca3af);margin-top:4px}.checkbox-group{margin-top:16px}.checkbox-label{display:flex!important;align-items:center;gap:10px;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-accent-primary, #297970);cursor:pointer}.theme-options{display:flex;gap:12px}.theme-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 24px;border:2px solid var(--color-border, #e5e7eb);border-radius:12px;background:var(--color-bg-card, #ffffff);cursor:pointer;transition:all .2s}.theme-option:hover{border-color:var(--color-accent-primary, #297970)}.theme-option.active{border-color:var(--color-accent-primary, #297970);background:#2979700d}.theme-option svg{color:var(--color-text-secondary, #6b7280)}.theme-option.active svg{color:var(--color-accent-primary, #297970)}.theme-option span{font-size:13px;font-weight:500;color:var(--color-text-secondary, #6b7280)}.theme-option.active span{color:var(--color-accent-primary, #297970)}.profile-settings{display:flex;flex-direction:column;gap:24px}.avatar-section{display:flex;align-items:center;gap:20px;padding:20px;background:var(--color-bg-tertiary, #f9fafb);border-radius:12px}.avatar-preview{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#297970,#20b2aa);display:flex;align-items:center;justify-content:center;overflow:hidden}.avatar-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-preview span{font-size:32px;font-weight:600;color:#fff}.avatar-info h3{font-size:18px;font-weight:600;color:var(--color-text-primary, #111827);margin:0 0 4px}.avatar-info p{font-size:14px;color:var(--color-text-muted, #9ca3af);margin:0}.role-badge{display:inline-block;margin-top:8px!important;padding:4px 12px;background:var(--color-accent-primary, #297970);color:#fff!important;font-size:12px!important;font-weight:500;border-radius:999px;text-transform:capitalize}.animate-spin{animation:spin 1s linear infinite}.provider-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:8px}.provider-card{padding:16px;border:2px solid var(--color-border, #e5e7eb);border-radius:12px;cursor:pointer;transition:all .2s;background:var(--color-bg-card, #ffffff)}.provider-card:hover{border-color:var(--color-accent-primary, #297970);box-shadow:0 2px 8px #00000014}.provider-card.selected{border-color:var(--color-accent-primary, #297970);background:linear-gradient(135deg,#2979700d,#29797005)}.provider-card-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.provider-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.provider-icon.kokoro{background:linear-gradient(135deg,teal,#20b2aa)}.provider-icon.browser{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.provider-info h4{margin:0;font-size:15px;font-weight:600;color:var(--color-text-primary, #111827)}.provider-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;margin-top:2px}.provider-badge.free{background:#dcfce7;color:#16a34a}.provider-badge.system{background:#e0e7ff;color:#4f46e5}.provider-desc{font-size:12px;color:var(--color-text-muted, #9ca3af);margin:0;line-height:1.4}.provider-selected{display:flex;align-items:center;gap:4px;margin-top:12px;font-size:12px;font-weight:600;color:var(--color-accent-primary, #297970)}.voices-by-category{background:var(--color-bg-card, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:20px;margin-top:12px}.category-title{font-size:.8rem;font-weight:600;color:var(--color-text-secondary, #64748b);text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid var(--color-border-light, #f1f5f9)}.voice-chip{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-bg-tertiary, #f8fafc);border:1px solid var(--color-border, #e2e8f0);border-radius:8px;cursor:pointer;transition:all .15s ease}.voice-chip:hover{border-color:var(--color-accent-primary, #297970);background:var(--color-bg-card, #ffffff)}.voice-chip.is-default{background:linear-gradient(135deg,#2979701a,#2979700d);border-color:var(--color-accent-primary, #297970)}.voice-chip .voice-name{font-size:.8125rem;font-weight:500;color:var(--color-text-primary, #1e293b)}.voice-chip .voice-gender{font-size:.7rem;color:var(--color-text-muted, #94a3b8);text-transform:capitalize}.chip-play-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:var(--color-accent-primary, #297970);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .15s ease}.chip-play-btn:hover:not(:disabled){background:var(--color-accent-dark, #1e5c55);transform:scale(1.05)}.default-check{color:var(--color-accent-primary, #297970)}.voice-card{display:flex;flex-direction:column;padding:12px;border:2px solid var(--color-border, #e5e7eb);border-radius:10px;cursor:pointer;transition:all .15s;background:var(--color-bg-card, #ffffff)}.voice-card:hover{border-color:var(--color-accent-primary, #297970)}.voice-card.selected{border-color:var(--color-accent-primary, #297970);background:linear-gradient(135deg,#29797014,#29797008)}.voice-card-main{display:flex;align-items:center;gap:10px}.voice-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;background:var(--color-bg-tertiary, #f3f4f6)}.voice-avatar.browser{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#4f46e5}.voice-details{flex:1;min-width:0}.voice-card .voice-name{display:block;font-size:13px;font-weight:600;color:var(--color-text-primary, #111827)}.voice-desc{display:block;font-size:11px;color:var(--color-text-muted, #9ca3af);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voice-selected-icon{color:var(--color-accent-primary, #297970);flex-shrink:0}.voice-preview-btn{display:flex;align-items:center;justify-content:center;width:100%;height:28px;margin-top:8px;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;background:var(--color-bg-card, #ffffff);color:var(--color-text-secondary, #6b7280);cursor:pointer;transition:all .15s}.voice-preview-btn:hover:not(:disabled){background:var(--color-accent-primary, #297970);border-color:var(--color-accent-primary, #297970);color:#fff}.voice-preview-btn:disabled{opacity:.6;cursor:wait}.browser-voice-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin-top:12px;margin-bottom:16px}.browser-voice{flex-direction:row}.no-voices-msg{color:var(--color-text-muted, #9ca3af);font-size:14px;padding:20px;text-align:center;background:var(--color-bg-tertiary, #f9fafb);border-radius:8px}.test-btn{margin-top:12px}.current-selection{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#2979701a,#2979700d);border-radius:8px;margin-top:20px}.selection-label{font-size:13px;color:var(--color-text-secondary, #6b7280)}.selection-value{font-size:13px;font-weight:600;color:var(--color-accent-primary, #297970)}.cache-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--color-border, #e5e7eb)}.clear-cache-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:var(--color-bg-tertiary, #f3f4f6);color:var(--color-text-secondary, #6b7280);border:1px solid var(--color-border, #e5e7eb);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.clear-cache-btn:hover:not(:disabled){background:var(--color-bg-card, #ffffff);border-color:var(--color-accent-primary, #297970);color:var(--color-accent-primary, #297970)}.clear-cache-btn:disabled{opacity:.7;cursor:not-allowed}@media(max-width:768px){.settings-container{flex-direction:column}.settings-tabs{width:100%;display:flex;overflow-x:auto;padding:8px;border-right:none;border-bottom:1px solid var(--color-border, #e5e7eb)}.settings-tab{flex-shrink:0;padding:10px 16px;border-radius:8px}.settings-tab.active{border-right:none;background:var(--color-accent-primary, #297970);color:#fff}.settings-content{padding:16px}.theme-options{flex-wrap:wrap}.avatar-section{flex-direction:column;text-align:center}.provider-cards{grid-template-columns:1fr}.voice-chips{flex-direction:column}.voice-chip{width:100%;justify-content:space-between}.browser-voice-list{grid-template-columns:1fr}.current-selection{flex-direction:column;text-align:center}.ai-services-grid{grid-template-columns:1fr}}.ai-services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-top:16px}.service-card{background:var(--color-bg-card, #ffffff);border:1px solid var(--color-border, #e5e7eb);border-radius:12px;padding:20px;transition:all .2s}.service-card:hover{border-color:var(--color-accent-primary, #297970);box-shadow:0 4px 12px #00000014}.service-card-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:12px}.service-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.service-icon.flowchart{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff}.service-icon.chat{background:linear-gradient(135deg,#3b82f6,#60a5fa);color:#fff}.service-icon.tts{background:linear-gradient(135deg,teal,#20b2aa);color:#fff}.service-info h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--color-text-primary, #111827)}.service-status{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.service-status.active{background:#dcfce7;color:#16a34a}.service-desc{font-size:13px;color:var(--color-text-muted, #9ca3af);line-height:1.5;margin:0 0 16px}.service-stats{display:flex;gap:16px;margin-bottom:16px;padding:12px;background:var(--color-bg-tertiary, #f9fafb);border-radius:8px}.stat-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text-secondary, #6b7280)}.stat-item svg{color:var(--color-accent-primary, #297970)}.service-config{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:13px}.config-label{color:var(--color-text-muted, #9ca3af)}.config-value{font-weight:600;color:var(--color-text-primary, #111827)}.service-settings{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border, #e5e7eb)}.service-settings .setting-row{display:flex;align-items:center;gap:12px}.service-settings label{font-size:13px;color:var(--color-text-secondary, #6b7280);margin:0}.service-settings select{flex:1;max-width:180px;padding:6px 10px;font-size:13px;border:1px solid var(--color-border, #e5e7eb);border-radius:6px;background:var(--color-bg-card, #ffffff)}.service-link{margin-top:12px}.btn-outline{background:transparent;border:1px solid var(--color-accent-primary, #297970);color:var(--color-accent-primary, #297970)}.btn-outline:hover{background:var(--color-accent-primary, #297970);color:#fff}.btn-sm{padding:6px 12px;font-size:13px}.settings-panel.ai-settings-full{padding:0;margin:-24px}.settings-panel.ai-settings-full .ai-settings-panel{border:none;box-shadow:none;background:transparent}.settings-panel.ai-settings-full .ai-settings-tabs{margin:0;border-radius:0}.settings-panel.ai-settings-full .ai-settings-content{padding:24px}.admin-layout{display:flex;flex-direction:column;height:100vh;background:#f5f7fa}.admin-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:60px;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff;box-shadow:0 2px 8px #00000026;z-index:100}.admin-header-left{display:flex;align-items:center;gap:1rem}.admin-menu-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;transition:background .2s}.admin-menu-toggle:hover{background:#fff3}.admin-title{font-size:1.25rem;font-weight:600;margin:0}.admin-role-badge{display:flex;align-items:center;gap:.4rem;padding:.35rem .75rem;background:#ffffff26;border-radius:20px;font-size:.75rem;font-weight:500;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px;margin-left:.5rem}.admin-role-badge svg{opacity:.9}.admin-header-right{display:flex;align-items:center;gap:.75rem}.admin-return-btn,.admin-logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;border:none;border-radius:8px;color:#fff;font-size:.875rem;cursor:pointer;text-decoration:none;transition:background .2s}.admin-return-btn:hover,.admin-logout-btn:hover{background:#fff3}.admin-body{display:flex;flex:1;overflow:hidden}.admin-sidebar{width:260px;background:linear-gradient(180deg,#1e3a5f,#16213e);color:#fff;overflow-y:auto;overflow-x:hidden;transition:width .3s ease;flex-shrink:0;position:relative;z-index:150}.admin-sidebar.closed{width:64px}.admin-sidebar.closed .admin-nav-btn span,.admin-sidebar.closed .admin-nav-btn svg:last-child{display:none}.admin-sidebar.closed .admin-nav-btn{justify-content:center;padding:1rem 0}.admin-sidebar.closed .admin-submenu{display:none}.admin-nav{padding:1rem 0}.admin-nav-item{margin-bottom:.25rem}.admin-nav-btn{display:flex;align-items:center;gap:12px;width:100%;padding:.75rem 1.25rem;background:transparent;border:none;color:#ffffffb3;font-size:.9rem;text-align:left;cursor:pointer;transition:all .2s;white-space:nowrap}.admin-nav-btn:hover{background:#ffffff1a;color:#fff}.admin-nav-btn.active{background:#00808033;color:#fff;border-left:3px solid #297970}.admin-nav-btn span{flex:1}.admin-submenu{padding-left:0;background:#0003;position:relative;z-index:200}.admin-submenu-btn{display:block;width:100%;padding:.6rem 1rem .6rem 2rem;background:transparent;border:none;color:#ffffffb3;font-size:.85rem;text-align:left;cursor:pointer;transition:all .2s}.admin-submenu-btn:hover{background:#ffffff14;color:#fff}.admin-submenu-btn.active{background:#00808033;color:#7fffd4}.admin-main{flex:1;padding:1.5rem;overflow-y:auto;background:#f5f7fa}.admin-sidebar-overlay{display:none}@media(max-width:768px){.admin-sidebar{position:fixed;top:60px;left:0;height:calc(100vh - 60px);z-index:200;transform:translate(-100%);width:260px;transition:transform .3s ease}.admin-sidebar.open{transform:translate(0)}.admin-sidebar.closed{transform:translate(-100%)}.admin-sidebar-overlay{display:block;position:fixed;inset:60px 0 0;background:#00000080;z-index:199}.admin-main{padding:1rem;width:100%}.admin-return-btn span,.admin-logout-btn span{display:none}.admin-header{padding:0 1rem}.admin-title{font-size:1rem}.admin-role-badge{display:none}}.admin-dashboard{max-width:1200px;margin:0 auto}.admin-dashboard.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#64748b}.spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#297970;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:1.75rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.dashboard-header p{color:#64748b;margin:0}.dashboard-section{margin-bottom:2rem}.dashboard-section h2{font-size:1rem;font-weight:600;color:#475569;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.05em}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}.stats-grid.jobs{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.stat-card.small{padding:1rem}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:color-mix(in srgb,var(--accent-color) 15%,transparent);border-radius:12px;color:var(--accent-color)}.stat-icon.small{width:40px;height:40px}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:1.5rem;font-weight:700;color:#1e293b;line-height:1.2}.stat-card.small .stat-value{font-size:1.25rem}.stat-label{font-size:.875rem;color:#64748b}.quick-actions{display:flex;flex-wrap:wrap;gap:1rem}.action-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#475569;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.action-btn:hover{background:#f8fafc;border-color:#297970;color:#297970}.search-box input{border:none;outline:none;font-size:.875rem;width:180px}.grid-header{display:grid;grid-template-columns:1.5fr 2fr .9fr .7fr 1fr .7fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.compact-grid.has-org-column .grid-header,.compact-grid.has-org-column .grid-row{grid-template-columns:1.3fr 1.8fr 1fr .8fr .7fr 1fr .7fr}.grid-row{display:grid;grid-template-columns:1.5fr 2fr .9fr .7fr 1fr .7fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:capitalize}.role-badge.user{background:#f1f5f9;color:#64748b}.role-badge.editor{background:#dbeafe;color:#1d4ed8}.role-badge.admin{background:#fef3c7;color:#b45309}.role-badge.org-admin{background:#e0e7ff;color:#4338ca}.role-badge.global-admin{background:#fce7f3;color:#be185d}.status-badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:12px;font-size:.7rem;font-weight:500}.org-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#f0f9ff;color:#0369a1;border-radius:6px;font-size:.8125rem;font-weight:500}.org-badge-small{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:#f0f9ff;color:#0369a1;border-radius:4px;font-size:.7rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.form-group label{display:block;font-size:.75rem;font-weight:600;color:#374151;margin-bottom:6px;text-transform:uppercase}.form-group input[type=text],.form-group input[type=email],.form-group select{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff}.form-help{display:block;font-size:.75rem;color:#64748b;margin-top:6px;font-style:italic}.admin-page{padding:24px;position:relative;min-height:100%}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-danger:hover{background:#fecaca}.grid-header{display:grid;grid-template-columns:2fr 1.2fr .8fr .6fr .8fr 1fr .8fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grid-row{display:grid;grid-template-columns:2fr 1.2fr .8fr .6fr .8fr 1fr .8fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.tier-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:capitalize}.tier-badge.free{background:#f1f5f9;color:#64748b}.tier-badge.pro{background:#dbeafe;color:#1d4ed8}.tier-badge.enterprise{background:#fef3c7;color:#b45309}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;font-size:.7rem;font-weight:500}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:.75rem;font-weight:600;color:#374151;margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.form-group input[type=text],.form-group input[type=email],.form-group select{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff;transition:border-color .15s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:#0078d4;box-shadow:0 0 0 3px #0078d41a}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer;text-transform:none!important}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#0078D4}.error-banner{display:flex;align-items:center;gap:8px;padding:12px;background:#fee2e2;color:#dc2626;border-radius:8px;margin-bottom:20px;font-size:.875rem}.btn-danger{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer}.btn-icon:hover{background:#f1f5f9;color:#dc2626}.btn-icon.enable:hover{color:#16a34a}.grid-header{display:grid;grid-template-columns:1.5fr 1fr .7fr 1fr .8fr .8fr .6fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grid-row{display:grid;grid-template-columns:1.5fr 1fr .7fr 1fr .8fr .8fr .6fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.grid-row.disabled-row{opacity:.6}.grid-row .grid-col{padding:10px 12px;font-size:.8125rem;color:#334155;display:flex;align-items:center;gap:6px;white-space:nowrap}.cost-col{color:#16a34a;font-weight:500}.latency-icon{color:#f59e0b}.grid-loading{padding:48px;text-align:center;color:#64748b}.provider-badge{display:inline-block;padding:3px 8px;background:#f1f5f9;color:#334155;border-radius:4px;font-size:.7rem;font-weight:600}.type-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.7rem;font-weight:600}.type-badge.type-text{background:#dbeafe;color:#1d4ed8}.type-badge.type-image{background:#fce7f3;color:#be185d}.type-badge.type-audio{background:#d1fae5;color:#047857}.status-badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:.7rem;font-weight:500}.status-badge.active{background:#dcfce7;color:#166534}.grid-header{display:grid;grid-template-columns:1.4fr 1.2fr 1.5fr 1.2fr 2fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grid-row{display:grid;grid-template-columns:1.4fr 1.2fr 1.5fr 1.2fr 2fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.grid-row .grid-col{padding:10px 12px;font-size:.8125rem;color:#334155;display:flex;align-items:center;gap:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.time-col{font-size:.75rem;color:#64748b}.row-icon{color:#94a3b8;flex-shrink:0}.details-col{color:#64748b;font-size:.75rem}.action-badge{display:inline-block;padding:3px 8px;border-radius:4px;font-size:.7rem;font-weight:600;font-family:monospace}.action-badge.success{background:#dcfce7;color:#166534}.action-badge.danger{background:#fee2e2;color:#dc2626}.action-badge.warning{background:#fef3c7;color:#b45309}.action-badge.info{background:#dbeafe;color:#1d4ed8}.action-badge.default{background:#f1f5f9;color:#64748b}.btn-primary.full-width{width:100%;justify-content:center}.settings-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px;margin-bottom:24px}.settings-card h3{display:flex;align-items:center;gap:8px;font-size:1rem;font-weight:600;color:#1e293b;margin:0 0 16px}.settings-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.setting-item{display:flex;flex-direction:column;gap:8px}.setting-item label{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.setting-item select{padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff}.setting-item select:focus{outline:none;border-color:#0078d4}.setting-item input[type=range]{width:100%;height:6px;accent-color:#0078D4}.section-header{display:flex;align-items:center;gap:8px;padding:16px 20px;font-weight:600;color:#1e293b;border-bottom:1px solid #e2e8f0;background:#f8fafc}.grid-header{display:grid;grid-template-columns:1.5fr 1fr .8fr 1fr 1fr .6fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grid-row{display:grid;grid-template-columns:1.5fr 1fr .8fr 1fr 1fr .6fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.grid-row.is-default{background:#f0fdf4}.grid-row .grid-col{padding:10px 16px;font-size:.8125rem;color:#334155;display:flex;align-items:center;gap:8px;white-space:nowrap}.default-tag{font-size:.65rem;background:#16a34a;color:#fff;padding:2px 6px;border-radius:4px;font-weight:600}.provider-badge{display:inline-block;padding:3px 8px;background:#dbeafe;color:#1d4ed8;border-radius:4px;font-size:.7rem;font-weight:600}.detail-actions{margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0}.detail-preview{margin-top:24px}.error-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.875rem;margin-bottom:20px}.grid-loading,.grid-empty{padding:40px 20px;text-align:center;color:#64748b;font-size:.875rem}.detail-overlay{position:fixed;inset:0;background:#0000004d;z-index:999}.provider-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.provider-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s ease}.provider-card:hover:not(.disabled){border-color:teal;box-shadow:0 4px 12px #0080801a}.provider-card.selected{border-color:teal;background:linear-gradient(135deg,#0080800d,#00808005)}.provider-card.disabled{opacity:.6;cursor:not-allowed}.provider-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.provider-header h4{margin:0;font-size:1rem;font-weight:600;color:#1e293b}.provider-description{font-size:.8rem;color:#64748b;margin:0 0 12px;line-height:1.4}.provider-stats{display:flex;gap:16px;font-size:.75rem;color:#94a3b8}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:9999px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.badge-primary{background:teal;color:#fff}.badge-success{background:#16a34a;color:#fff}.badge-warning{background:#f59e0b;color:#fff}.voices-by-category{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.category-section{margin-bottom:24px}.category-section:last-child{margin-bottom:0}.category-title{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.voice-chips{display:flex;flex-wrap:wrap;gap:10px}.voice-chip{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .15s ease}.voice-chip:hover{border-color:teal;background:#fff}.voice-chip.is-default{background:linear-gradient(135deg,#0080801a,#0080800d);border-color:teal}.voice-name{font-size:.8125rem;font-weight:500;color:#1e293b}.voice-gender{font-size:.7rem;color:#94a3b8;text-transform:capitalize}.chip-play-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:teal;border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .15s ease}.chip-play-btn:hover:not(:disabled){background:#066;transform:scale(1.05)}.chip-play-btn:disabled{opacity:.7;cursor:wait}.default-check{color:teal}@media(max-width:1024px){.provider-grid,.settings-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.provider-grid,.settings-grid{grid-template-columns:1fr}}.job-queue-page{padding:24px;position:relative}.filter-select{padding:8px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;background:#fff}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#0078d4;color:#fff;border:none;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .15s ease}.jobs-grid{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px}.compact-grid{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.grid-header{display:grid;grid-template-columns:1fr 1.2fr 1fr 1.5fr 1.2fr .8fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grid-header .grid-col{padding:12px 16px}.grid-col.sortable{cursor:pointer}.grid-col.sortable:hover{color:#0078d4}.grid-row{display:grid;grid-template-columns:1fr 1.2fr 1fr 1.5fr 1.2fr .8fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.grid-row .grid-col{padding:12px 16px;font-size:.875rem;color:#334155;display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grid-row .grid-col code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.75rem}.grid-loading,.grid-empty{padding:40px;text-align:center;color:#64748b}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-badge.completed{background:#dcfce7;color:#166534}.status-badge.running{background:#dbeafe;color:#1e40af}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.failed{background:#fee2e2;color:#991b1b}.status-icon.running{color:#2563eb}.progress-bar{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.progress-text{font-size:.75rem;color:#64748b;min-width:35px;text-align:right}.grid-col.actions{justify-content:flex-end}.detail-panel{position:fixed;top:0;right:-400px;width:400px;height:100vh;background:#fff;box-shadow:-4px 0 20px #0000001a;z-index:1000;transition:right .3s ease;display:flex;flex-direction:column}.detail-row label{font-size:.75rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.detail-row code{background:#f1f5f9;padding:4px 8px;border-radius:4px;font-family:monospace}.import-version-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center}.import-version-backdrop{position:absolute;inset:0;background:#0f172ab3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.import-version-container{position:relative;width:90%;max-width:720px;max-height:85vh;background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000059;display:flex;flex-direction:column;overflow:hidden}.import-version-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:linear-gradient(135deg,#1e293b,#334155);color:#fff}.import-version-header .header-left{display:flex;align-items:center;gap:12px}.import-version-header h2{margin:0;font-size:17px;font-weight:600;letter-spacing:-.01em}.import-version-header .module-info{color:#fff9;font-weight:400;font-size:14px}.import-version-header .btn-icon{background:#ffffff1a;border:1px solid rgba(255,255,255,.1);padding:8px;cursor:pointer;color:#fff;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.import-version-header .btn-icon:hover{background:#fff3;border-color:#fff3}.import-version-tabs{display:flex;gap:0;padding:0 24px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.import-version-tabs .tab{display:flex;align-items:center;gap:8px;padding:14px 20px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;color:#64748b;font-size:14px;font-weight:500;transition:all .2s ease}.import-version-tabs .tab:hover{color:#334155;background:#f1f5f9}.import-version-tabs .tab.active{color:#0ea5e9;border-bottom-color:#0ea5e9;background:#fff}.import-version-tabs .tab svg{flex-shrink:0}.import-version-content{flex:1;padding:24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px;background:#fff}.upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 32px;border:2px dashed #cbd5e1;border-radius:12px;background:#f8fafc;cursor:pointer;transition:all .2s ease}.upload-zone:hover{border-color:#0ea5e9;background:#0ea5e90a}.upload-zone .upload-icon{color:#94a3b8;margin-bottom:16px}.upload-zone .upload-text{font-size:15px;font-weight:600;color:#334155;margin:0 0 8px}.upload-zone .upload-hint{font-size:13px;color:#64748b;margin:0}.markdown-input-container{display:flex;flex-direction:column;gap:8px;flex:1;min-height:280px}.markdown-input-container label{font-size:13px;font-weight:600;color:#334155;text-transform:uppercase;letter-spacing:.03em}.markdown-input{flex:1;min-height:220px;padding:16px;border:1px solid #e2e8f0;border-radius:10px;font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;line-height:1.7;resize:none;background:#f8fafc;color:#1e293b;transition:all .2s ease}.markdown-input:focus{outline:none;border-color:#0ea5e9;background:#fff;box-shadow:0 0 0 3px #0ea5e91a}.markdown-input::-moz-placeholder{color:#94a3b8}.markdown-input::placeholder{color:#94a3b8}.markdown-stats{display:flex;gap:16px;font-size:12px;color:#64748b;padding:8px 0}.markdown-stats span{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#f1f5f9;border-radius:6px}.notes-input-container{display:flex;flex-direction:column;gap:8px}.notes-input-container label{font-size:13px;font-weight:600;color:#334155;text-transform:uppercase;letter-spacing:.03em}.notes-input-container input{padding:12px 16px;border:1px solid #e2e8f0;border-radius:10px;font-size:14px;background:#f8fafc;color:#1e293b;transition:all .2s ease}.notes-input-container input:focus{outline:none;border-color:#0ea5e9;background:#fff;box-shadow:0 0 0 3px #0ea5e91a}.notes-input-container input::-moz-placeholder{color:#94a3b8}.notes-input-container input::placeholder{color:#94a3b8}.import-version-status{display:flex;align-items:center;gap:10px;padding:14px 24px;font-size:13px;font-weight:500}.import-version-status.success{background:linear-gradient(90deg,#ecfdf5,#d1fae5);color:#065f46}.import-version-status.error{background:linear-gradient(90deg,#fef2f2,#fee2e2);color:#991b1b}.import-version-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e2e8f0;background:#f8fafc}.import-version-footer .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.import-version-footer .btn-secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.import-version-footer .btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.import-version-footer .btn-primary{background:linear-gradient(135deg,#0ea5e9,#0284c7);border:none;color:#fff;box-shadow:0 2px 4px #0ea5e94d}.import-version-footer .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#0284c7,#0369a1);box-shadow:0 4px 8px #0ea5e966}.import-version-footer .btn-primary:disabled{opacity:.5;cursor:not-allowed}@keyframes spin{to{transform:rotate(360deg)}}.spinning{animation:spin 1s linear infinite}@media(max-width:640px){.import-version-container{width:100%;max-width:none;max-height:100vh;border-radius:0}.import-version-header{padding:14px 16px}.import-version-tabs{padding:0 16px}.import-version-tabs .tab{padding:12px 14px;font-size:13px}.import-version-content{padding:16px}.import-version-footer{padding:14px 16px}.upload-zone{padding:32px 20px}}.version-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.version-modal{background:#fff;border-radius:12px;width:90%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.version-modal-header{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f8fafc;border-radius:12px 12px 0 0;flex-wrap:wrap;gap:8px}.version-modal-title{display:flex;align-items:center;gap:10px;color:#1e293b}.version-modal-title h2{font-size:1.1rem;font-weight:600;margin:0}.version-modal-subtitle{flex:1;color:#64748b;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.version-modal-close{padding:6px;border:none;background:transparent;color:#64748b;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}.version-modal-close:hover{background:#e2e8f0;color:#334155}.version-error{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#fef2f2;border-bottom:1px solid #fecaca;color:#dc2626;font-size:.85rem}.version-modal-content{flex:1;overflow-y:auto;padding:20px}.version-loading,.version-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#64748b;gap:12px}.version-loading .spinning,.version-btn .spinning{animation:spin 1s linear infinite}.version-empty svg{opacity:.3}.version-list{display:flex;flex-direction:column;gap:16px}.version-card{border:1px solid #e5e7eb;border-radius:10px;padding:16px;background:#fff;transition:all .15s}.version-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000f}.version-card.is-active{border-color:#22c55e;background:linear-gradient(to bottom right,#f0fdf4,#fff)}.version-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.version-number{display:flex;align-items:center;gap:8px}.version-label{font-size:1.1rem;font-weight:700;color:#1e293b}.version-name{font-size:.85rem;color:#64748b;font-weight:400}.version-status{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.version-status.active{background:#dcfce7;color:#16a34a}.version-status.published{background:#dbeafe;color:#2563eb}.version-status.draft{background:#fef3c7;color:#d97706}.version-status.review{background:#e0e7ff;color:#4f46e5}.version-status.archived{background:#f1f5f9;color:#64748b}.version-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px;margin-bottom:12px}.version-stat{display:flex;align-items:center;gap:6px;font-size:.8rem;color:#64748b}.version-stat.full-width{grid-column:1 / -1}.version-stat svg{flex-shrink:0;opacity:.6}.version-stat .truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.version-notes{padding:10px 12px;background:#f8fafc;border-radius:6px;font-size:.8rem;color:#475569;margin-bottom:12px;border-left:3px solid #e2e8f0}.version-actions{display:flex;align-items:center;gap:10px;padding-top:12px;border-top:1px solid #f1f5f9}.version-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:none;border-radius:6px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.version-btn:disabled{opacity:.6;cursor:not-allowed}.version-btn.activate{background:#2563eb;color:#fff}.version-btn.activate:hover:not(:disabled){background:#1d4ed8}.version-btn.delete{background:#fff;color:#dc2626;border:1px solid #fecaca}.version-btn.delete:hover:not(:disabled){background:#fef2f2;border-color:#dc2626}.version-btn.secondary{background:#f1f5f9;color:#475569}.version-btn.secondary:hover:not(:disabled){background:#e2e8f0}.version-active-label{display:flex;align-items:center;gap:6px;color:#16a34a;font-size:.8rem;font-weight:500}.version-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid #e5e7eb;background:#f8fafc;border-radius:0 0 12px 12px}@media(max-width:600px){.version-modal{width:95%;max-height:90vh}.version-stats{grid-template-columns:1fr}.version-actions{flex-direction:column;align-items:stretch}.version-btn{justify-content:center}}.search-box{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#64748b}.search-box input{border:none;outline:none;font-size:.875rem;width:160px}.grid-header{display:grid;grid-template-columns:2fr 1fr .6fr .8fr 1fr 1fr .8fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grid-row{display:grid;grid-template-columns:2fr 1fr .6fr .8fr 1fr 1fr .8fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.status-badge{display:inline-block;padding:3px 8px;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:capitalize}.status-badge.default{background:#f1f5f9;color:#64748b}.detail-actions{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid #e2e8f0}.markdown-editor-page{display:flex;flex-direction:column;height:calc(100vh - 60px);background:#f8fafc;margin:-1.5rem;width:calc(100% + 3rem)}.markdown-editor-page .editor-page-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#1e293b;color:#fff;border-bottom:1px solid #334155;flex-shrink:0}.markdown-editor-page .editor-page-header .header-left{display:flex;align-items:center;gap:12px}.markdown-editor-page .editor-page-header h1{font-size:1.1rem;font-weight:600;margin:0}.markdown-editor-page .editor-page-header .module-title{color:#94a3b8;font-size:.95rem;margin-left:8px;padding-left:12px;border-left:1px solid #475569}.markdown-editor-page .back-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:#ffffff1a;color:#fff;border-radius:8px;cursor:pointer;transition:all .15s}.markdown-editor-page .back-btn:hover{background:#fff3}.markdown-editor-page .header-actions{display:flex;gap:8px}.markdown-editor-page .header-actions .btn-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;color:#94a3b8;border-radius:8px;cursor:pointer;transition:all .15s}.markdown-editor-page .header-actions .btn-icon:hover{background:#ffffff1a;color:#fff}.markdown-editor-page .editor-page-toolbar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#fff;border-bottom:1px solid #e2e8f0;gap:12px;flex-shrink:0;flex-wrap:nowrap;overflow-x:auto}.markdown-editor-page .editor-page-toolbar .toolbar-left,.markdown-editor-page .editor-page-toolbar .toolbar-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.markdown-editor-page .editor-toolbar-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid #e2e8f0;background:#fff;color:#475569;font-size:.8rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}.markdown-editor-page .editor-toolbar-btn svg{width:16px;height:16px;flex-shrink:0}.markdown-editor-page .editor-toolbar-btn:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.markdown-editor-page .editor-toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.markdown-editor-page .editor-toolbar-btn.accent{background:#7c3aed;color:#fff;border-color:#7c3aed}.markdown-editor-page .editor-toolbar-btn.accent:hover:not(:disabled){background:#6d28d9}.markdown-editor-page .editor-toolbar-btn.primary{background:#22c55e;color:#fff;border-color:#22c55e}.markdown-editor-page .editor-toolbar-btn.primary:hover:not(:disabled){background:#16a34a}.markdown-editor-page .toolbar-separator{width:1px;height:24px;background:#e2e8f0;margin:0 4px;flex-shrink:0}.markdown-editor-page .mode-selector{display:flex;align-items:center;gap:8px;flex-shrink:0}.markdown-editor-page .mode-selector label{font-size:.8rem;color:#64748b;white-space:nowrap}.markdown-editor-page .mode-selector select{padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.8rem;color:#334155;background:#fff}.markdown-editor-page .editor-page-status{display:flex;align-items:center;gap:8px;padding:10px 20px;font-size:.85rem;flex-shrink:0}.markdown-editor-page .editor-page-status.success{background:#f0fdf4;color:#16a34a;border-bottom:1px solid #bbf7d0}.markdown-editor-page .editor-page-status.error{background:#fef2f2;color:#dc2626;border-bottom:1px solid #fecaca}.markdown-editor-page .editor-page-validation{padding:10px 20px;background:#f8fafc;border-bottom:1px solid #e2e8f0;flex-shrink:0}.markdown-editor-page .validation-summary{display:flex;align-items:center;gap:16px;font-size:.8rem;color:#64748b}.markdown-editor-page .validation-summary .valid{color:#16a34a;font-weight:600}.markdown-editor-page .validation-summary .invalid{color:#dc2626;font-weight:600}.markdown-editor-page .validation-summary .warning{color:#d97706;font-weight:500}.markdown-editor-page .validation-warnings{margin-top:8px;padding:8px 12px;background:#fef3c7;border-radius:6px;font-size:.75rem}.markdown-editor-page .warning-item{color:#92400e;padding:2px 0}.markdown-editor-page .warning-more{color:#78350f;font-style:italic;margin-top:4px}.markdown-editor-page .editor-page-content{flex:1;display:flex;overflow:hidden;min-height:0}.markdown-editor-page .llm-guide-panel{width:320px;background:#1e293b;color:#e2e8f0;padding:16px;overflow-y:auto;border-right:1px solid #334155;flex-shrink:0}.markdown-editor-page .llm-guide-panel h3{font-size:.95rem;margin:0 0 16px;color:#fff}.markdown-editor-page .llm-guide-panel h4{font-size:.8rem;margin:16px 0 8px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}.markdown-editor-page .llm-guide-panel pre{background:#0f172a;padding:10px;border-radius:6px;font-size:.7rem;overflow-x:auto;white-space:pre;font-family:JetBrains Mono,Fira Code,monospace}.markdown-editor-page .llm-guide-panel p{font-size:.8rem;margin:6px 0;color:#94a3b8}.markdown-editor-page .llm-guide-panel ul{margin:8px 0;padding-left:20px}.markdown-editor-page .llm-guide-panel li{font-size:.8rem;color:#94a3b8;margin:4px 0}.markdown-editor-page .editor-container{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.markdown-editor-page .editor-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#64748b;gap:12px}.markdown-editor-page .markdown-textarea{flex:1;width:100%;padding:20px;border:none;resize:none;font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.85rem;line-height:1.6;color:#1e293b;background:#fff}.markdown-editor-page .markdown-textarea:focus{outline:none}.markdown-editor-page .markdown-textarea::-moz-placeholder{color:#94a3b8}.markdown-editor-page .markdown-textarea::placeholder{color:#94a3b8}.markdown-editor-page .editor-page-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:#f1f5f9;border-top:1px solid #e2e8f0;font-size:.75rem;color:#64748b;flex-shrink:0}.markdown-editor-page .footer-stats{display:flex;gap:16px}.markdown-editor-page .footer-stats .unsaved{color:#d97706;font-weight:500}.markdown-editor-page .footer-meta{color:#94a3b8}.markdown-editor-page .spinning{animation:spin 1s linear infinite}@media(max-width:900px){.markdown-editor-page .editor-page-toolbar,.markdown-editor-page .editor-page-toolbar .toolbar-left,.markdown-editor-page .editor-page-toolbar .toolbar-right{flex-wrap:wrap}.markdown-editor-page .llm-guide-panel{display:none}}@media(max-width:600px){.markdown-editor-page .editor-page-footer{flex-direction:column;gap:4px;align-items:flex-start}}.categories-page h1{display:flex;align-items:center;gap:12px}.tree-container{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden;min-height:400px}.tree-loading,.tree-empty{padding:48px;text-align:center;color:#64748b}.tree-empty p{margin-bottom:16px;font-size:1rem}.tree-root{padding:8px 0}.tree-node{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;cursor:pointer;transition:all .15s;border-left:3px solid transparent}.node-left{display:flex;align-items:center;gap:8px}.node-right{display:flex;gap:4px;opacity:0;transition:opacity .15s}.tree-node:hover .node-right{opacity:1}.expand-btn{background:none;border:none;padding:2px;cursor:pointer;color:#64748b;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s}.expand-btn:hover{background:#e2e8f0;color:#334155}.expand-spacer{width:20px}.color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.node-name{font-size:.9rem;font-weight:500;color:#1e293b}.child-count{font-size:.75rem;background:#e2e8f0;color:#64748b;padding:2px 6px;border-radius:10px;font-weight:500}.btn-icon-sm{background:none;border:none;padding:4px;cursor:pointer;color:#94a3b8;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .15s}.btn-icon-sm:hover{background:#e2e8f0;color:#3b82f6}.color-picker{display:flex;align-items:center;gap:12px}.color-picker input[type=color]{width:40px;height:32px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;padding:2px}.color-picker span{font-family:monospace;color:#64748b}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;font-size:.875rem;color:#374151}.form-group input[type=text],.form-group select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.9rem}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:#dcfce7;color:#15803d}.status-badge.inactive{background:#f1f5f9;color:#64748b}.color-swatch{display:inline-block;width:24px;height:24px;border-radius:6px;border:1px solid rgba(0,0,0,.1)}.detail-panel{position:fixed;top:0;right:-450px;width:420px;height:100vh;background:#fff;box-shadow:-4px 0 20px #0000001a;z-index:1000;transition:right .3s ease;display:flex;flex-direction:column}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.detail-header h3{margin:0;font-size:1.1rem;font-weight:600}.detail-content{flex:1;overflow-y:auto;padding:24px}.detail-row{display:flex;flex-direction:column;margin-bottom:16px}.detail-row label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;margin-bottom:4px;letter-spacing:.5px}.detail-row span,.detail-row code{font-size:.9rem;color:#1e293b}.detail-row code{font-family:monospace;background:#f1f5f9;padding:4px 8px;border-radius:4px}.detail-actions{display:flex;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #e2e8f0}.btn-primary,.btn-secondary,.btn-danger{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;font-size:.875rem;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .15s}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#f1f5f9;color:#374151}.btn-danger{background:#fef2f2;color:#dc2626}.btn-danger:hover{background:#fee2e2}.btn-icon{background:transparent;border:none;padding:8px;cursor:pointer;color:#64748b;border-radius:8px;transition:all .15s}.btn-icon:hover{background:#f1f5f9;color:#334155}.admin-page{min-height:100%}.page-header h1{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0 0 4px}.page-subtitle{font-size:.9rem;color:#64748b;margin:0}.header-actions{display:flex;gap:12px}.admin-page{padding:24px;position:relative}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.page-header h1{font-size:1.5rem;font-weight:600;color:#1e293b;margin:0}.page-subtitle{color:#64748b;font-size:.875rem;margin-top:4px}.header-actions{display:flex;gap:12px;align-items:center}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#0078d4;color:#fff;border:none;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer}.btn-primary:hover{background:#005a9e}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#f1f5f9;color:#334155;border:1px solid #e2e8f0;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer}.btn-secondary:hover{background:#e2e8f0}.btn-icon{display:inline-flex;align-items:center;justify-content:center;padding:6px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#64748b;transition:all .15s ease}.btn-icon:hover{background:#f1f5f9;color:#0078d4}.btn-icon.danger:hover{color:#dc2626;background:#fee2e2}.grid-container{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.compact-grid{width:100%}.grid-header{display:grid;grid-template-columns:2fr .8fr 1fr .6fr 1fr 1.2fr .8fr;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grid-header .grid-col{padding:12px}.grid-col.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-col.sortable:hover,.grid-col.sorted{color:#0078d4}.grid-row{display:grid;grid-template-columns:2fr .8fr 1fr .6fr 1fr 1.2fr .8fr;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:background .1s ease}.grid-row:last-child{border-bottom:none}.grid-row:hover{background:#f8fafc}.grid-row.selected{background:#eff6ff}.grid-row .grid-col{padding:10px 12px;font-size:.8125rem;color:#334155;display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grid-row .grid-col code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.7rem}.name-col{font-weight:500}.row-icon{color:#64748b;flex-shrink:0}.grid-loading,.grid-empty{padding:48px;text-align:center;color:#64748b}.grid-col.actions{justify-content:flex-end;gap:4px}.type-badge{display:inline-block;padding:3px 8px;background:#f1f5f9;color:#334155;border-radius:4px;font-size:.7rem;font-weight:600}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:12px;font-size:.7rem;font-weight:500;text-transform:capitalize}.status-badge.success{background:#dcfce7;color:#166534}.status-badge.info{background:#dbeafe;color:#1d4ed8}.status-badge.warning{background:#fef3c7;color:#b45309}.status-badge.danger{background:#fee2e2;color:#dc2626}.status-icon.success{color:#16a34a}.status-icon.processing{color:#2563eb;animation:spin 1s linear infinite}.status-icon.pending{color:#d97706}.status-icon.error{color:#dc2626}.detail-overlay{position:fixed;inset:0;background:#0f172a66;z-index:999}.detail-panel{position:fixed;top:0;right:-420px;width:420px;height:100vh;background:#fff;box-shadow:-4px 0 24px #0000001f;z-index:1000;transition:right .25s ease;display:flex;flex-direction:column}.detail-panel.open{right:0}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.detail-header h3{margin:0;font-size:1.125rem;font-weight:600;color:#1e293b}.detail-content{flex:1;padding:24px;overflow-y:auto}.detail-row{display:flex;flex-direction:column;gap:4px;margin-bottom:20px}.detail-row label{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.detail-row span,.detail-row code{font-size:.875rem;color:#1e293b}.detail-row code{background:#f1f5f9;padding:6px 10px;border-radius:6px;font-family:monospace;font-size:.8rem}.detail-row.error .error-text{color:#dc2626;background:#fee2e2;padding:8px 12px;border-radius:6px}.progress-bar{width:100%;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;margin-bottom:4px}.progress-fill{height:100%;background:linear-gradient(90deg,#0078d4,#00a86b);border-radius:3px;transition:width .3s ease}.dest-sidebar-overlay{position:fixed;inset:0;background:#0006;z-index:10000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:opacity .3s}.dest-sidebar{position:fixed;top:0;bottom:0;right:-420px;width:400px;background:#fff;z-index:10001;box-shadow:-4px 0 15px #0000001a;display:flex;flex-direction:column;transition:right .3s cubic-bezier(.16,1,.3,1)}.dest-sidebar.open{right:0}.dest-header{padding:16px 20px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center}.dest-header h3{margin:0;font-size:1.1rem;color:#0f172a;font-weight:600}.dest-close{border:none;background:none;cursor:pointer;color:#64748b;padding:4px;margin:-4px;border-radius:4px}.dest-close:hover{background:#f1f5f9;color:#0f172a}.dest-tabs{display:flex;border-bottom:1px solid #e2e8f0;padding:0 16px;gap:16px;margin-top:8px}.dest-tab{background:none;border:none;padding:10px 4px;font-size:.9rem;font-weight:500;color:#64748b;cursor:pointer;border-bottom:2px solid transparent;display:flex;align-items:center;gap:6px}.dest-tab:hover{color:#334155}.dest-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.dest-content{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column}.dest-section{display:flex;flex-direction:column;flex:1}.dest-section.full-height{height:100%}.dest-section label{font-size:.85rem;font-weight:600;color:#475569;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.dest-search-box{position:relative;display:flex;align-items:center;margin-bottom:12px}.dest-search-box input{width:100%;padding:8px 12px 8px 34px;border:1px solid #e2e8f0;border-radius:6px;font-size:.9rem;background:#f8fafc}.dest-search-box input:focus{border-color:#3b82f6;background:#fff;outline:none}.dest-search-box .search-icon{position:absolute;left:10px;color:#94a3b8}.dest-search-box .clear-btn{position:absolute;right:10px;background:none;border:none;color:#94a3b8;cursor:pointer;font-size:18px;line-height:1}.dest-list{border:1px solid #e2e8f0;border-radius:6px;overflow-y:auto;max-height:400px}.dest-list-item{padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;border-bottom:1px solid #f1f5f9;font-size:.9rem;color:#334155;transition:background .1s}.dest-list-item:hover{background:#f8fafc}.dest-list-item.selected{background:#eef2ff;color:#4f46e5;font-weight:500}.dest-list-item:last-child{border-bottom:none}.dest-list-item .item-icon{color:#94a3b8}.dest-list-item.selected .item-icon{color:#4f46e5}.dest-list-item .check-icon{margin-left:auto;color:#4f46e5}.dest-input{width:100%;padding:10px;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:8px;font-size:.9rem}.dest-input:focus{border-color:#3b82f6;outline:none}.dest-tree{flex:1;overflow-y:auto;border:1px solid #e2e8f0;border-radius:6px;padding:8px 0;min-height:200px}.dest-tree-node{-webkit-user-select:none;-moz-user-select:none;user-select:none}.dest-node-content{display:flex;align-items:center;padding:6px 12px;cursor:pointer;font-size:.9rem;color:#334155}.dest-node-content:hover{background:#f8fafc}.dest-node-content.selected{background:#eef2ff;color:#4f46e5;font-weight:500}.dest-expand-btn{background:none;border:none;padding:2px;margin-right:4px;cursor:pointer;color:#94a3b8;display:flex}.dest-spacer{width:20px}.dest-icon{margin-right:8px;color:#3b82f6}.dest-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dest-check{margin-left:8px;color:#4f46e5}.dest-footer{padding:16px 20px;border-top:1px solid #e2e8f0;background:#f8fafc;display:flex;flex-direction:column;gap:12px}.dest-summary{font-size:.85rem;color:#64748b}.dest-summary strong{color:#334155;font-weight:600}.dest-btn-primary{width:100%;padding:10px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.dest-btn-primary:hover{background:#2563eb}.dest-empty,.dest-loading{padding:20px;text-align:center;color:#94a3b8;font-size:.9rem}.content-import-page{display:flex;flex-direction:column;height:100%;background:#f1f5f9}.import-header{display:flex;justify-content:space-between;align-items:center;padding:6px 14px;background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0}.header-left{display:flex;align-items:center;gap:8px}.header-icon{color:#3b82f6;width:16px;height:16px}.import-header h1{font-size:.88rem;font-weight:600;color:#0f172a;margin:0}.section-badge{font-size:.62rem;color:#059669;background:#d1fae5;padding:2px 8px;border-radius:10px;font-weight:500}.header-actions{display:flex;align-items:center;gap:6px}.ai-model-select{padding:4px 8px;border:1px solid #e2e8f0;border-radius:4px;font-size:.68rem;background:#fff}.btn-sm{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:.68rem;font-weight:500;border:none;border-radius:4px;cursor:pointer;transition:all .15s}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8)}.btn-primary:disabled{background:#94a3b8;cursor:not-allowed}.btn-ghost{background:transparent;color:#64748b;border:1px solid #e2e8f0}.btn-ghost:hover{background:#f1f5f9}.spin{animation:spin 1s linear infinite}.toast{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:.78rem;margin:8px 20px 0;border-radius:6px;flex-shrink:0}.toast.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.toast button{margin-left:auto;background:none;border:none;font-size:1.1rem;cursor:pointer;color:inherit;opacity:.6}.toast button:hover{opacity:1}.input-panel{flex:1;display:flex;flex-direction:column;padding:16px 20px;gap:12px}.input-toolbar{display:flex;align-items:center;gap:12px}.upload-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px dashed #cbd5e1;border-radius:6px;font-size:.8rem;color:#475569;cursor:pointer;transition:all .15s}.upload-btn:hover{border-color:#3b82f6;color:#3b82f6}.model-dropdown{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.78rem;background:#fff}.char-count{font-size:.72rem;color:#94a3b8;margin-left:auto}.markdown-editor{flex:1;padding:14px;border:1px solid #d1d5db;border-radius:8px;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.85rem;line-height:1.6;resize:none;background:#fff}.markdown-editor:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.split-layout{flex:1;display:flex;overflow:hidden}.tree-sidebar{width:320px;display:flex;flex-direction:column;background:#fff;border-right:1px solid #e2e8f0;flex-shrink:0}.tree-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #e2e8f0;font-size:.85rem;font-weight:600;color:#334155}.tree-stats{font-size:.72rem;font-weight:400;color:#64748b;background:#f1f5f9;padding:2px 8px;border-radius:4px}.tree-container{flex:1;overflow-y:auto;padding:8px 0}.tree-node-wrapper{-webkit-user-select:none;-moz-user-select:none;user-select:none}.tree-node{display:flex;align-items:center;gap:6px;padding:6px 10px;font-size:.78rem;color:#334155;cursor:pointer;border-left:3px solid transparent;transition:all .1s}.tree-node:hover{background:#f8fafc}.tree-node.selected{background:#eff6ff;border-left-color:#3b82f6}.tree-node.excluded{opacity:.35}.tree-node.excluded .tree-label{text-decoration:line-through}.tree-expand{display:flex;align-items:center;justify-content:center;width:18px;height:18px;color:#94a3b8;flex-shrink:0}.expand-spacer{width:14px}.tree-node input[type=checkbox]{width:14px;height:14px;accent-color:#3b82f6;cursor:pointer;flex-shrink:0}.tree-icon{display:flex;align-items:center;flex-shrink:0}.tree-icon.folder{color:#f59e0b}.tree-icon.file{color:#64748b}.tree-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.tree-type{font-size:.6rem;padding:2px 6px;border-radius:3px;text-transform:uppercase;font-weight:600;flex-shrink:0;background:#f1f5f9;color:#64748b}.tree-type.type-overview{background:#dbeafe;color:#1d4ed8}.tree-type.type-concepts{background:#fae8ff;color:#a21caf}.tree-type.type-walkthrough{background:#d1fae5;color:#059669}.tree-type.type-example{background:#fef3c7;color:#b45309}.tree-type.type-configuration{background:#e0e7ff;color:#4338ca}.tree-type.type-diagram{background:#f3e8ff;color:#7c3aed}.tree-type.type-quiz{background:#ffe4e6;color:#e11d48}.tree-children{margin-left:4px;border-left:1px dashed #e2e8f0}.module-selector{padding:14px 16px;border-top:1px solid #e2e8f0;background:#fafbfc}.module-label{font-size:.72rem;font-weight:600;color:#475569;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.module-tabs{display:flex;margin-bottom:10px;border-radius:6px;overflow:hidden;border:1px solid #d1d5db}.module-tabs .tab{flex:1;padding:6px 12px;font-size:.72rem;font-weight:500;background:#fff;border:none;cursor:pointer;transition:all .15s}.module-tabs .tab:first-child{border-right:1px solid #d1d5db}.module-tabs .tab.active{background:#3b82f6;color:#fff}.module-tabs .tab:not(.active):hover{background:#f1f5f9}.module-input,.module-selector .module-dropdown{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.78rem}.module-input:focus,.module-dropdown:focus{outline:none;border-color:#3b82f6}.editor-panel{flex:1;display:flex;flex-direction:column;background:#fff;overflow:hidden}.compact-toolbar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;flex-shrink:0}.title-input{flex:1;min-width:150px;max-width:300px;padding:4px 8px;border:1px solid #e2e8f0;border-radius:4px;font-size:.82rem;font-weight:600;color:#0f172a;background:#fff}.title-input:focus{outline:none;border-color:#3b82f6}.level-tag{font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:3px;background:#e2e8f0;color:#475569}.type-select{padding:3px 6px;border:1px solid #e2e8f0;border-radius:4px;font-size:.7rem;background:#fff}.toolbar-sep{width:1px;height:18px;background:#e2e8f0;margin:0 2px}.tool-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:#fff;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;color:#64748b;transition:all .1s}.tool-btn:hover:not(:disabled){background:#f1f5f9;color:#3b82f6;border-color:#3b82f6}.tool-btn.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.tool-btn:disabled{opacity:.4;cursor:not-allowed}.nav-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#fff;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;color:#475569}.nav-btn:hover:not(:disabled){background:#f1f5f9;color:#3b82f6}.nav-btn:disabled{opacity:.35;cursor:not-allowed}.nav-pos{font-size:.65rem;color:#64748b;font-weight:500;min-width:36px;text-align:center}.save-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:#e2e8f0;border:none;border-radius:4px;color:#94a3b8;cursor:not-allowed;margin-left:auto}.save-btn.unsaved{background:#10b981;color:#fff;cursor:pointer}.save-btn.unsaved:hover{background:#059669}.content-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.content-editor{flex:1;padding:20px;border:none;font-family:SF Mono,Menlo,Consolas,monospace;font-size:.85rem;line-height:1.7;resize:none;background:#fff}.content-editor:focus{outline:none}.content-preview{flex:1;padding:20px;overflow-y:auto;font-size:.9rem;line-height:1.7;color:#334155}.content-preview h1{font-size:1.4rem;margin:0 0 12px;color:#0f172a}.content-preview h2{font-size:1.2rem;margin:20px 0 10px;color:#1e293b}.content-preview h3{font-size:1.05rem;margin:16px 0 8px;color:#334155}.content-preview p{margin:0 0 12px}.content-preview strong{font-weight:600}.content-preview code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-size:.85em}.content-preview li{margin-left:20px;margin-bottom:4px}.content-preview .placeholder{color:#94a3b8;font-style:italic}.no-selection{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;gap:12px}.no-selection p{font-size:.9rem}.complete-panel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.complete-panel h2{font-size:1.4rem;color:#0f172a;margin:0}.complete-panel p{color:#64748b;margin:0}.complete-actions{display:flex;gap:12px;margin-top:12px}.section-nav{display:flex;align-items:center;gap:4px;margin-left:8px;padding-left:8px;border-left:1px solid #e2e8f0}.nav-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#fff;border:1px solid #e2e8f0;border-radius:5px;cursor:pointer;color:#475569;transition:all .15s}.nav-btn:hover:not(:disabled){background:#f1f5f9;border-color:#3b82f6;color:#3b82f6}.nav-btn:disabled{opacity:.4;cursor:not-allowed}.nav-counter{font-size:.7rem;color:#64748b;font-weight:500;min-width:50px;text-align:center}.content-preview .ascii-diagram{background:#1e293b;color:#e2e8f0;padding:16px 20px;border-radius:8px;font-family:SF Mono,Menlo,Consolas,Courier New,monospace;font-size:.78rem;line-height:1.4;overflow-x:auto;white-space:pre;margin:12px 0;border:1px solid #334155}.content-preview .code-block{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;padding:12px;margin:10px 0;overflow-x:auto}.content-preview .code-block code{background:transparent;padding:0;color:#0f172a;font-size:.8rem}.md-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:.85rem}.md-table th,.md-table td{padding:8px 12px;border:1px solid #e2e8f0;text-align:left}.md-table th{background:#f8fafc;font-weight:600;color:#334155}.md-table tr:nth-child(2n){background:#fcfcfc}.md-table tr:hover{background:#f1f5f9}.markdown-body{font-size:.9rem;line-height:1.7}.combobox-wrapper{position:relative;width:100%}.combobox-input-wrapper{position:relative;display:flex;align-items:center}.combobox-icon{position:absolute;left:10px;color:#64748b;z-index:10;pointer-events:none}.module-input.search{padding-left:36px;padding-right:32px}.clear-search{position:absolute;right:10px;background:none;border:none;color:#94a3b8;font-size:18px;cursor:pointer;padding:0;line-height:1;display:flex;align-items:center;justify-content:center}.clear-search:hover{color:#ef4444}.combobox-dropdown{position:absolute;inset:auto 0 100%;max-height:250px;overflow-y:auto;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 -4px 12px #00000026;z-index:1000;margin-bottom:6px}.combobox-option{padding:10px 14px;font-size:.9rem;color:#334155;cursor:pointer;border-bottom:1px solid #f1f5f9;transition:background .1s}.combobox-option:last-child{border-bottom:none}.combobox-option:hover{background:#f8fafc}.combobox-option.selected{background:#eef2ff;color:#4f46e5;font-weight:600}.combobox-option.no-results{padding:16px;color:#94a3b8;text-align:center;font-size:.85rem;cursor:default;background:#f8fafc}.new-module-stack{display:flex;flex-direction:column;gap:8px;width:100%}.category-select-btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#fff;border:1px dashed #cbd5e1;border-radius:6px;cursor:pointer;font-size:.85rem;color:#64748b;transition:all .2s;text-align:left}.category-select-btn:hover{border-color:#3b82f6;background:#f8fafc;color:#334155;text-decoration:none}.cat-placeholder{color:#94a3b8;font-style:italic}.cat-selected-val{display:flex;align-items:center;gap:8px;color:#334155;font-weight:500;overflow:hidden;flex:1}.cat-name-trunc{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-chevron{color:#cbd5e1;flex-shrink:0;margin-left:8px}.category-select-btn:hover .cat-chevron{color:#94a3b8}.dest-trigger-btn{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #cbd5e1;padding:0 12px;border-radius:6px;font-size:.85rem;color:#475569;cursor:pointer;transition:all .2s;height:32px;margin-right:8px;max-width:280px}.dest-trigger-btn:hover{border-color:#3b82f6;background:#f1f5f9;color:#0f172a;box-shadow:0 1px 2px #0000000d}.dest-trigger-lbl{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px;font-weight:500}.dest-cat-dot{width:6px;height:6px;border-radius:50%;margin-left:2px;flex-shrink:0;box-shadow:0 0 0 1px #0000001a}.icon-blue{color:#3b82f6}.prompts-page{padding:20px;max-width:1000px}.ai-services-page{max-width:1200px}.info-banner{display:flex;align-items:flex-start;gap:12px;padding:16px 20px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:10px;margin-bottom:24px;color:#1e40af;font-size:.875rem;line-height:1.5}.info-banner svg{flex-shrink:0;margin-top:2px}.success-banner{display:flex;align-items:center;gap:12px;padding:14px 20px;background:#d1fae5;border:1px solid #6ee7b7;border-radius:10px;margin-bottom:20px;color:#065f46;font-size:.875rem;font-weight:500}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:#6b7280}.loading-state .spin{animation:spin 1s linear infinite;margin-bottom:16px;color:#4f46e5}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.services-container{display:flex;flex-direction:column;gap:24px}.service-category{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.category-header{display:flex;align-items:center;width:100%;padding:16px 20px;background:#f9fafb;border:none;border-bottom:1px solid #e5e7eb;cursor:pointer;transition:background .2s}.category-header:hover{background:#f3f4f6}.category-header h2{font-size:1rem;font-weight:600;color:#1f2937;margin:0;flex:1;text-align:left}.category-count{font-size:.75rem;color:#6b7280;background:#e5e7eb;padding:4px 10px;border-radius:12px;margin-right:12px}.category-header svg{color:#6b7280}.service-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;padding:20px}.service-card{display:flex;flex-direction:column;padding:24px;background:#fafbfc;border:1px solid #e5e7eb;border-radius:12px;transition:border-color .2s,box-shadow .2s;min-height:220px}.service-card:hover{border-color:#c7d2fe;box-shadow:0 4px 12px #4f46e51a}.service-header{display:flex;align-items:center;gap:14px;margin-bottom:12px}.service-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f46e5,#6366f1);border-radius:12px;color:#fff;flex-shrink:0}.service-title{font-size:1rem;font-weight:600;color:#1f2937;margin:0}.service-description{font-size:.875rem;color:#6b7280;line-height:1.6;margin:0 0 auto;padding-bottom:16px}.service-config{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:auto;padding-top:16px;border-top:1px solid #f0f0f0}.service-config label{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.service-config select{width:100%;padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:.875rem;color:#374151;background:#fff;cursor:pointer;transition:border-color .2s,box-shadow .2s}.service-config select:hover{border-color:#9ca3af}.service-config select:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.current-model{font-size:.75rem;color:#059669;font-weight:500}.error-banner{display:flex;align-items:center;gap:10px;padding:14px 20px;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;margin-bottom:20px;color:#dc2626;font-size:.875rem}@media(max-width:768px){.service-cards{grid-template-columns:1fr}.page-header{flex-direction:column;gap:16px}.header-actions{width:100%;justify-content:flex-end}}.ai-services-page .page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.ai-services-page .page-header h1{font-size:1.5rem;font-weight:600;color:#1e293b;margin:0}.ai-services-page .page-subtitle{color:#64748b;font-size:.875rem;margin-top:4px}.ai-services-page .header-actions{display:flex;gap:12px}.ai-services-page .btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#4f46e5;color:#fff;border:none;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:background .2s}.ai-services-page .btn-primary:hover{background:#4338ca}.ai-services-page .btn-primary:disabled{opacity:.6;cursor:not-allowed}.ai-services-page .btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:background .2s,border-color .2s}.ai-services-page .btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.ai-services-page .btn-secondary:disabled{opacity:.6;cursor:not-allowed}
