*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.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}}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.\!visible{visibility:visible!important}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:-webkit-sticky;position:sticky}.inset-0{inset:0}.-bottom-1{bottom:-.25rem}.bottom-1{bottom:.25rem}.bottom-4{bottom:1rem}.bottom-full{bottom:100%}.left-0{left:0}.right-0{right:0}.right-2{right:.5rem}.right-4{right:1rem}.top-0{top:0}.top-2{top:.5rem}.top-4{top:1rem}.z-10{z-index:10}.z-50{z-index:50}.z-\[100\]{z-index:100}.col-span-2{grid-column:span 2/span 2}.m-1{margin:.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-8{margin-bottom:2rem;margin-top:2rem}.-mb-0\.5{margin-bottom:-.125rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-11{margin-left:2.75rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.aspect-square{aspect-ratio:1/1}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-full{height:100%}.max-h-40{max-height:10rem}.max-h-60{max-height:15rem}.max-h-64{max-height:16rem}.max-h-\[60vh\]{max-height:60vh}.max-h-\[90vh\]{max-height:90vh}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-20{width:5rem}.w-24{width:6rem}.w-28{width:7rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-8{width:2rem}.w-auto{width:auto}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[100px\]{max-width:100px}.max-w-md{max-width:28rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1}.flex-shrink-0{flex-shrink:0}.origin-top-right{transform-origin:top right}.rotate-180{--tw-rotate:180deg}.rotate-180,.scale-105{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.resize-none{resize:none}.resize{resize:both}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.75rem*var(--tw-space-x-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(2rem*var(--tw-space-y-reverse));margin-top:calc(2rem*(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-r-lg{border-bottom-right-radius:.5rem;border-top-right-radius:.5rem}.rounded-t-2xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-t-2{border-top-width:2px}.border-none{border-style:none}.border-blue-200{--tw-border-opacity:1;border-color:#bfdbfe;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-blue-300{--tw-border-opacity:1;border-color:#93c5fd;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.border-blue-400{--tw-border-opacity:1;border-color:#60a5fa;border-color:rgb(96 165 250/var(--tw-border-opacity,1))}.border-blue-500{--tw-border-opacity:1;border-color:#3b82f6;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-blue-600{--tw-border-opacity:1;border-color:#2563eb;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-current{border-color:currentColor}.border-gray-100{--tw-border-opacity:1;border-color:#f3f4f6;border-color:rgb(243 244 246/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:#e5e7eb;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-gray-300{--tw-border-opacity:1;border-color:#d1d5db;border-color:rgb(209 213 219/var(--tw-border-opacity,1))}.border-gray-500{--tw-border-opacity:1;border-color:#6b7280;border-color:rgb(107 114 128/var(--tw-border-opacity,1))}.border-gray-700{--tw-border-opacity:1;border-color:#374151;border-color:rgb(55 65 81/var(--tw-border-opacity,1))}.border-gray-800{--tw-border-opacity:1;border-color:#1f2937;border-color:rgb(31 41 55/var(--tw-border-opacity,1))}.border-green-200{--tw-border-opacity:1;border-color:#bbf7d0;border-color:rgb(187 247 208/var(--tw-border-opacity,1))}.border-green-300{--tw-border-opacity:1;border-color:#86efac;border-color:rgb(134 239 172/var(--tw-border-opacity,1))}.border-green-400{--tw-border-opacity:1;border-color:#4ade80;border-color:rgb(74 222 128/var(--tw-border-opacity,1))}.border-indigo-200{--tw-border-opacity:1;border-color:#c7d2fe;border-color:rgb(199 210 254/var(--tw-border-opacity,1))}.border-indigo-500{--tw-border-opacity:1;border-color:#6366f1;border-color:rgb(99 102 241/var(--tw-border-opacity,1))}.border-indigo-600{--tw-border-opacity:1;border-color:#4f46e5;border-color:rgb(79 70 229/var(--tw-border-opacity,1))}.border-orange-300{--tw-border-opacity:1;border-color:#fdba74;border-color:rgb(253 186 116/var(--tw-border-opacity,1))}.border-orange-500{--tw-border-opacity:1;border-color:#f97316;border-color:rgb(249 115 22/var(--tw-border-opacity,1))}.border-purple-200{--tw-border-opacity:1;border-color:#e9d5ff;border-color:rgb(233 213 255/var(--tw-border-opacity,1))}.border-purple-500{--tw-border-opacity:1;border-color:#a855f7;border-color:rgb(168 85 247/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:#fecaca;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-red-300{--tw-border-opacity:1;border-color:#fca5a5;border-color:rgb(252 165 165/var(--tw-border-opacity,1))}.border-red-500{--tw-border-opacity:1;border-color:#ef4444;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.border-transparent{border-color:#0000}.border-white{--tw-border-opacity:1;border-color:#fff;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-yellow-200{--tw-border-opacity:1;border-color:#fef08a;border-color:rgb(254 240 138/var(--tw-border-opacity,1))}.border-yellow-300{--tw-border-opacity:1;border-color:#fde047;border-color:rgb(253 224 71/var(--tw-border-opacity,1))}.border-yellow-400{--tw-border-opacity:1;border-color:#facc15;border-color:rgb(250 204 21/var(--tw-border-opacity,1))}.border-yellow-500{--tw-border-opacity:1;border-color:#eab308;border-color:rgb(234 179 8/var(--tw-border-opacity,1))}.border-t-transparent{border-top-color:#0000}.bg-black{--tw-bg-opacity:1;background-color:#000;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black\/50{background-color:#00000080}.bg-black\/60{background-color:#0009}.bg-blue-100{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-blue-200{--tw-bg-opacity:1;background-color:#bfdbfe;background-color:rgb(191 219 254/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-50\/80{background-color:#eff6ffcc}.bg-blue-500{--tw-bg-opacity:1;background-color:#3b82f6;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-blue-600{--tw-bg-opacity:1;background-color:#2563eb;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-gray-100{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.bg-gray-200{--tw-bg-opacity:1;background-color:#e5e7eb;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.bg-gray-300{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.bg-gray-50{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-gray-600{--tw-bg-opacity:1;background-color:#4b5563;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.bg-gray-700{--tw-bg-opacity:1;background-color:#374151;background-color:rgb(55 65 81/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:#1f2937;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-gray-900{--tw-bg-opacity:1;background-color:#111827;background-color:rgb(17 24 39/var(--tw-bg-opacity,1))}.bg-green-100{--tw-bg-opacity:1;background-color:#dcfce7;background-color:rgb(220 252 231/var(--tw-bg-opacity,1))}.bg-green-50{--tw-bg-opacity:1;background-color:#f0fdf4;background-color:rgb(240 253 244/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:#22c55e;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-green-600{--tw-bg-opacity:1;background-color:#16a34a;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.bg-indigo-50{--tw-bg-opacity:1;background-color:#eef2ff;background-color:rgb(238 242 255/var(--tw-bg-opacity,1))}.bg-indigo-50\/80{background-color:#eef2ffcc}.bg-indigo-600{--tw-bg-opacity:1;background-color:#4f46e5;background-color:rgb(79 70 229/var(--tw-bg-opacity,1))}.bg-orange-100{--tw-bg-opacity:1;background-color:#ffedd5;background-color:rgb(255 237 213/var(--tw-bg-opacity,1))}.bg-orange-50{--tw-bg-opacity:1;background-color:#fff7ed;background-color:rgb(255 247 237/var(--tw-bg-opacity,1))}.bg-orange-500{--tw-bg-opacity:1;background-color:#f97316;background-color:rgb(249 115 22/var(--tw-bg-opacity,1))}.bg-orange-600{--tw-bg-opacity:1;background-color:#ea580c;background-color:rgb(234 88 12/var(--tw-bg-opacity,1))}.bg-orange-700{--tw-bg-opacity:1;background-color:#c2410c;background-color:rgb(194 65 12/var(--tw-bg-opacity,1))}.bg-purple-100{--tw-bg-opacity:1;background-color:#f3e8ff;background-color:rgb(243 232 255/var(--tw-bg-opacity,1))}.bg-purple-50{--tw-bg-opacity:1;background-color:#faf5ff;background-color:rgb(250 245 255/var(--tw-bg-opacity,1))}.bg-purple-600{--tw-bg-opacity:1;background-color:#9333ea;background-color:rgb(147 51 234/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:#fee2e2;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:#fef2f2;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-500{--tw-bg-opacity:1;background-color:#ef4444;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-red-600{--tw-bg-opacity:1;background-color:#dc2626;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-transparent{background-color:initial}.bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/50{background-color:#ffffff80}.bg-white\/70{background-color:#ffffffb3}.bg-yellow-100{--tw-bg-opacity:1;background-color:#fef9c3;background-color:rgb(254 249 195/var(--tw-bg-opacity,1))}.bg-yellow-400{--tw-bg-opacity:1;background-color:#facc15;background-color:rgb(250 204 21/var(--tw-bg-opacity,1))}.bg-yellow-50{--tw-bg-opacity:1;background-color:#fefce8;background-color:rgb(254 252 232/var(--tw-bg-opacity,1))}.bg-yellow-500{--tw-bg-opacity:1;background-color:#eab308;background-color:rgb(234 179 8/var(--tw-bg-opacity,1))}.bg-opacity-20{--tw-bg-opacity:0.2}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-opacity-60{--tw-bg-opacity:0.6}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-blue-100{--tw-gradient-from:#dbeafe var(--tw-gradient-from-position);--tw-gradient-to:#dbeafe00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from:#eff6ff var(--tw-gradient-from-position);--tw-gradient-to:#eff6ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:#2563eb00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-cyan-500{--tw-gradient-from:#06b6d4 var(--tw-gradient-from-position);--tw-gradient-to:#06b6d400 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-100{--tw-gradient-from:#f3f4f6 var(--tw-gradient-from-position);--tw-gradient-to:#f3f4f600 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-50{--tw-gradient-from:#eef2ff var(--tw-gradient-from-position);--tw-gradient-to:#eef2ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-600{--tw-gradient-from:#4f46e5 var(--tw-gradient-from-position);--tw-gradient-to:#4f46e500 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-orange-100{--tw-gradient-from:#ffedd5 var(--tw-gradient-from-position);--tw-gradient-to:#ffedd500 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-orange-50{--tw-gradient-from:#fff7ed var(--tw-gradient-from-position);--tw-gradient-to:#fff7ed00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-pink-100{--tw-gradient-from:#fce7f3 var(--tw-gradient-from-position);--tw-gradient-to:#fce7f300 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-100{--tw-gradient-from:#f3e8ff var(--tw-gradient-from-position);--tw-gradient-to:#f3e8ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-purple-50{--tw-gradient-from:#faf5ff var(--tw-gradient-from-position);--tw-gradient-to:#faf5ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-blue-500{--tw-gradient-to:#3b82f600 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#3b82f6 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-purple-600{--tw-gradient-to:#9333ea00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#9333ea var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-blue-50{--tw-gradient-to:#eff6ff var(--tw-gradient-to-position)}.to-blue-500{--tw-gradient-to:#3b82f6 var(--tw-gradient-to-position)}.to-blue-700{--tw-gradient-to:#1d4ed8 var(--tw-gradient-to-position)}.to-gray-200{--tw-gradient-to:#e5e7eb var(--tw-gradient-to-position)}.to-indigo-50{--tw-gradient-to:#eef2ff var(--tw-gradient-to-position)}.to-orange-50{--tw-gradient-to:#fff7ed var(--tw-gradient-to-position)}.to-pink-50{--tw-gradient-to:#fdf2f8 var(--tw-gradient-to-position)}.to-pink-600{--tw-gradient-to:#db2777 var(--tw-gradient-to-position)}.to-purple-50{--tw-gradient-to:#faf5ff var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to:#9333ea var(--tw-gradient-to-position)}.to-red-50{--tw-gradient-to:#fef2f2 var(--tw-gradient-to-position)}.p-1{padding:.25rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-12{padding-bottom:3rem;padding-top:3rem}.py-16{padding-bottom:4rem;padding-top:4rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-20{padding-bottom:5rem;padding-top:5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.pb-2{padding-bottom:.5rem}.pb-4{padding-bottom:1rem}.pb-6{padding-bottom:1.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.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}.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-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-\[10px\]{font-size:10px}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-wide{letter-spacing:.025em}.tracking-widest{letter-spacing:.1em}.text-blue-100{--tw-text-opacity:1;color:#dbeafe;color:rgb(219 234 254/var(--tw-text-opacity,1))}.text-blue-500{--tw-text-opacity:1;color:#3b82f6;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-blue-800{--tw-text-opacity:1;color:#1e40af;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-blue-900{--tw-text-opacity:1;color:#1e3a8a;color:rgb(30 58 138/var(--tw-text-opacity,1))}.text-gray-300{--tw-text-opacity:1;color:#d1d5db;color:rgb(209 213 219/var(--tw-text-opacity,1))}.text-gray-400{--tw-text-opacity:1;color:#9ca3af;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:#6b7280;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:#374151;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:#111827;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-green-400{--tw-text-opacity:1;color:#4ade80;color:rgb(74 222 128/var(--tw-text-opacity,1))}.text-green-500{--tw-text-opacity:1;color:#22c55e;color:rgb(34 197 94/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:#16a34a;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-green-700{--tw-text-opacity:1;color:#15803d;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-green-800{--tw-text-opacity:1;color:#166534;color:rgb(22 101 52/var(--tw-text-opacity,1))}.text-green-900{--tw-text-opacity:1;color:#14532d;color:rgb(20 83 45/var(--tw-text-opacity,1))}.text-indigo-600{--tw-text-opacity:1;color:#4f46e5;color:rgb(79 70 229/var(--tw-text-opacity,1))}.text-indigo-900{--tw-text-opacity:1;color:#312e81;color:rgb(49 46 129/var(--tw-text-opacity,1))}.text-orange-100{--tw-text-opacity:1;color:#ffedd5;color:rgb(255 237 213/var(--tw-text-opacity,1))}.text-orange-600{--tw-text-opacity:1;color:#ea580c;color:rgb(234 88 12/var(--tw-text-opacity,1))}.text-orange-700{--tw-text-opacity:1;color:#c2410c;color:rgb(194 65 12/var(--tw-text-opacity,1))}.text-orange-800{--tw-text-opacity:1;color:#9a3412;color:rgb(154 52 18/var(--tw-text-opacity,1))}.text-orange-900{--tw-text-opacity:1;color:#7c2d12;color:rgb(124 45 18/var(--tw-text-opacity,1))}.text-purple-100{--tw-text-opacity:1;color:#f3e8ff;color:rgb(243 232 255/var(--tw-text-opacity,1))}.text-purple-600{--tw-text-opacity:1;color:#9333ea;color:rgb(147 51 234/var(--tw-text-opacity,1))}.text-purple-700{--tw-text-opacity:1;color:#7e22ce;color:rgb(126 34 206/var(--tw-text-opacity,1))}.text-purple-900{--tw-text-opacity:1;color:#581c87;color:rgb(88 28 135/var(--tw-text-opacity,1))}.text-red-500{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:#dc2626;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-red-700{--tw-text-opacity:1;color:#b91c1c;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-red-800{--tw-text-opacity:1;color:#991b1b;color:rgb(153 27 27/var(--tw-text-opacity,1))}.text-red-900{--tw-text-opacity:1;color:#7f1d1d;color:rgb(127 29 29/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-yellow-400{--tw-text-opacity:1;color:#facc15;color:rgb(250 204 21/var(--tw-text-opacity,1))}.text-yellow-600{--tw-text-opacity:1;color:#ca8a04;color:rgb(202 138 4/var(--tw-text-opacity,1))}.text-yellow-700{--tw-text-opacity:1;color:#a16207;color:rgb(161 98 7/var(--tw-text-opacity,1))}.text-yellow-800{--tw-text-opacity:1;color:#854d0e;color:rgb(133 77 14/var(--tw-text-opacity,1))}.text-yellow-900{--tw-text-opacity:1;color:#713f12;color:rgb(113 63 18/var(--tw-text-opacity,1))}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-2xl{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px #00000040;--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-lg,.shadow-md{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-sm,.shadow-xl{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.outline-none{outline:2px solid #0000;outline-offset:2px}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-black\/5{--tw-ring-color:#0000000d}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.grayscale{--tw-grayscale:grayscale(100%)}.filter,.grayscale{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-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-shadow{transition-duration:.15s;transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.fade-in{animation:fadeIn .2s ease-out}.spinner{animation:spin .6s linear infinite}.last\:border-b-0:last-child{border-bottom-width:0}.hover\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-blue-300:hover{--tw-border-opacity:1;border-color:#93c5fd;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.hover\:bg-blue-100:hover{--tw-bg-opacity:1;background-color:#dbeafe;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.hover\:bg-blue-200:hover{--tw-bg-opacity:1;background-color:#bfdbfe;background-color:rgb(191 219 254/var(--tw-bg-opacity,1))}.hover\:bg-blue-50:hover{--tw-bg-opacity:1;background-color:#eff6ff;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:#1d4ed8;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:#f3f4f6;background-color:rgb(243 244 246/var(--tw-bg-opacity,1))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:#e5e7eb;background-color:rgb(229 231 235/var(--tw-bg-opacity,1))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:#f9fafb;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.hover\:bg-gray-600:hover{--tw-bg-opacity:1;background-color:#4b5563;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.hover\:bg-gray-700:hover{--tw-bg-opacity:1;background-color:#374151;background-color:rgb(55 65 81/var(--tw-bg-opacity,1))}.hover\:bg-gray-800:hover{--tw-bg-opacity:1;background-color:#1f2937;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.hover\:bg-green-200:hover{--tw-bg-opacity:1;background-color:#bbf7d0;background-color:rgb(187 247 208/var(--tw-bg-opacity,1))}.hover\:bg-green-700:hover{--tw-bg-opacity:1;background-color:#15803d;background-color:rgb(21 128 61/var(--tw-bg-opacity,1))}.hover\:bg-indigo-700:hover{--tw-bg-opacity:1;background-color:#4338ca;background-color:rgb(67 56 202/var(--tw-bg-opacity,1))}.hover\:bg-orange-50:hover{--tw-bg-opacity:1;background-color:#fff7ed;background-color:rgb(255 247 237/var(--tw-bg-opacity,1))}.hover\:bg-orange-700:hover{--tw-bg-opacity:1;background-color:#c2410c;background-color:rgb(194 65 12/var(--tw-bg-opacity,1))}.hover\:bg-purple-200:hover{--tw-bg-opacity:1;background-color:#e9d5ff;background-color:rgb(233 213 255/var(--tw-bg-opacity,1))}.hover\:bg-red-50:hover{--tw-bg-opacity:1;background-color:#fef2f2;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.hover\:bg-red-600:hover{--tw-bg-opacity:1;background-color:#dc2626;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:#b91c1c;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.hover\:bg-white:hover{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/20:hover{background-color:#fff3}.hover\:bg-yellow-200:hover{--tw-bg-opacity:1;background-color:#fef08a;background-color:rgb(254 240 138/var(--tw-bg-opacity,1))}.hover\:bg-opacity-20:hover{--tw-bg-opacity:0.2}.hover\:from-cyan-600:hover{--tw-gradient-from:#0891b2 var(--tw-gradient-from-position);--tw-gradient-to:#0891b200 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:to-blue-600:hover{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.hover\:text-blue-500:hover{--tw-text-opacity:1;color:#3b82f6;color:rgb(59 130 246/var(--tw-text-opacity,1))}.hover\:text-blue-600:hover{--tw-text-opacity:1;color:#2563eb;color:rgb(37 99 235/var(--tw-text-opacity,1))}.hover\:text-blue-700:hover{--tw-text-opacity:1;color:#1d4ed8;color:rgb(29 78 216/var(--tw-text-opacity,1))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:#1e40af;color:rgb(30 64 175/var(--tw-text-opacity,1))}.hover\:text-gray-300:hover{--tw-text-opacity:1;color:#d1d5db;color:rgb(209 213 219/var(--tw-text-opacity,1))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:#4b5563;color:rgb(75 85 99/var(--tw-text-opacity,1))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:#374151;color:rgb(55 65 81/var(--tw-text-opacity,1))}.hover\:text-gray-800:hover{--tw-text-opacity:1;color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.hover\:text-gray-900:hover{--tw-text-opacity:1;color:#111827;color:rgb(17 24 39/var(--tw-text-opacity,1))}.hover\:text-green-700:hover{--tw-text-opacity:1;color:#15803d;color:rgb(21 128 61/var(--tw-text-opacity,1))}.hover\:text-indigo-600:hover{--tw-text-opacity:1;color:#4f46e5;color:rgb(79 70 229/var(--tw-text-opacity,1))}.hover\:text-orange-700:hover{--tw-text-opacity:1;color:#c2410c;color:rgb(194 65 12/var(--tw-text-opacity,1))}.hover\:text-purple-700:hover{--tw-text-opacity:1;color:#7e22ce;color:rgb(126 34 206/var(--tw-text-opacity,1))}.hover\:text-red-700:hover{--tw-text-opacity:1;color:#b91c1c;color:rgb(185 28 28/var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:text-yellow-300:hover{--tw-text-opacity:1;color:#fde047;color:rgb(253 224 71/var(--tw-text-opacity,1))}.hover\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.hover\:shadow-lg:hover,.hover\:shadow-md:hover{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.hover\:shadow-sm:hover{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.hover\:shadow-sm:hover,.hover\:shadow-xl:hover{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.focus\:border-blue-600:focus{--tw-border-opacity:1;border-color:#2563eb;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.focus\:border-transparent:focus{border-color:#0000}.focus\:outline-none:focus{outline:2px solid #0000;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),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-blue-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(191 219 254/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-indigo-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(99 102 241/var(--tw-ring-opacity,1))}.focus\:ring-orange-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(249 115 22/var(--tw-ring-opacity,1))}.active\:scale-95:active{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-400:disabled{--tw-bg-opacity:1;background-color:#9ca3af;background-color:rgb(156 163 175/var(--tw-bg-opacity,1))}.disabled\:text-gray-400:disabled{--tw-text-opacity:1;color:#9ca3af;color:rgb(156 163 175/var(--tw-text-opacity,1))}.disabled\:no-underline:disabled{-webkit-text-decoration-line:none;text-decoration-line:none}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@media (min-width:640px){.sm\:inline-block{display:inline-block}.sm\:flex-row{flex-direction:row}}@media (min-width:768px){.md\:col-span-2{grid-column:span 2/span 2}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.md\:p-12{padding:3rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-6xl{font-size:3.75rem;line-height:1}}@media (min-width:1024px){.lg\:col-span-1{grid-column:span 1/span 1}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:grid-cols-2{grid-template-columns:repeat(2,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))}}.assessment-chart-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:20px auto;max-width:800px;padding:24px}.assessment-header{border-bottom:2px solid #f0f0f0;margin-bottom:30px;padding-bottom:20px;text-align:center}.student-name{font-size:28px;font-weight:600;margin:0 0 12px}.date-range{align-items:center;color:#666;display:flex;font-size:14px;gap:12px;justify-content:center}.end-date,.start-date{background:#f5f5f5;border-radius:6px;font-weight:500;padding:6px 12px}.date-separator{color:#5b9bd5;font-size:18px}.completion-section{margin-bottom:30px}.completion-label{align-items:center;color:#666;display:flex;font-size:14px;justify-content:space-between;margin-bottom:8px}.completion-value{color:#5b9bd5;font-size:20px;font-weight:700}.completion-bar{background:#f0f0f0;border-radius:20px;height:40px;overflow:hidden;position:relative}.completion-fill{align-items:center;background:linear-gradient(90deg,#5b9bd5,#4a8ac9);border-radius:20px;display:flex;height:100%;justify-content:flex-end;min-width:60px;padding-right:16px;transition:width 1s ease-in-out}.completion-text{color:#fff;font-size:16px;font-weight:700;text-shadow:0 1px 2px #0003}.balance-chart-section{margin-bottom:30px;text-align:center}.chart-title{color:#333;font-size:18px;font-weight:600;margin-bottom:20px}.radar-chart{align-items:center;display:flex;justify-content:center}.radar-svg{height:auto;max-width:400px;width:100%}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e0e0e0;border-radius:12px;transition:transform .2s,box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #5b9bd526;transform:translateY(-2px)}.stat-icon{font-size:32px;margin-bottom:8px}.stat-value{color:#5b9bd5;font-size:28px;font-weight:700;margin-bottom:4px}.stat-label{color:#666;font-size:13px;font-weight:500}.summary-section{background:#f8f9fa;border-left:4px solid #5b9bd5;border-radius:8px;padding:20px}.summary-title{color:#333;font-size:16px;font-weight:600;margin:0 0 12px}.summary-text{color:#555;font-size:14px;line-height:1.6;margin:0}@media (max-width:768px){.assessment-chart-container{margin:10px;padding:16px}.student-name{font-size:22px}.date-range{flex-direction:column;gap:8px}.date-separator{transform:rotate(90deg)}.stats-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.stat-card{padding:16px}.stat-icon{font-size:24px}.stat-value{font-size:22px}.radar-svg{max-width:300px}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.completion-fill{padding-right:8px}.completion-text{font-size:14px}}@media print{.assessment-chart-container{box-shadow:none;page-break-inside:avoid}.stat-card{background:#fff;border:1px solid #ccc}.completion-fill{background:#5b9bd5!important}}.jsa-floating-button{align-items:center;background:linear-gradient(135deg,#5b9bd5,#4a90c9);border:3px solid #fff;border-radius:50%;bottom:30px;box-shadow:0 4px 16px #5b9bd580;cursor:pointer;display:flex;height:72px;justify-content:center;left:30px;overflow:hidden;position:fixed;right:auto;transition:all .3s cubic-bezier(.4,0,.2,1);width:72px;z-index:1000}.jsa-floating-button img{border-radius:50%;height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:cover;object-position:top center;width:100%}.jsa-floating-button:hover{box-shadow:0 8px 24px #5b9bd599;transform:scale(1.1)}.jsa-floating-button:active{transform:scale(.95)}.jsa-pulse-ring{animation:pulse 2s ease-out infinite;border:3px solid #5b9bd5;border-radius:50%;height:100%;pointer-events:none;position:absolute;width:100%}.jsa-chat-panel{background:#fff;border-radius:16px;bottom:30px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;height:650px;left:116px;overflow:hidden;position:fixed;right:auto;width:380px;z-index:999}.jsa-chat-panel.animate-slide-up{animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.jsa-chat-header{background:linear-gradient(135deg,#5b9bd5,#4a90c9);border-bottom:2px solid #fff3;color:#fff;justify-content:space-between;padding:16px 20px}.jsa-branding,.jsa-chat-header{align-items:center;display:flex}.jsa-branding{gap:12px}.jsa-branding img{border:2px solid #ffffffe6;border-radius:50%;box-shadow:0 2px 10px #00000040;height:56px;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:cover;object-position:top center;width:56px}.jsa-branding h3{font-size:18px;font-weight:600;letter-spacing:.5px;margin:0}.jsa-status{align-items:center;display:flex;font-size:12px;gap:6px;margin:2px 0 0;opacity:.9}.jsa-status:before{animation:blink 2s infinite;color:#4ade80;content:"●";font-size:14px}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.jsa-close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;transition:background .2s;width:32px}.jsa-close-btn:hover{background:#ffffff4d}.jsa-chat-messages{background:#f8fafc;flex:1 1;overflow-y:auto;padding:16px}.jsa-message{animation:fadeIn .3s;display:flex;gap:10px;margin-bottom:16px}.jsa-message.user{flex-direction:row-reverse}.message-avatar{flex-shrink:0}.message-avatar img{border:2px solid #5b9bd5;border-radius:50%;height:36px;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:cover;width:36px}.message-avatar .user-icon{align-items:center;background:linear-gradient(135deg,#48bb78,#38a169);border:2px solid #48bb78;border-radius:50%;color:#fff;display:flex;font-size:20px;height:36px;justify-content:center;width:36px}.message-content{background:#fff;border-radius:12px;box-shadow:0 2px 6px #00000014;flex:1 1;max-width:75%;padding:12px 16px}.jsa-message.user .message-content{background:linear-gradient(135deg,#5b9bd5,#4a90c9);color:#fff}.message-content p{word-wrap:break-word;font-size:14px;line-height:1.6;margin:0;white-space:pre-wrap}.message-time{color:#94a3b8;display:block;font-size:11px;font-weight:500;margin-top:6px}.jsa-message.user .message-time{color:#fffc;text-align:right}.jsa-message.error .message-content{background:#fee2e2;border:1px solid #fca5a5;color:#dc2626}.typing-indicator{background:#fff;border-radius:12px;display:flex;gap:5px;padding:12px 16px;width:-webkit-fit-content;width:fit-content}.typing-indicator span{animation:typing 1.4s infinite;background:#5b9bd5;border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.7;transform:translateY(0)}30%{opacity:1;transform:translateY(-10px)}}.jsa-quick-questions{background:#fff;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:8px;max-height:120px;overflow-y:auto;padding:12px 16px}.quick-question-btn{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:20px;color:#475569;cursor:pointer;font-size:13px;font-weight:500;padding:8px 14px;transition:all .2s;white-space:nowrap}.quick-question-btn:hover:not(:disabled){background:linear-gradient(135deg,#5b9bd5,#4a90c9);border-color:#5b9bd5;box-shadow:0 4px 12px #5b9bd54d;color:#fff;transform:translateY(-2px)}.quick-question-btn:disabled{cursor:not-allowed;opacity:.5}.jsa-chat-input{background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:10px;padding:16px}.jsa-chat-input input{border:2px solid #cbd5e1;border-radius:24px;flex:1 1;font-size:14px;outline:none;padding:12px 16px;transition:border-color .2s}.jsa-chat-input input:focus{border-color:#5b9bd5;box-shadow:0 0 0 3px #5b9bd51a}.jsa-chat-input input:disabled{background:#f1f5f9;cursor:not-allowed}.send-btn{align-items:center;background:linear-gradient(135deg,#5b9bd5,#4a90c9);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:48px;justify-content:center;transition:all .2s;width:48px}.send-btn:hover:not(:disabled){box-shadow:0 4px 12px #5b9bd566;transform:scale(1.1)}.send-btn:active:not(:disabled){transform:scale(.95)}.send-btn:disabled{cursor:not-allowed;opacity:.5}.jsa-assistant-embedded{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;display:flex;flex-direction:column;height:600px;overflow:hidden;width:100%}.jsa-embedded-header{align-items:center;background:linear-gradient(135deg,#5b9bd5,#4a90c9);color:#fff;display:flex;gap:16px;padding:20px}.jsa-embedded-header img{border:3px solid #fffc;border-radius:50%;height:60px;width:60px}.jsa-embedded-header h3{font-size:20px;font-weight:600;margin:0}.jsa-tagline{font-size:14px;margin:4px 0 0;opacity:.9}.jsa-embedded-messages{background:#f8fafc;flex:1 1;overflow-y:auto;padding:20px}.jsa-embedded-quick{background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:10px;justify-content:center;padding:12px 20px}.jsa-embedded-quick button{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:50%;cursor:pointer;font-size:20px;height:44px;transition:all .2s;width:44px}.jsa-embedded-quick button:hover{background:linear-gradient(135deg,#5b9bd5,#4a90c9);transform:scale(1.1)}.jsa-embedded-input{background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:12px;padding:16px 20px}.jsa-embedded-input input{border:2px solid #cbd5e1;border-radius:24px;flex:1 1;font-size:14px;outline:none;padding:14px 18px;transition:border-color .2s}.jsa-embedded-input input:focus{border-color:#5b9bd5;box-shadow:0 0 0 3px #5b9bd51a}.jsa-embedded-input button{background:linear-gradient(135deg,#5b9bd5,#4a90c9);border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:22px;height:50px;transition:all .2s;width:50px}.jsa-embedded-input button:hover:not(:disabled){box-shadow:0 4px 12px #5b9bd566;transform:scale(1.1)}@media (max-width:480px){.jsa-chat-panel{bottom:12px;height:calc(100vh - 120px);left:10px;right:10px;width:calc(100vw - 20px)}.jsa-floating-button{bottom:16px;height:60px;right:16px;width:60px}.jsa-quick-questions{max-height:100px}.quick-question-btn{font-size:12px;padding:6px 12px}}.jsa-chat-messages::-webkit-scrollbar,.jsa-embedded-messages::-webkit-scrollbar,.jsa-quick-questions::-webkit-scrollbar{width:6px}.jsa-chat-messages::-webkit-scrollbar-track,.jsa-embedded-messages::-webkit-scrollbar-track,.jsa-quick-questions::-webkit-scrollbar-track{background:#f1f5f9}.jsa-chat-messages::-webkit-scrollbar-thumb,.jsa-embedded-messages::-webkit-scrollbar-thumb,.jsa-quick-questions::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.jsa-chat-messages::-webkit-scrollbar-thumb:hover,.jsa-embedded-messages::-webkit-scrollbar-thumb:hover,.jsa-quick-questions::-webkit-scrollbar-thumb:hover{background:#94a3b8}.jsa-close-btn:focus,.jsa-floating-button:focus,.quick-question-btn:focus,.send-btn:focus{outline:3px solid #5b9bd5;outline-offset:2px}@media print{.jsa-chat-panel,.jsa-floating-button{display:none}}.scroll-to-top-btn{align-items:center;background:#1e3a8a;border:none;border-radius:10px;bottom:28px;box-shadow:0 4px 14px #1e3a8a73;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:44px;justify-content:center;left:auto;line-height:1;opacity:1;position:fixed;right:28px;transition:all .2s ease;width:44px;z-index:9999}.scroll-to-top-btn:hover{background:#1d4ed8;box-shadow:0 6px 18px #1e3a8a8c;opacity:1;transform:translateY(-2px)}.scroll-to-top-btn:active{opacity:.8;transform:translateY(0)}@media (max-width:768px){.scroll-to-top-btn{bottom:20px;font-size:13px;height:32px;right:20px;width:32px}}:root{--color-navy:#0f1d30;--color-blue:#1d4ed8;--color-blue-light:#eff6ff;--color-gray-bg:#f2f4f7;--color-gray-text:#3d4a5c;--color-border:#dde1e8}.home-page{background:#fff;color:#0f1d30;color:var(--color-navy);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh}.home-nav{background:#fff;border-bottom:1px solid #dde1e8;border-bottom:1px solid var(--color-border);position:-webkit-sticky;position:sticky;top:0;z-index:50}.nav-container{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1200px;padding:.75rem 2rem}.nav-left{display:flex;flex-direction:column;gap:.3rem}.nav-tagline{color:#3d4a5c;color:var(--color-gray-text);font-size:.75rem;line-height:1.4;margin:0}.logo-area,.logo-link{align-items:center;display:flex;gap:.5rem}.logo-link{text-decoration:none;transition:opacity .2s}.logo-link:hover{opacity:.75}.logo-text-badge{align-items:center;background:#0f1d30;background:var(--color-navy);border-radius:.35rem;color:#fff;display:inline-flex;font-size:.85rem;font-weight:800;justify-content:center;letter-spacing:.02em;padding:.25rem .6rem}.logo-text-badge--pda{background:#c0392b}.logo-text-name{color:#0f1d30;color:var(--color-navy);font-size:.8rem;font-weight:600;line-height:1.2;max-width:90px}.logo-divider{font-size:1rem;padding:0 .25rem}.logo-divider,.logo-powered-sep{color:#dde1e8;color:var(--color-border);-webkit-user-select:none;user-select:none}.logo-powered-sep{font-size:.85rem;padding:0 .2rem}.logo-powered-link{align-items:center;display:flex;gap:.35rem;opacity:.72;text-decoration:none;transition:opacity .2s}.logo-powered-link:hover{opacity:1}.logo-powered-label{color:#3d4a5c;color:var(--color-gray-text);font-size:.65rem;font-weight:500;letter-spacing:.03em;line-height:1;white-space:nowrap}.logo-fallback,.logo-img{display:none}.hero-section{background:#0b1628;color:#fff;overflow:hidden;position:relative}.hero-bg-gradient,.hero-bg-grid,.hero-bg-overlay{display:none}.hero-background-image{line-height:0;width:100%}.hero-bg-img{display:block;height:auto;width:100%}.hero-inner{background:linear-gradient(135deg,#0b1628,#0f2347);padding:2.25rem 2rem 2rem;position:relative;text-align:center;z-index:1}.hero-brand-lockup{background:#ffffff14;border:1px solid #ffffff26;border-radius:.75rem;gap:.875rem;margin-bottom:1.1rem;padding:.5rem 1.1rem .5rem .65rem}.hero-brand-badge,.hero-brand-lockup{align-items:center;display:inline-flex}.hero-brand-badge{background:#fff;border-radius:.45rem;color:#0b1628;flex-shrink:0;font-size:1rem;font-weight:900;height:2.2rem;justify-content:center;letter-spacing:-.02em;width:2.2rem}.hero-brand-text{display:flex;flex-direction:column;gap:.12rem;text-align:left}.hero-brand-name{color:#fff;font-size:.9rem;font-weight:700;line-height:1.2}.hero-brand-sub{color:#c8e1ffcc;font-size:.65rem;font-weight:400;letter-spacing:.01em}.hero-headline{color:#fff;font-size:2.4rem;font-weight:800;letter-spacing:-.025em;line-height:1.18;margin:0 0 .75rem}.hero-desc{color:#c8e4ffd9;font-size:1rem;line-height:1.7;margin:0 auto;max-width:540px}.hero-stats-bar{background:#fffffff7;border-top:1px solid #ffffff1a;box-shadow:0 4px 24px #00000026;position:relative;width:100%;z-index:3}.hero-stats-container{align-items:center;display:flex;justify-content:center;margin:0 auto;max-width:860px;padding:.875rem 2rem}.hero-stat{align-items:center;display:flex;flex-direction:column;padding:.4rem 2.75rem;text-align:center}.hero-stat-number{color:#0f1d30;font-size:1.4rem;font-weight:800;line-height:1.2}.hero-stat-label{color:#3d4a5c;font-size:.7rem;letter-spacing:.02em;margin-top:.15rem;white-space:nowrap}.hero-stat-divider{background:#dde1e8;background:var(--color-border);flex-shrink:0;height:2.25rem;width:1px}.hero-app-bar{align-items:center;background:#f4f6f9;border-top:1px solid #dde1e8;border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:1.25rem;justify-content:center;padding:.9rem 2rem}.hero-app-label{color:#8a95a3;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.hero-app-buttons{display:flex;gap:.65rem}.hero-app-btn{align-items:center;border:1px solid #0000;border-radius:.55rem;display:inline-flex;gap:.55rem;padding:.45rem 1rem;text-decoration:none;transition:opacity .2s,transform .15s}.hero-app-btn:hover{opacity:.85;transform:translateY(-1px)}.hero-app-btn--apple{background:#0b1628;border-color:#0b1628;color:#fff}.hero-app-btn--google{background:#fff;border-color:#d0d7e0;color:#0b1628}.hero-app-btn-text{display:flex;flex-direction:column;line-height:1.2}.hero-app-btn-sub{font-size:.58rem;font-weight:400;letter-spacing:.02em;opacity:.8}.hero-app-btn-store{font-size:.85rem;font-weight:700;letter-spacing:-.01em}.tagline-bar{background:#fff;border-bottom:1px solid #dde1e8;border-bottom:1px solid var(--color-border);padding:1.25rem 2rem;text-align:center}.tagline-line{color:#0f1d30;color:var(--color-navy);font-size:1.15rem;font-weight:600;line-height:1.6;margin:0}.section-container{margin:0 auto;max-width:1200px}.section-header{margin-bottom:1.25rem;text-align:center}.section-label{color:#1d4ed8;color:var(--color-blue);display:inline-block;font-size:.75rem;font-weight:700;letter-spacing:.08em;margin-bottom:.5rem;text-transform:uppercase}.section-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1a56db,#0b3a8c);-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:.35rem}.section-description{color:#3d4a5c;color:var(--color-gray-text);font-size:.875rem;line-height:1.7;margin:0 auto;max-width:44rem}.ecosystem-section{background:#fff;padding:5rem 2rem}.ecosystem-container{grid-gap:5rem;align-items:center;display:grid;gap:5rem;grid-template-columns:1fr 1fr;margin:0 auto;max-width:1100px}.ecosystem-image-side{align-items:center;display:flex;justify-content:center}.ecosystem-img{border-radius:1.5rem;box-shadow:0 4px 6px #0000000a,0 20px 50px #1d4ed81a,0 8px 20px #0000000f;display:block;height:auto;max-width:440px;width:100%}.ecosystem-text-side{padding:1rem 0}.ecosystem-heading{color:#0f1d30;color:var(--color-navy);font-size:2.2rem;font-weight:800;letter-spacing:-.02em;line-height:1.2;margin-bottom:1.25rem}.ecosystem-body{color:#3d4a5c;color:var(--color-gray-text);font-size:1.05rem;line-height:1.8;margin-bottom:1.75rem}.ecosystem-features{display:flex;flex-direction:column;gap:.65rem;list-style:none;margin:0 0 2rem;padding:0}.ecosystem-features li{align-items:center;color:#0f1d30;color:var(--color-navy);display:flex;font-size:.95rem;font-weight:500;gap:.75rem}.eco-check{align-items:center;background:#eff6ff;background:var(--color-blue-light,#eff6ff);border-radius:50%;color:#1d4ed8;color:var(--color-blue);display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:1.4rem;justify-content:center;width:1.4rem}.ecosystem-cta{background:#1d4ed8;background:var(--color-blue);border-radius:.5rem;color:#fff;display:inline-block;font-size:.95rem;font-weight:700;padding:.8rem 1.75rem;text-decoration:none;transition:all .2s}.ecosystem-cta:hover{background:#1a44c0;box-shadow:0 6px 20px #1d4ed840;transform:translateY(-1px)}.ecosystem-row{align-items:center;background:#0000;border:none;border-radius:0;display:flex;gap:2rem;margin-bottom:1.5rem;padding:0}.ecosystem-row-img{background:#f2f4f7;background:var(--color-gray-bg);cursor:pointer;flex-shrink:0;height:320px;mix-blend-mode:multiply;object-fit:contain;transform-origin:center bottom;transition:filter .18s ease;width:320px}@keyframes ecosystem-wobble{0%{transform:rotate(0deg) scale(1)}15%{transform:rotate(-4deg) scale(1.03)}30%{transform:rotate(4deg) scale(1.04)}45%{transform:rotate(-3deg) scale(1.03)}60%{transform:rotate(3deg) scale(1.02)}75%{transform:rotate(-1.5deg) scale(1.01)}90%{transform:rotate(1deg) scale(1)}to{transform:rotate(0deg) scale(1)}}.ecosystem-row-img:hover{filter:drop-shadow(0 8px 18px rgba(11,22,40,.18))}.ecosystem-row-img:active{filter:drop-shadow(0 4px 10px rgba(11,22,40,.14))}.ecosystem-row-img--wobble{animation:ecosystem-wobble .6s cubic-bezier(.36,.07,.19,.97) forwards}.ecosystem-row-text{display:flex;flex:1 1;flex-direction:column;gap:.75rem}.ecosystem-row-heading{color:#0f1d30;color:var(--color-navy);font-size:1.35rem;font-weight:700;letter-spacing:-.01em;line-height:1.35;margin:0;max-width:18rem}.ecosystem-row-body{color:#3d4a5c;color:var(--color-gray-text);font-size:.9rem;line-height:1.7;margin:0;max-width:36rem}@media (max-width:768px){.ecosystem-row{flex-direction:column;gap:1.5rem;text-align:center}.ecosystem-row-img{height:200px;width:200px}.ecosystem-row-heading{max-width:100%}}.services-section{background:#f2f4f7;background:var(--color-gray-bg);padding:2.5rem 2rem 3.5rem}.services-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(4,1fr);margin:0 auto;max-width:1200px}.service-card{background:#fff;border:1px solid #0000000a;border-radius:1rem;box-shadow:0 1px 4px #0000000f;cursor:pointer;display:flex;flex-direction:column;padding:1.5rem;transform-origin:center bottom;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s ease;will-change:transform}.service-card:hover{box-shadow:0 16px 32px #0000001f,0 4px 8px #0000000f;transform:translateY(-6px) rotate(.4deg) scale(1.02)}.service-card:active{box-shadow:0 4px 12px #00000014;transform:translateY(-2px) rotate(-.3deg) scale(.98);transition:transform .07s ease,box-shadow .07s ease}.service-icon{font-size:2rem;margin-bottom:.75rem}.service-title{color:#0f1d30;color:var(--color-navy);font-size:1.05rem;font-weight:700;margin-bottom:.5rem}.service-description{color:#3d4a5c;color:var(--color-gray-text);flex:1 1;font-size:.875rem;line-height:1.6;margin-bottom:1.25rem}.service-action{background:#fff;border:1px solid #dde1e8;border:1px solid var(--color-border);border-radius:.5rem;color:#1d4ed8;color:var(--color-blue);cursor:pointer;font-size:.85rem;font-weight:600;margin-top:auto;padding:.55rem;transition:all .2s;width:100%}.service-action:hover{background:#eff6ff;background:var(--color-blue-light);border-color:#bfdbfe}.features-section{background:#fff;padding:5rem 2rem}.features-grid{grid-gap:2rem;gap:2rem;grid-template-columns:repeat(3,1fr)}.feature-card{background:#f2f4f7;background:var(--color-gray-bg);border:1px solid #dde1e8;border:1px solid var(--color-border);border-radius:1rem;padding:2.5rem 2rem;text-align:center;transition:box-shadow .2s}.feature-card:hover{box-shadow:0 8px 24px #00000012}.feature-icon{font-size:2.75rem;margin-bottom:1.25rem}.feature-title{color:#0f1d30;color:var(--color-navy);font-size:1.15rem;font-weight:700;margin-bottom:.75rem}.feature-description{color:#3d4a5c;color:var(--color-gray-text);font-size:.9rem;line-height:1.7}.home-footer{background:#fff;border-top:1px solid #dde1e8;border-top:1px solid var(--color-border);color:#0f1d30;color:var(--color-navy)}.footer-main{grid-gap:3rem;align-items:start;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1.4fr 1.1fr;margin:0 auto;max-width:1200px;padding:4rem 2rem 3rem}.footer-brand{display:flex;flex-direction:column;gap:1.25rem}.footer-logos{align-items:center;display:flex;gap:1.25rem}.footer-logo-img{display:none}.footer-logo-text-link{align-items:center;display:flex;gap:.5rem;text-decoration:none;transition:opacity .2s}.footer-logo-text-link:hover{opacity:.75}.footer-logo-badge{align-items:center;background:#0f1d30;background:var(--color-navy);border-radius:.35rem;color:#fff;display:inline-flex;font-size:.85rem;font-weight:800;justify-content:center;letter-spacing:.02em;padding:.25rem .6rem}.footer-logo-badge--pda{background:#c0392b}.footer-logo-name{color:#0f1d30;color:var(--color-navy);font-size:.8rem;font-weight:600;line-height:1.2;max-width:90px}.footer-brand-desc{color:#3d4a5c;color:var(--color-gray-text);font-size:.875rem;line-height:1.75;margin:0;max-width:280px}.footer-socials{display:flex;gap:.75rem;margin-top:.25rem}.footer-social-icon{align-items:center;border:1.5px solid #dde1e8;border:1.5px solid var(--color-border);border-radius:50%;color:#374151;display:flex;height:2.25rem;justify-content:center;text-decoration:none;transition:all .2s;width:2.25rem}.footer-social-icon:hover{background:#eff6ff;background:var(--color-blue-light);border-color:#1d4ed8;border-color:var(--color-blue);color:#1d4ed8;color:var(--color-blue)}.footer-section{display:flex;flex-direction:column;gap:1rem}.footer-title{color:#0f1d30;color:var(--color-navy);font-size:.95rem;font-weight:700;letter-spacing:.06em;margin:0 0 .25rem;text-transform:uppercase}.footer-links-grid{grid-gap:.55rem 1.5rem;display:grid;gap:.55rem 1.5rem;grid-template-columns:1fr 1fr}.footer-links-grid a{color:#3d4a5c;color:var(--color-gray-text);font-size:.875rem;text-decoration:none;transition:color .2s}.footer-links-grid a:hover{color:#1d4ed8;color:var(--color-blue)}.footer-contact-list{display:flex;flex-direction:column;gap:.7rem}.footer-contact-item{align-items:flex-start;color:#3d4a5c;color:var(--color-gray-text);display:flex;font-size:.875rem;gap:.6rem}.footer-contact-icon{flex-shrink:0;font-size:.95rem;margin-top:.05rem}.footer-contact-item a{color:#3d4a5c;color:var(--color-gray-text);text-decoration:none;transition:color .2s}.footer-contact-item a:hover,.footer-contact-sublabel{color:#1d4ed8;color:var(--color-blue)}.footer-contact-sublabel{display:inline-block;font-size:.7rem;font-weight:700;letter-spacing:.04em;margin-bottom:.1rem;opacity:.85;text-transform:uppercase}.footer-contact-map-link{color:#3d4a5c;color:var(--color-gray-text);display:block;line-height:1.5;text-decoration:none;transition:color .2s}.footer-contact-map-link:hover{color:#1d4ed8;color:var(--color-blue)}.footer-contact-map-link:hover .footer-contact-sublabel{opacity:1}.footer-map-badge{background:#1a56db1a;border-radius:3px;color:#1d4ed8;color:var(--color-blue);display:inline-block;font-size:.62rem;font-weight:600;letter-spacing:0;margin-left:.3rem;opacity:0;padding:.05rem .3rem;text-transform:none;transition:opacity .2s;vertical-align:middle}.footer-contact-map-link:hover .footer-map-badge{opacity:1}.footer-qr-wrap{align-items:center;background:#f2f4f7;background:var(--color-gray-bg);border:1px solid #dde1e8;border:1px solid var(--color-border);border-radius:.75rem;display:flex;height:130px;justify-content:center;overflow:hidden;width:130px}.footer-qr-img{height:100%;object-fit:contain;padding:.5rem;width:100%}.footer-qr-placeholder{align-items:center;background:#f3f4f6;color:#9ca3af;display:flex;font-size:1.5rem;font-weight:700;height:100%;justify-content:center;width:100%}.footer-qr-label{color:#3d4a5c;color:var(--color-gray-text);font-size:.8rem;margin:.5rem 0 .75rem}.footer-website-link{color:#1d4ed8;color:var(--color-blue);font-size:.875rem;font-weight:600;text-decoration:none;transition:color .2s}.footer-website-link:hover{color:#1d4ed8;text-decoration:underline}.footer-bottom{border-top:1px solid #dde1e8;border-top:1px solid var(--color-border);padding:1.25rem 2rem 1.5rem}.footer-bottom-inner{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin:0 auto .75rem;max-width:1200px}.footer-copyright{color:#3d4a5c;color:var(--color-gray-text);font-size:.85rem;margin:0}.footer-bottom-links{align-items:center;display:flex;gap:.75rem}.footer-bottom-links a{color:#0f1d30;color:var(--color-navy);font-size:.85rem;font-weight:600;text-decoration:none;transition:color .2s}.footer-bottom-links a:hover{color:#1d4ed8;color:var(--color-blue)}.footer-bottom-divider{color:#dde1e8;color:var(--color-border);font-size:.85rem}.footer-legal-text{color:#6b7585;display:block;font-size:.7rem;line-height:1.75;margin:0 auto;max-width:1200px;text-align:center}@media (max-width:1100px){.services-grid{grid-template-columns:repeat(2,1fr)}.footer-main{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}.ecosystem-container{gap:3rem}}@media (max-width:768px){.hero-inner{padding:3.5rem 1.5rem 3rem}.hero-headline{font-size:2.1rem}.hero-desc{font-size:.95rem}.hero-brand-lockup{flex-direction:row;gap:.65rem}.hero-section{padding:0}.ecosystem-container{gap:2.5rem;grid-template-columns:1fr;text-align:center}.ecosystem-image-side{order:-1}.ecosystem-img{max-width:300px}.ecosystem-features li{justify-content:center}.ecosystem-cta{text-align:center;width:100%}.ecosystem-heading{font-size:1.75rem}.hero-title{font-size:2.25rem}.hero-subtitle{font-size:1rem}.section-title{font-size:1.75rem}.features-grid,.footer-main,.services-grid{grid-template-columns:1fr}.footer-main{gap:2rem;padding:2.5rem 1.5rem}.footer-brand{grid-column:auto}.hero-stats-container{flex-wrap:wrap}.hero-stat{padding:.4rem 1rem}.hero-stat-number{font-size:1.15rem}.hero-stat-divider{display:none}.footer-bottom-inner{flex-direction:column;gap:.75rem;text-align:center}}.shortcuts-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.shortcuts-panel{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:85vh;max-width:900px;overflow-y:auto;width:90%}.shortcuts-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #e2e8f0;border-radius:16px 16px 0 0;color:#fff;display:flex;justify-content:space-between;padding:24px 32px}.shortcuts-header h2{font-size:28px;font-weight:700;margin:0 0 4px}.shortcuts-subtitle{font-size:14px;margin:0;opacity:.9}.shortcuts-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;transition:all .2s;width:36px}.shortcuts-close:hover{background:#ffffff4d;transform:scale(1.1)}.shortcuts-tabs{background:#f8fafc;display:flex;gap:8px;padding:16px 32px 0}.shortcuts-tab{background:#fff;border:2px solid #e2e8f0;border-radius:8px 8px 0 0;color:#64748b;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.shortcuts-tab:hover{background:#f1f5f9;border-color:#cbd5e1}.shortcuts-tab.active{background:#fff;border-color:#667eea #667eea #fff;color:#667eea;position:relative;z-index:1}.shortcuts-content{background:#fff;padding:32px}.shortcuts-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.shortcut-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:16px;padding:12px 16px;transition:all .2s}.shortcut-item:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateX(4px)}.shortcut-key{align-items:center;background:#fff;border:2px solid #cbd5e1;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#475569;display:inline-flex;font-family:Monaco,Courier New,monospace;font-size:13px;font-weight:600;justify-content:center;min-width:80px;padding:8px 12px;white-space:nowrap}.shortcut-action{color:#334155;flex:1 1;font-size:14px;line-height:1.4}.ai-features-section{background:linear-gradient(135deg,#f8fafc,#e0e7ff);border-top:2px solid #e2e8f0;padding:32px}.ai-features-section h3{color:#334155;font-size:20px;font-weight:700;margin:0 0 20px}.ai-features-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.ai-feature-card{background:#fff;border:2px solid #e0e7ff;border-radius:12px;cursor:pointer;padding:20px;transition:all .3s}.ai-feature-card:hover{border-color:#667eea;box-shadow:0 8px 16px #667eea33;transform:translateY(-4px)}.feature-icon{font-size:36px;margin-bottom:12px;text-align:center}.feature-content h4{color:#334155;font-size:16px;font-weight:600;margin:0 0 8px;text-align:center}.feature-content p{color:#64748b;font-size:13px;line-height:1.5;margin:0;text-align:center}.shortcuts-footer{background:#f8fafc;border-radius:0 0 16px 16px;border-top:1px solid #e2e8f0;padding:16px 32px;text-align:center}.shortcuts-footer p{color:#64748b;font-size:14px;margin:0}@media (max-width:768px){.shortcuts-panel{max-height:90vh;width:95%}.shortcuts-header{padding:20px}.shortcuts-header h2{font-size:22px}.shortcuts-tabs{flex-wrap:nowrap;overflow-x:auto;padding:12px 20px 0}.shortcuts-tab{padding:10px 16px;white-space:nowrap}.shortcuts-content{padding:20px}.shortcuts-grid{grid-template-columns:1fr}.ai-features-section{padding:20px}.ai-features-grid{grid-template-columns:1fr}}@media (prefers-color-scheme:dark){.shortcuts-panel{background:#1e293b;color:#e2e8f0}.shortcuts-header{background:linear-gradient(135deg,#4c1d95,#5b21b6)}.shortcuts-tabs{background:#0f172a}.shortcuts-tab{background:#1e293b;border-color:#334155;color:#94a3b8}.shortcuts-tab.active{background:#1e293b;border-color:#7c3aed;color:#a78bfa}.shortcuts-content{background:#1e293b}.shortcut-item{background:#0f172a;border-color:#334155}.shortcut-key{background:#1e293b;border-color:#475569;color:#cbd5e1}.shortcut-action{color:#cbd5e1}.ai-features-section{background:linear-gradient(135deg,#0f172a,#1e1b4b);border-top-color:#334155}.ai-features-section h3{color:#e2e8f0}.ai-feature-card{background:#1e293b;border-color:#3730a3}.feature-content h4{color:#e2e8f0}.feature-content p{color:#94a3b8}.shortcuts-footer{background:#0f172a;border-top-color:#334155}.shortcuts-footer p{color:#94a3b8}}.translation-overlay{align-items:center;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.translation-panel{animation:slideUp .4s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:20px;box-shadow:0 25px 80px #0006;max-height:90vh;max-width:1200px;overflow-y:auto;width:95%}.translation-header{align-items:center;background:linear-gradient(135deg,#00d4ff,#09f);border-radius:20px 20px 0 0;color:#fff;display:flex;justify-content:space-between;padding:24px 32px}.header-left h2{font-size:28px;font-weight:700;margin:0 0 4px}.translation-subtitle{font-size:14px;margin:0;opacity:.9}.header-controls{align-items:center;display:flex;gap:12px}.font-size-selector{background:#fff3;border:1px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 12px;transition:all .2s}.font-size-selector:hover{background:#ffffff4d}.font-size-selector option{color:#334155}.swap-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;transition:all .3s;width:40px}.swap-btn:hover{background:#ffffff4d;transform:rotate(180deg)}.close-btn{background:#fff3;font-size:20px;height:40px;transition:all .2s;width:40px}.close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.translation-main{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;padding:32px}.translation-input-section,.translation-output-section{display:flex;flex-direction:column;gap:12px}.section-label{align-items:center;color:#334155;display:flex;font-size:16px;font-weight:600;justify-content:space-between}.translating-badge{animation:pulse 1.5s infinite;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.clear-btn{background:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#64748b;cursor:pointer;font-size:13px;font-weight:600;padding:6px 16px;transition:all .2s}.clear-btn:hover{background:#e2e8f0;border-color:#94a3b8;color:#334155}.translation-input{border:2px solid #e2e8f0;border-radius:12px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:18px;padding:16px;resize:vertical;transition:all .2s;width:100%}.translation-input:focus{border-color:#00d4ff;box-shadow:0 0 0 3px #00d4ff1a;outline:none}.translation-output{word-wrap:break-word;align-items:center;background:linear-gradient(135deg,#f8fafc,#e0f2fe);border:3px solid #0ea5e9;border-radius:12px;color:#0c4a6e;display:flex;font-weight:700;justify-content:center;line-height:1.4;min-height:150px;padding:24px;text-align:center;transition:all .3s;width:100%}.translation-output.text-2xl{font-size:2rem}.translation-output.text-4xl{font-size:2.5rem}.translation-output.text-5xl{font-size:3.5rem}.translation-output.text-6xl{font-size:4.5rem}.placeholder-text{color:#94a3b8;font-size:1.2rem;font-weight:400}.quick-phrases-section{background:#f8fafc;border-top:1px solid #e2e8f0;padding:24px 32px}.quick-phrases-section h3{color:#334155;font-size:18px;font-weight:700;margin:0 0 16px}.quick-phrases-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.quick-phrase-btn{background:#fff;border:2px solid #e0e7ff;border-radius:10px;color:#334155;cursor:pointer;font-size:14px;font-weight:500;padding:12px 16px;text-align:left;transition:all .2s}.quick-phrase-btn:hover{background:#e0f2fe;border-color:#00d4ff;box-shadow:0 4px 12px #00d4ff33;transform:translateY(-2px)}.translation-history{background:#fff;border-top:1px solid #e2e8f0;padding:24px 32px}.translation-history h3{color:#334155;font-size:18px;font-weight:700;margin:0 0 16px}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{grid-gap:12px;align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:grid;gap:12px;grid-template-columns:1fr auto 1fr auto;padding:12px 16px;transition:all .2s}.history-item:hover{background:#e0f2fe;border-color:#00d4ff;transform:translateX(4px)}.history-original,.history-translated{color:#334155;font-size:14px}.history-arrow{color:#94a3b8;font-size:18px}.history-time{color:#94a3b8;font-size:12px;text-align:right}.translation-footer{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:0 0 20px 20px;border-top:1px solid #fbbf24;padding:16px 32px;text-align:center}.translation-footer p{color:#78350f;font-size:14px;line-height:1.6;margin:0}@media (max-width:1024px){.translation-main{grid-template-columns:1fr}.translation-output.text-5xl{font-size:3rem}.translation-output.text-6xl{font-size:3.5rem}}@media (max-width:768px){.translation-panel{max-height:95vh;width:98%}.translation-header{flex-direction:column;gap:16px;padding:20px}.header-controls{justify-content:space-between;width:100%}.quick-phrases-section,.translation-main{padding:20px}.quick-phrases-grid{grid-template-columns:1fr}.translation-history{padding:20px}.history-item{grid-template-columns:1fr;text-align:center}.history-arrow{display:none}.history-time{text-align:center}.translation-output.text-4xl{font-size:2rem}.translation-output.text-5xl{font-size:2.5rem}.translation-output.text-6xl{font-size:3rem}}.clear-btn:focus,.close-btn:focus,.quick-phrase-btn:focus,.swap-btn:focus,.translation-input:focus{outline:3px solid #00d4ff;outline-offset:2px}@media print{.translation-overlay,.translation-panel{display:none}}.coach-navigation{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;margin:0 auto;max-width:1200px;padding:20px}.nav-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;margin-bottom:40px;padding:20px;text-align:center}.nav-header h1{font-size:2rem;margin:0 0 10px}.nav-header .subtitle{font-size:1.1rem;margin:0;opacity:.9}.nav-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:20px}.nav-section h2{border-bottom:2px solid #667eea;color:#333;font-size:1.5rem;margin:0 0 20px;padding-bottom:10px}.nav-section h3{color:#555;font-size:1.2rem;margin:0 0 15px}.vehicle-buttons{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.vehicle-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:10px;padding:20px;transition:all .3s ease}.vehicle-btn:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.vehicle-btn.active{background:linear-gradient(135deg,#667eea20,#764ba220);border-color:#667eea;font-weight:700}.vehicle-btn .icon{font-size:2.5rem}.vehicle-btn .name{color:#333;font-size:1.2rem}.scenario-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.scenario-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:15px;text-align:center;transition:all .3s ease}.scenario-btn:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.scenario-btn.active{background:linear-gradient(135deg,#667eea20,#764ba220);border-color:#667eea;font-weight:700}.scenario-btn .icon{font-size:2rem}.scenario-btn .name{color:#333;font-size:1rem;font-weight:500}.scenario-btn .name-en{color:#666;font-size:.85rem}.sub-scenario-list{display:flex;flex-wrap:wrap;gap:10px}.sub-scenario-btn{align-items:flex-start;background:#fff;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:12px 20px;transition:all .3s ease}.sub-scenario-btn:hover{background:#f8f9ff;border-color:#667eea}.sub-scenario-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.sub-scenario-btn.active .name-en{color:#ffffffe6}.sub-scenario-btn .name{font-size:1rem;font-weight:500}.sub-scenario-btn .name-en{color:#666;font-size:.8rem}.issue-checkboxes{display:flex;flex-direction:column;gap:10px}.issue-checkbox{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.issue-checkbox:hover{background:#f8f9ff;border-color:#667eea}.issue-checkbox input[type=checkbox]{accent-color:#667eea;cursor:pointer;height:20px;width:20px}.issue-checkbox .issue-id{color:#667eea;font-family:Courier New,monospace;font-size:.9rem;font-weight:700;min-width:120px}.issue-checkbox .issue-name{color:#333;font-size:1rem}.preview-section{background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001a;margin-top:30px;padding:20px}.preview-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.preview-header h2{color:#333;margin:0}.preview-toggle{display:flex;gap:10px}.preview-toggle button{background:#fff;border:2px solid #e0e0e0;border-radius:20px;cursor:pointer;font-size:.9rem;padding:8px 16px;transition:all .2s ease}.preview-toggle button:hover{border-color:#667eea}.preview-toggle button.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;font-weight:700}.preview-content{display:flex;flex-direction:column;gap:20px;margin-bottom:20px}.preview-card{background:#fafafa;border:1px solid #e0e0e0;border-radius:10px;padding:20px}.preview-card h3{color:#333;font-size:1.2rem;margin:0 0 5px}.preview-card .name-en{color:#666;display:block;font-size:.9rem;font-style:italic;margin-bottom:15px}.coach-tone,.student-tone{border-radius:8px;margin-top:15px;padding:15px}.coach-tone{background:#fff3e0;border-left:4px solid #ff9800}.coach-tone h4{color:#e65100;font-size:1rem;margin:0 0 10px}.coach-tone p{color:#333;line-height:1.6;margin:0}.student-tone{background:#e8f5e9;border-left:4px solid #4caf50}.student-tone h4{color:#2e7d32;font-size:1rem;margin:0 0 10px}.student-tone p{color:#333;line-height:1.6;margin:0}.student-tone .fallback{color:#999;font-style:italic}.preview-actions{display:flex;gap:15px;justify-content:flex-end}.preview-actions button{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:700;padding:12px 24px;transition:all .3s ease}.btn-generate{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-generate:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-send{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-send:hover{box-shadow:0 4px 12px #4caf5066;transform:translateY(-2px)}.loading-overlay{background:#00000080}.spinner{border:4px solid #ffffff4d;height:50px;width:50px}.loading-overlay p{font-size:1.1rem}.section-header-with-toggle{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.toggle-details-btn{background:linear-gradient(135deg,#ff8c42,#ff6b35);border:none;border-radius:20px;box-shadow:0 2px 8px #ff8c424d;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 16px;transition:all .3s ease}.toggle-details-btn:hover{box-shadow:0 4px 12px #ff8c4266;transform:translateY(-2px)}.issue-checkbox.detailed{align-items:flex-start;background:linear-gradient(135deg,#fffbf0,#fff9e6);border:2px solid #fff3e0;flex-direction:column;padding:16px}.issue-checkbox.detailed:hover{border-color:#ff8c42;box-shadow:0 4px 12px #ff8c4226}.issue-info{display:flex;flex-direction:column;gap:8px;width:100%}.issue-details{background:#ffffffb3;border-left:3px solid #ff8c42;border-radius:8px;margin-top:10px;padding:12px}.issue-details .name-en{color:#ff6b35;display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.issue-details .description{color:#555;line-height:1.6;margin-bottom:10px}.issue-details .meta-info{display:flex;font-size:.85rem;gap:16px}.issue-details .category,.issue-details .severity{background:#fff;border-radius:12px;color:#ff8c42;font-weight:600;padding:4px 12px}.custom-input-section{background:linear-gradient(135deg,#fff9e6,#ffe8cc);border:3px solid #ffd93d;border-radius:16px;margin-top:40px;padding:24px}.custom-input-section h3{align-items:center;color:#ff6b35;display:flex;font-size:1.3rem;gap:8px;margin:0 0 20px}.input-methods{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr;margin-bottom:20px}.text-input-area{display:flex;flex-direction:column;gap:12px}.text-input-area textarea{border:2px solid #ffd93d;border-radius:12px;font-family:inherit;font-size:1rem;line-height:1.6;padding:16px;resize:vertical;transition:all .3s ease;width:100%}.text-input-area textarea:focus{border-color:#ff8c42;box-shadow:0 0 0 3px #ff8c421a;outline:none}.btn-add-custom{background:linear-gradient(135deg,#2ecc71,#27ae60);border:none;border-radius:10px;box-shadow:0 4px 12px #2ecc714d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-add-custom:hover:not(:disabled){box-shadow:0 6px 16px #2ecc7166;transform:translateY(-2px)}.btn-add-custom:disabled{cursor:not-allowed;opacity:.5}.voice-input-area{align-items:center;display:flex;flex-direction:column;gap:12px;justify-content:center}.btn-voice{background:linear-gradient(135deg,#4a90e2,#357abd);border:none;border-radius:50px;box-shadow:0 4px 12px #4a90e24d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:20px 30px;transition:all .3s ease;white-space:nowrap}.btn-voice:hover{box-shadow:0 6px 16px #4a90e266;transform:scale(1.05)}.btn-voice.recording{animation:pulse-btn 1.5s ease-in-out infinite;background:linear-gradient(135deg,#e74c3c,#c0392b)}@keyframes pulse-btn{0%,to{box-shadow:0 4px 12px #e74c3c4d}50%{box-shadow:0 4px 20px #e74c3c99}}.recording-indicator{align-items:center;color:#e74c3c;display:flex;font-weight:600;gap:8px}.recording-indicator .pulse{animation:pulse-dot 1s ease-in-out infinite;background:#e74c3c;border-radius:50%;height:12px;width:12px}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.custom-issues-list{background:#fff;border:2px solid #ffd93d;border-radius:12px;margin-top:20px;padding:20px}.custom-issues-list h4{color:#ff6b35;font-size:1.1rem;margin:0 0 16px}.custom-issue-card{align-items:flex-start;background:#fffbf0;border-left:4px solid #ff8c42;border-radius:10px;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px;padding:16px;transition:all .3s ease}.custom-issue-card:hover{box-shadow:0 4px 12px #ff8c4226;transform:translateX(4px)}.custom-issue-content{flex:1 1}.custom-issue-content .timestamp{color:#999;display:block;font-size:.85rem;margin-bottom:6px}.custom-issue-content p{color:#333;line-height:1.6;margin:0}.voice-badge{background:#4a90e2;border-radius:12px;color:#fff;display:inline-block;font-size:.85rem;font-weight:600;margin-top:8px;padding:4px 12px}.btn-remove{background:#e74c3c;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.2rem;padding:8px 12px;transition:all .3s ease}.btn-remove:hover{background:#c0392b;transform:scale(1.1)}.btn-save-to-db{background:linear-gradient(135deg,#9b59b6,#8e44ad);border:none;border-radius:10px;box-shadow:0 4px 12px #9b59b64d;color:#fff;cursor:pointer;font-size:1.05rem;font-weight:600;margin-top:12px;padding:14px 24px;transition:all .3s ease;width:100%}.btn-save-to-db:hover{box-shadow:0 6px 16px #9b59b666;transform:translateY(-2px)}@media (max-width:768px){.coach-navigation{padding:10px}.nav-header h1{font-size:1.5rem}.nav-header .subtitle{font-size:.9rem}.scenario-grid,.vehicle-buttons{grid-template-columns:1fr}.preview-header{align-items:flex-start;flex-direction:column;gap:15px}.preview-actions{flex-direction:column;width:100%}.preview-actions button{width:100%}.input-methods{grid-template-columns:1fr}.voice-input-area{margin-top:12px}}.student-feedback-card{background:#fff;border:3px solid #ffd73d80;border-radius:24px;box-shadow:0 12px 48px #ff6b3540;margin:20px auto;max-width:600px;opacity:0;overflow:hidden;transform:translateY(20px);transition:all .5s ease}.student-feedback-card.visible{opacity:1;transform:translateY(0)}.feedback-header{align-items:flex-start;background:linear-gradient(135deg,#ffd93d,#ff8c42 50%,#ff6b35);color:#fff;display:flex;justify-content:space-between;overflow:hidden;padding:28px;position:relative}.feedback-header:before{animation:rotate 20s linear infinite;content:"🌟";font-size:8rem;opacity:.1;position:absolute;right:-20px;top:-20px}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.header-info h2{font-size:1.6rem;font-weight:700;margin:0 0 8px;text-shadow:0 2px 8px #0003}.header-info h2:before{content:"✨ "}.session-date{font-size:1.1rem;font-weight:500;margin:4px 0;opacity:.95}.session-type{background:#fff3;border-radius:12px;display:inline-block;font-size:.95rem;font-weight:400;margin:8px 0 4px;opacity:.9;padding:4px 12px}.close-btn{align-items:center;background:#ffffff40;border:2px solid #ffffff80;border-radius:50%;color:#fff;display:flex;font-size:1.3rem;font-weight:700;height:36px;justify-content:center;transition:all .2s ease;width:36px}.close-btn:hover{background:#fff6;transform:rotate(90deg) scale(1.1)}.progress-section{background:linear-gradient(135deg,#fff9e6,#ffe8cc);border-bottom:2px solid #ffd93d;padding:24px 28px}.progress-label{color:#ff6b35;display:flex;font-size:1rem;font-weight:600;justify-content:space-between;margin-bottom:10px}.progress-label .hours{color:#ff8c42;font-size:1.1rem;font-weight:700}.progress-label .hours:after{content:" 💪"}.progress-bar{background:#ff8c4233;border-radius:8px;box-shadow:inset 0 2px 4px #0000001a;height:12px}.progress-fill{animation:shimmer 2s ease-in-out infinite;background:linear-gradient(90deg,#ffd93d,#ff8c42 50%,#ff6b35);border-radius:8px;box-shadow:0 2px 8px #ff8c4266;transition:width 1.5s ease}@keyframes shimmer{0%,to{opacity:1}50%{opacity:.85}}.feedback-section{animation:fadeInUp .6s ease forwards;border-bottom:2px solid #fff3e0;opacity:0;padding:28px}.feedback-section:nth-child(3){animation-delay:.1s;background:linear-gradient(135deg,#fffbf0,#fff9e6)}.feedback-section:nth-child(4){animation-delay:.2s;background:linear-gradient(135deg,#fff9e6,#fff3e0)}.feedback-section:nth-child(5){animation-delay:.3s;background:linear-gradient(135deg,#fff3e0,#ffe8cc)}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}0%{opacity:0;transform:translateY(10px)}}.feedback-section h3{align-items:center;display:flex;font-size:1.3rem;font-weight:700;gap:8px;margin:0 0 16px}.section-content{display:flex;flex-direction:column;gap:14px}.highlights h3{color:#ff8c42;text-shadow:0 2px 4px #ff8c4233}.highlight-item{background:#e8f5e9;border-left:4px solid #4caf50;border-radius:6px;color:#333;line-height:1.6;margin:0;padding:12px 16px}.notices h3{color:#ff9800}.notice-item{background:#fff3e0;border-left:4px solid #ff9800;border-radius:6px;padding:16px}.notice-text{color:#333;line-height:1.6;margin:0 0 12px}.pro-tip{background:#ffffffb3;border-radius:6px;display:flex;flex-direction:column;gap:6px;margin-bottom:10px;padding:10px 12px}.tip-label{color:#f57c00;font-size:.85rem;font-weight:700}.tip-text{color:#555;font-size:.9rem;line-height:1.5}.mantra{align-items:center;background:linear-gradient(135deg,#ffd54f20,#ffb30020);border:1px dashed #ff9800;border-radius:6px;display:flex;gap:8px;padding:10px 12px}.mantra-icon{font-size:1.2rem}.mantra-text{color:#e65100;font-size:.95rem;font-style:italic;font-weight:600}.goals h3{color:#2196f3}.goal-item{align-items:flex-start;background:#e3f2fd;border-left:4px solid #2196f3;border-radius:6px;display:flex;gap:12px;padding:12px 16px}.goal-number{align-items:center;background:#2196f3;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.85rem;font-weight:700;height:24px;justify-content:center;width:24px}.goal-text{color:#333;flex:1 1;line-height:1.6}.feedback-footer{align-items:center;background:#fafafa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.instructor-info,.next-session{align-items:center;display:flex;font-size:.9rem;gap:6px}.instructor-label,.next-label{color:#666}.instructor-name{color:#667eea;font-weight:700}.next-date{color:#333;font-weight:600}.action-buttons{display:flex;gap:12px;padding:20px 24px}.action-buttons button{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:12px 20px;transition:all .3s ease}.btn-save{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-save:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-share{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-share:hover{box-shadow:0 4px 12px #4caf5066;transform:translateY(-2px)}@media (max-width:768px){.student-feedback-card{border-radius:12px;margin:10px}.feedback-header{padding:20px}.header-info h2{font-size:1.3rem}.feedback-section{padding:20px}.feedback-footer{align-items:flex-start;gap:12px}.action-buttons,.feedback-footer{flex-direction:column}.action-buttons button{width:100%}}@media print{.student-feedback-card{border:1px solid #e0e0e0;box-shadow:none}.action-buttons,.close-btn{display:none}.feedback-header{background:#667eea!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}}.demo-page{background:linear-gradient(135deg,#ffd93d,#ff8c42 50%,#ff6b35);display:flex;flex-direction:column;min-height:100vh;position:relative}.demo-page:before{background-image:radial-gradient(circle at 20% 50%,#ffffff1a 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff1a 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.demo-nav{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:3px solid #ff8c42;box-shadow:0 4px 20px #ff6b3533;justify-content:space-between;padding:16px 32px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.demo-nav,.nav-brand{align-items:center;display:flex}.nav-brand{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff8c42,#ff6b35);-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:700;gap:8px}.nav-brand:before{content:"🚗";filter:drop-shadow(0 2px 4px rgba(255,140,66,.3));font-size:1.8rem}.nav-links{display:flex;gap:16px}.nav-links button{background:linear-gradient(135deg,#ff8c42,#ff6b35);border:2px solid #0000;border-radius:25px;box-shadow:0 4px 15px #ff8c424d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:10px 24px;transition:all .3s ease}.nav-links button:hover{background:linear-gradient(135deg,#ff6b35,#ff8c42);box-shadow:0 6px 25px #ff8c4280;transform:translateY(-2px)}.nav-links button.active{background:#fff;border-color:#ff8c42;box-shadow:0 4px 15px #ff8c4233;color:#ff8c42}.nav-links button:hover{background:#f0f0f0}.nav-links button.active{background:linear-gradient(135deg,#667eea20,#764ba220);border-color:#667eea;color:#667eea;font-weight:700}.demo-content{flex:1 1;padding:32px;position:relative;z-index:1}.overview-section{margin:0 auto;max-width:1200px}.hero{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:3px solid #fffc;border-radius:24px;box-shadow:0 8px 32px #ff6b3533;margin-bottom:40px;padding:60px 20px;text-align:center}.hero h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff8c42,#ff6b35);-webkit-background-clip:text;background-clip:text;font-size:3rem;margin:0 0 16px}.hero h1:before{content:"🌟 "}.hero h1:after{content:" 🌟"}.tagline{color:#ff6b35;font-size:1.3rem;font-weight:600;margin:8px 0 0}.tagline:before{content:"💪 "}.system-status{margin-bottom:40px}.system-status h2{color:#fff;font-size:2rem;margin-bottom:24px;text-align:center;text-shadow:0 2px 8px #ff6b354d}.system-status h2:before{content:"🚀 "}.status-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.status-card{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:2px solid #fffc;border-radius:20px;box-shadow:0 8px 24px #ff6b3533;display:flex;gap:20px;padding:30px}.status-card:hover{border-color:#ff8c42;box-shadow:0 12px 40px #ff6b3559;transform:translateY(-8px) scale(1.02)}.status-icon{animation:bounce 2s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(255,140,66,.3));font-size:3.5rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.status-info h3{color:#ff6b35;font-size:1.1rem;margin:0 0 8px}.status-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#ff8c42,#ff6b35);-webkit-background-clip:text;background-clip:text;font-size:2rem;font-weight:700}.status-detail{color:#666;font-size:.9rem;margin:0}.features-section{margin-bottom:40px}.features-section h2{color:#333;font-size:2rem;margin-bottom:32px;text-align:center}.features-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.feature-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:28px;transition:all .3s ease}.feature-card:hover{box-shadow:0 8px 24px #00000026;transform:translateY(-4px)}.feature-card h3{color:#667eea;font-size:1.3rem;margin:0 0 12px}.feature-card p{color:#555;line-height:1.6;margin:0 0 16px}.feature-card ul{color:#666;margin:0;padding-left:20px}.feature-card li{line-height:1.5;margin-bottom:8px}.batch-summary{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:40px;padding:32px}.batch-summary h2{color:#333;font-size:1.8rem;margin:0 0 24px}.batch-list{display:flex;flex-direction:column;gap:12px}.batch-item{grid-gap:16px;align-items:center;background:#f8f9ff;border-left:4px solid #667eea;border-radius:8px;display:grid;gap:16px;grid-template-columns:120px 1fr 100px 100px;padding:16px 20px}.batch-item.completed{opacity:1}.batch-number{color:#667eea;font-weight:700}.batch-name{color:#333}.batch-count{color:#666;font-weight:600;text-align:center}.batch-status{font-size:.9rem;text-align:center}.demo-actions{display:flex;gap:20px;justify-content:center;margin-top:40px}.demo-btn{align-items:center;border:none;border-radius:30px;cursor:pointer;display:flex;font-size:1.1rem;font-weight:700;gap:10px;padding:16px 32px;transition:all .3s ease}.demo-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 16px #667eea66;color:#fff}.demo-btn.primary:hover{box-shadow:0 8px 24px #667eea80;transform:translateY(-2px)}.demo-btn.secondary{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 4px 16px #4caf5066;color:#fff}.demo-btn.secondary:hover{box-shadow:0 8px 24px #4caf5080;transform:translateY(-2px)}.feedback-modal{align-items:center;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;left:0;position:absolute;right:0;top:0}.feedback-modal .student-feedback-card{max-height:90vh;overflow-y:auto;position:relative;z-index:1001}.demo-footer{background:#fff;border-top:1px solid #e0e0e0;margin-top:auto;padding:24px}.demo-footer p{color:#666;font-size:.9rem;margin:4px 0}@media (max-width:768px){.demo-nav{flex-direction:column;gap:12px;padding:12px 16px}.nav-brand{font-size:1.2rem}.nav-links{justify-content:space-around;width:100%}.nav-links button{font-size:.9rem;padding:6px 12px}.demo-content{padding:16px}.hero h1{font-size:2rem}.tagline{font-size:1rem}.batch-item,.features-grid,.status-grid{grid-template-columns:1fr}.batch-item{gap:8px}.batch-count,.batch-status{text-align:left}.demo-actions{flex-direction:column;width:100%}.demo-btn{justify-content:center;width:100%}}.batch-item,.feature-card,.status-card{animation:fadeIn .6s ease forwards}.status-card:nth-child(2){animation-delay:.1s}.status-card:nth-child(3){animation-delay:.2s}.status-card:nth-child(4){animation-delay:.3s}.feature-card:nth-child(2){animation-delay:.1s}.feature-card:nth-child(3){animation-delay:.2s}.feature-card:nth-child(4){animation-delay:.3s}.batch-item:nth-child(2){animation-delay:.1s}.batch-item:nth-child(3){animation-delay:.2s}.batch-item:nth-child(4){animation-delay:.3s}.batch-item:nth-child(5){animation-delay:.4s}.traffic-light-container{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:16px}.traffic-light-main{display:flex;flex-direction:column;gap:8px}.traffic-light-btn{align-items:center;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:12px;overflow:hidden;padding:14px 24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.traffic-light-btn.draft{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fca5a5;color:#991b1b}.traffic-light-btn.draft:hover:not(:disabled){background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#f87171;box-shadow:0 8px 16px #ef444433;transform:translateY(-2px)}.traffic-light-btn.published{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac;color:#166534}.traffic-light-btn.published:hover:not(:disabled){background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#4ade80;box-shadow:0 8px 16px #22c55e33;transform:translateY(-2px)}.traffic-light-btn.processing{cursor:wait;opacity:.7}.traffic-light-btn:disabled{cursor:not-allowed;opacity:.5}.status-icon{animation:pulse 2s ease-in-out infinite;font-size:24px;line-height:1}.traffic-light-btn.published .status-icon{animation:glow 2s ease-in-out infinite}@keyframes glow{0%,to{opacity:1;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}.status-label{flex:1 1;text-align:left}.spinner{border-top-color:initial;height:20px;width:20px}.status-description{color:#64748b;font-size:14px;padding:0 8px}.draft-hint,.published-hint{border-radius:6px;display:inline-block;font-weight:500;padding:6px 12px}.draft-hint{background:#fef2f2;color:#991b1b}.published-hint{background:#f0fdf4;color:#166534}.traffic-light-recall{margin-top:4px}.recall-btn{background:linear-gradient(135deg,#fafafa,#f5f5f5);border:2px solid #d4d4d4;border-radius:8px;color:#525252;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s;width:100%}.recall-btn:hover:not(:disabled){background:linear-gradient(135deg,#f5f5f5,#e5e5e5);border-color:#a3a3a3;box-shadow:0 4px 12px #0000001a;color:#171717;transform:translateY(-1px)}.recall-btn:disabled{cursor:not-allowed;opacity:.5}.recall-confirm-overlay{align-items:center;animation:fadeIn .2s;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.recall-confirm-modal{animation:slideUp .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:80vh;max-width:500px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.recall-confirm-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.recall-confirm-header h3{color:#dc2626;font-size:20px;font-weight:700;margin:0}.close-btn{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:24px;line-height:1;padding:4px;transition:color .2s}.close-btn:hover{color:#374151}.recall-confirm-body{padding:24px}.recall-warning{color:#374151;font-size:15px;line-height:1.6;margin:0 0 16px}.recall-warning strong{color:#dc2626}.recall-impact{background:#fef2f2;border-radius:8px;list-style:none;margin:16px 0;padding:16px}.recall-impact li{align-items:center;color:#991b1b;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 0}.recall-confirm-question{color:#1f2937;font-size:16px;font-weight:600;margin:16px 0 0}.recall-confirm-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;padding:20px 24px}.btn-cancel,.btn-recall-confirm{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-cancel{background:#f3f4f6;color:#374151}.btn-cancel:hover:not(:disabled){background:#e5e7eb}.btn-recall-confirm{background:#dc2626;color:#fff}.btn-recall-confirm:hover:not(:disabled){background:#b91c1c;box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.btn-cancel:disabled,.btn-recall-confirm:disabled{cursor:not-allowed;opacity:.5}@media (max-width:640px){.traffic-light-container{padding:12px}.traffic-light-btn{font-size:14px;padding:12px 16px}.status-icon{font-size:20px}.recall-confirm-modal{margin:16px;width:95%}.recall-confirm-body,.recall-confirm-header{padding:16px}.recall-confirm-actions{flex-direction:column;padding:16px}}.traffic-light-container.compact{background:#0000;border:none;padding:8px 12px}.traffic-light-container.compact,.traffic-light-container.compact .traffic-light-main{align-items:center;flex-direction:row}.traffic-light-container.compact .traffic-light-btn{font-size:13px;min-width:120px;padding:6px 12px}.traffic-light-container.compact .status-icon{font-size:16px}.traffic-light-container.compact .status-description{display:none}.traffic-light-container.compact .recall-btn{font-size:12px;min-width:80px;padding:6px 12px}.office-panel{margin:0 auto;max-width:1400px;padding:20px}.panel-header{margin-bottom:30px}.panel-header h1{color:#2c3e50;font-size:2rem;font-weight:600}.section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px;padding:24px;transition:box-shadow .3s}.section:hover{box-shadow:0 4px 12px #00000014}.section h2{border-bottom:2px solid #ecf0f1;color:#34495e;font-size:1.5rem;font-weight:600;margin-bottom:20px;padding-bottom:12px}.section h3{color:#555;font-size:1.1rem;font-weight:500;margin:16px 0 12px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.form-group label{font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px 12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#3498db}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f8f9fa;cursor:not-allowed}.button{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .3s}.button-primary{background:linear-gradient(135deg,#5a67d8,#6b46c1);color:#fff;overflow:hidden;position:relative}.button-primary:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.button-primary:hover:before{left:100%}.button-primary:hover{box-shadow:0 4px 12px #5a67d84d;transform:translateY(-2px)}.button-primary:active{transform:translateY(-1px)}.button-secondary{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border:2px solid #cbd5e0;color:#34495e}.button-secondary:hover{background:linear-gradient(135deg,#e2e8f0,#a0aec0);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.button-secondary:active{transform:translateY(0)}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:20px}.stat-card{background:linear-gradient(135deg,#5a67d8,#6b46c1);border-radius:8px;color:#fff;padding:20px;text-align:center}.stat-card h4{font-size:.9rem;margin-bottom:8px;opacity:.9}.stat-card .stat-value{font-size:2rem;font-weight:700}.placeholder-section{color:#7f8c8d;padding:60px 20px;text-align:center}.placeholder-section .icon{font-size:3rem;margin-bottom:16px}.placeholder-section h3{color:#555;font-size:1.3rem;margin-bottom:8px}.placeholder-section p{color:#95a5a6;font-size:1rem}@media (max-width:768px){.office-panel{padding:12px}.panel-header h1{font-size:1.5rem}.form-grid,.stats-grid{grid-template-columns:1fr}}.coach-calendar{background:#f5f5f5;min-height:100vh;padding-bottom:80px}.calendar-header{background:linear-gradient(135deg,#4a90e2,#357abd);box-shadow:0 2px 8px #0000001a;color:#fff;padding:20px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-top{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.header-top h1{font-size:1.5rem;margin:0}.view-toggle{display:flex;gap:8px}.view-toggle button{background:#fff3;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:8px 16px;transition:all .3s ease}.view-toggle button.active{background:#fff;color:#4a90e2}.date-selector{align-items:center;background:#ffffff26;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px}.date-selector .current-date{font-size:1.1rem;font-weight:600}.btn-next,.btn-prev{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:36px;justify-content:center;transition:all .3s ease;width:36px}.btn-next:hover,.btn-prev:hover{background:#ffffff4d}.day-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.summary-item{align-items:center;background:#ffffff26;border-radius:10px;flex-direction:column;gap:4px;padding:12px}.summary-item .label{font-size:.85rem;opacity:.9}.summary-item .value{font-size:1.3rem;font-weight:700}.calendar-body{padding:16px}.sessions-timeline{display:flex;flex-direction:column;gap:16px}.session-block{background:#fff;border-left:6px solid #4a90e2;border-radius:16px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s ease}.session-block.confirmed{border-left-color:#2ecc71}.session-block.pending{border-left-color:#ffd93d}.session-block:active{transform:scale(.98)}.session-time-bar{align-items:center;background:linear-gradient(135deg,#fff9e6,#fff3e0);border-bottom:1px solid #ffe8cc;display:flex;justify-content:space-between;padding:12px 16px}.time-start{color:#ff6b35;font-size:1.3rem;font-weight:700}.time-duration{background:#fff;border-radius:12px;color:#999;font-size:.9rem;padding:4px 12px}.session-content{padding:16px}.session-header-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.student-name{color:#333;font-size:1.2rem;margin:0}.status-badge{border-radius:16px;font-size:.85rem;font-weight:600;padding:4px 12px;white-space:nowrap}.status-badge.confirmed{background:#e8f8f1;color:#2ecc71}.status-badge.pending{background:#fff9e6;color:#ff8c42}.session-details{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.detail-row{align-items:center;color:#666;display:flex;font-size:.95rem;gap:10px}.detail-row .icon{font-size:1.1rem;text-align:center;width:24px}.detail-row .text{flex:1 1}.detail-row .text.progress{color:#4a90e2;font-weight:600}.detail-row.notes{background:#f8f9fa;border-radius:8px;margin-top:6px;padding:10px}.detail-row.notes .text{color:#ff8c42;font-style:italic}.session-actions{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.btn-action{border:none;border-radius:10px;box-shadow:0 2px 6px #0000001a;cursor:pointer;font-size:.95rem;font-weight:600;padding:12px;transition:all .3s ease}.btn-action:active{transform:scale(.95)}.btn-start{background:linear-gradient(135deg,#2ecc71,#27ae60);color:#fff;grid-column:1/-1}.btn-complete{background:linear-gradient(135deg,#ff8c42,#ff6b35);color:#fff}.btn-contact{background:linear-gradient(135deg,#4a90e2,#357abd);color:#fff}.floating-actions{bottom:20px;position:fixed;right:20px;z-index:1000}.fab{background:linear-gradient(135deg,#9b59b6,#8e44ad);border:none;border-radius:50px;box-shadow:0 6px 20px #9b59b666;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:16px 24px;transition:all .3s ease}.fab:hover{box-shadow:0 8px 24px #9b59b680;transform:translateY(-4px)}@media (min-width:600px){.session-actions{grid-template-columns:2fr 1fr 1fr}.btn-start{grid-column:1/2}}@media (min-width:1024px){.coach-calendar{margin:0 auto;max-width:1200px}.calendar-header{border-radius:16px 16px 0 0}.sessions-timeline{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}}.student-course-list{background:#f5f5f5;min-height:100vh;padding-bottom:70px}.list-header{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff;padding:24px 16px;text-align:center}.list-header h1{font-size:1.8rem;margin:0 0 8px}.list-header p{font-size:1rem;margin:0;opacity:.95}.filters{grid-gap:12px;background:#fff;border-bottom:1px solid #e0e0e0;display:grid;gap:12px;grid-template-columns:1fr 1fr;padding:16px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{color:#666;font-size:.9rem;font-weight:600}.filter-group select{background:#fff;border:2px solid #e0e0e0;border-radius:10px;font-family:inherit;font-size:.95rem;padding:10px;transition:all .3s ease}.filter-group select:focus{border-color:#9b59b6;outline:none}.course-list{padding:16px}.list-header-bar{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.list-header-bar h2{color:#333;font-size:1.3rem;margin:0}.list-header-bar .count{color:#999;font-size:.9rem}.slots-container{display:flex;flex-direction:column;gap:16px}.slot-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a;overflow:hidden;transition:all .3s ease}.slot-card:active{transform:scale(.98)}.slot-date-badge{background:linear-gradient(135deg,#ffd93d,#ff8c42);color:#fff;font-size:.95rem;font-weight:600;padding:10px 16px;text-align:center}.slot-main{padding:16px}.slot-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.coach-info h3{color:#333;font-size:1.2rem;margin:0 0 6px}.rating{color:#ff8c42;font-size:.9rem;font-weight:600}.slot-time{text-align:right}.time-value{color:#9b59b6;font-size:1.4rem;font-weight:700;line-height:1;margin-bottom:4px}.duration{color:#999;font-size:.85rem}.slot-details{background:#f8f9fa;border-radius:10px;margin-bottom:16px;padding:12px}.detail-item{align-items:center;color:#666;display:flex;font-size:.9rem;gap:10px}.detail-item .icon{font-size:1.1rem;text-align:center;width:24px}.detail-item .text{flex:1 1}.slot-footer{align-items:center;display:flex;gap:12px;justify-content:space-between}.price-info{display:flex;flex-direction:column;gap:4px}.price{color:#2ecc71;font-size:1.5rem}.spots-left{color:#e74c3c;font-size:.85rem;font-weight:600}.btn-book{background:linear-gradient(135deg,#9b59b6,#8e44ad);border:none;border-radius:12px;box-shadow:0 4px 12px #9b59b64d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease;white-space:nowrap}.btn-book:active{transform:scale(.95)}.empty-state{background:#fff;border-radius:16px;padding:60px 20px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:20px}.empty-state h3{color:#333;font-size:1.3rem;margin:0 0 10px}.empty-state p{color:#999;margin:0}.bottom-nav{background:#fff;border-top:1px solid #e0e0e0;bottom:0;box-shadow:0 -2px 10px #0000000d;display:grid;grid-template-columns:repeat(4,1fr);left:0;position:fixed;right:0;z-index:1000}.nav-item{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:10px;transition:all .3s ease}.nav-item .icon{font-size:1.5rem}.nav-item .label{font-size:.75rem}.nav-item.active{color:#9b59b6}.nav-item:active{background:#f5f5f5}@media (min-width:768px){.student-course-list{margin:0 auto;max-width:1200px}.filters{grid-template-columns:repeat(4,1fr)}.slots-container{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.bottom-nav{display:none}}.flexible-calendar{background:#fff;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:100%;width:100%}.calendar-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:16px 20px}.view-switcher{background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;display:flex;gap:4px;padding:4px}.view-btn{background:#0000;border:none;border-radius:4px;color:#5f6368;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.view-btn:hover{background:#f1f3f4}.view-btn.active{background:#1a73e8;color:#fff}.date-navigation{align-items:center;display:flex;gap:8px}.date-navigation button{background:#fff;border:1px solid #dadce0;border-radius:4px;color:#202124;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.date-navigation button:hover{background:#f8f9fa;border-color:#5f6368}.today-btn{color:#1a73e8!important;font-weight:600}.sync-btn{background:#34a853;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.sync-btn:hover{background:#2d8e47}.sync-btn:disabled{background:#dadce0;cursor:not-allowed}.calendar-legend{background:#fff;border-bottom:1px solid #e0e0e0;display:flex;font-size:13px;gap:20px;padding:12px 20px}.legend-item{align-items:center;display:flex;gap:8px}.legend-color{border:1px solid #dadce0;border-radius:4px;height:20px;width:20px}.legend-color.available{background:#e8f5e9;border-color:#4caf50}.legend-color.booked{background:#e3f2fd;border-color:#2196f3}.legend-color.selected{background:#fff3e0;border-color:#ff9800}.legend-color.unavailable{background:#fafafa;border-color:#e0e0e0}.calendar-container{flex:1 1;overflow:auto;padding:20px}.calendar-grid{background:#e0e0e0;border:1px solid #e0e0e0;border-radius:8px;gap:1px;overflow:hidden}.time-axis{background:#fff;flex-shrink:0;width:80px}.time-axis-header{background:#f8f9fa;height:60px}.time-axis-header,.time-label{border-bottom:1px solid #e0e0e0}.time-label{align-items:center;color:#5f6368;display:flex;font-size:12px;font-weight:500;justify-content:center}.day-column{flex:1 1;min-width:120px}.day-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;font-weight:600;height:60px;justify-content:center}.date-header{text-align:center}.date-weekday{color:#5f6368;font-size:11px;margin-bottom:4px;text-transform:uppercase}.date-number{color:#202124;font-size:14px}.day-slots,.time-slot{position:relative}.time-slot{border-bottom:1px solid #e0e0e0}.time-slot.available{background:linear-gradient(135deg,#e8f5e9,#f1f8f2);cursor:pointer}.time-slot.available:hover{background:linear-gradient(135deg,#c8e6c9,#dcedc8);box-shadow:0 2px 8px #4caf504d;transform:scale(1.02);z-index:1}.time-slot.booked{background:linear-gradient(135deg,#e3f2fd,#f1f7fd);cursor:default}.time-slot.selected{background:linear-gradient(135deg,#fff3e0,#ffe0b2);box-shadow:inset 0 0 0 2px #ff9800}.time-slot.unavailable{background:#fafafa}.slot-content{display:flex;flex-direction:column;height:100%;justify-content:center;padding:8px}.slot-time{color:#202124;font-size:12px;font-weight:600;margin-bottom:4px}.slot-status{color:#4caf50;font-size:11px;font-weight:500}.slot-info{color:#5f6368;font-size:10px;line-height:1.4}.slot-info>div{margin-bottom:2px}.calendar-month-view{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.month-day-column{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.month-day-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;font-size:12px;font-weight:600;padding:8px;text-align:center}.month-day-slots{display:flex;flex-direction:column;gap:2px;padding:4px}.month-day-slots .time-slot{border:none;border-radius:4px;min-height:24px}.month-day-slots .slot-content{font-size:10px;padding:4px}.selected-slot-info{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;bottom:20px;box-shadow:0 4px 16px #00000026;min-width:280px;padding:20px;position:fixed;right:20px;z-index:1000}@keyframes slideIn{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.selected-slot-info h4{color:#202124;font-size:16px;margin:0 0 12px}.selected-slot-info p{color:#5f6368;font-size:14px;margin:8px 0}.confirm-btn{background:#1a73e8;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:16px;padding:12px;transition:all .2s;width:100%}.confirm-btn:hover{background:#1557b0;box-shadow:0 2px 8px #1a73e84d}.booking-rules{background:#f8f9fa;border-top:1px solid #e0e0e0;margin-top:auto;padding:20px}.booking-rules h4{color:#202124;font-size:14px;margin:0 0 12px}.booking-rules ul{color:#5f6368;font-size:13px;line-height:1.8;margin:0;padding-left:20px}@media (max-width:768px){.calendar-toolbar{align-items:stretch;flex-direction:column}.date-navigation,.view-switcher{justify-content:center}.calendar-grid{overflow-x:auto}.time-axis{width:60px}.day-column{min-width:100px}.selected-slot-info{bottom:20px;left:20px;right:20px}}.calendar-container::-webkit-scrollbar{height:8px;width:8px}.calendar-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.calendar-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.calendar-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.sms-consent{background:#fff9c4;border:2px solid #fbc02d;border-radius:8px;margin:20px 0;padding:20px}.sms-consent.compact{background:#f5f5f5;border:1px solid #e0e0e0;padding:12px}.consent-checkbox{align-items:flex-start;display:flex;gap:12px;margin-bottom:16px}.consent-checkbox input[type=checkbox]{cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.consent-checkbox label{color:#333;cursor:pointer;font-size:16px;font-weight:600;line-height:1.5}.required-mark{color:#f44336;margin-left:4px}.consent-details{padding-left:32px}.consent-text{color:#555;font-size:14px;line-height:1.6;margin-bottom:16px}.consent-terms{background:#fff;border-radius:6px;margin:16px 0;padding:16px}.term-item{align-items:flex-start;display:flex;font-size:14px;gap:12px;line-height:1.5;margin-bottom:12px}.term-item:last-child{margin-bottom:0}.term-icon{flex-shrink:0;font-size:18px}.term-text{color:#555}.term-text strong{color:#333;font-weight:600}.term-text code{background:#f5f5f5;border-radius:3px;color:#d32f2f;font-family:Courier New,monospace;font-size:13px;font-weight:600;padding:2px 6px}.consent-links{color:#555;font-size:14px;margin:16px 0}.consent-links a{color:#1a73e8;font-weight:500;text-decoration:none}.consent-links a:hover{text-decoration:underline}.consent-highlight{background:#e8f5e9;border-left:4px solid #4caf50;border-radius:4px;color:#2e7d32;font-size:14px;margin-top:16px;padding:12px}.consent-highlight strong{font-weight:600}.sms-consent.compact .consent-checkbox{margin-bottom:8px}.sms-consent.compact .consent-checkbox label{font-size:14px;font-weight:500}.consent-details-compact{padding-left:32px}.consent-text-small{color:#666;font-size:12px;line-height:1.5;margin:0}.consent-text-small a{color:#1a73e8;margin:0 4px;text-decoration:none}.consent-text-small a:hover{text-decoration:underline}@media (max-width:768px){.sms-consent{padding:16px}.consent-details,.consent-details-compact{padding-left:0}.consent-checkbox{align-items:flex-start;flex-direction:row}.consent-checkbox input[type=checkbox]{margin-top:4px}.term-item{flex-direction:column;gap:4px}.term-icon{font-size:16px}}@media print{.sms-consent{background:#fff;border:1px solid #999}.consent-terms{border:1px solid #ddd}.consent-highlight{background:#fff;border:1px solid #4caf50}}.student-booking-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;margin:0 auto;max-width:1400px;padding:20px}.page-header{margin-bottom:30px;text-align:center}.page-header h1{color:#2c3e50;font-size:2.2rem;margin-bottom:10px}.page-header .subtitle{color:#7f8c8d;font-size:1.1rem}.student-info-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 6px #0000001a;color:#fff;margin-bottom:25px;padding:25px}.student-info-card h2{font-size:1.4rem;margin-bottom:20px;margin-top:0}.info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{display:flex;flex-direction:column;gap:5px}.info-item label{font-size:.85rem;opacity:.9}.info-item span{font-size:1.1rem;font-weight:700}.important-notice{background:linear-gradient(135deg,#fff9e6,#fff3e0);border:2px solid #ffd93d;border-radius:12px;margin-bottom:30px;padding:20px}.important-notice h3{align-items:center;color:#e67e22;display:flex;gap:8px;margin-bottom:15px;margin-top:0}.important-notice ul{margin:0;padding-left:20px}.important-notice li{color:#666;line-height:1.6;margin-bottom:10px}.important-notice li strong{color:#e67e22}.booking-content-full{display:flex;flex-direction:column;gap:30px;margin-bottom:30px}.week-calendar-section{background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:25px}.week-calendar-section h2{color:#2c3e50;font-weight:500;margin-bottom:10px;margin-top:0}.week-calendar-section .hint{align-items:center;background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;color:#7f8c8d;display:flex;font-size:.95rem;gap:8px;margin-bottom:20px;padding:12px 15px}.week-calendar-section .hint:before{content:"💡";font-size:1.2rem}.week-calendar-grid{grid-gap:1px;background:#e0e0e0;border:1px solid #e0e0e0;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow-x:auto}@media (max-width:1200px){.week-calendar-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){.week-calendar-grid{grid-template-columns:repeat(2,1fr)}}.day-column{background:#fff;min-height:400px;min-width:140px;overflow:hidden;transition:all .2s}.day-column:hover{background:#f8f9fa}.day-column.selected{background:#e8f4fd;box-shadow:inset 0 0 0 2px #4a90e2}.day-column.today{background:#fff9e6}.day-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;cursor:pointer;padding:15px 10px;position:-webkit-sticky;position:sticky;text-align:center;top:0;transition:background .2s;z-index:10}.day-header:hover{background:#e9ecef}.day-column.selected .day-header{background:#4a90e2;color:#fff}.day-column.today .day-header{background:#ffd93d;color:#333;font-weight:600}.day-name{font-size:.75rem;font-weight:500;letter-spacing:.5px;margin-bottom:4px;opacity:.8;text-transform:uppercase}.day-column.today .day-name{color:#e67e22;font-weight:700}.day-date{font-size:1.5rem;font-weight:400}.badge{border-radius:12px;display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.5px;margin-top:6px;padding:3px 10px;text-transform:uppercase}.today-badge{background:#e67e22;color:#fff}.tomorrow-badge{background:#4a90e2;color:#fff}.time-slots-vertical{background:#fafafa;display:flex;flex-direction:column;gap:6px;padding:10px 8px}.time-slot-compact{align-items:center;background:#fff;border:none;border-left:4px solid #0000;border-radius:4px;box-shadow:0 1px 3px #00000014;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;justify-content:space-between;padding:10px 12px;text-align:left;transition:all .15s}.time-slot-compact.available{background:#f0fff4;border-left-color:#34a853;color:#1e7e34}.time-slot-compact.available:hover{background:#e6f7ed;box-shadow:0 2px 6px #34a85333;transform:translateX(4px)}.time-slot-compact.available.selected{background:#34a853;border-left-color:#2d8e47;box-shadow:0 2px 8px #34a85366;color:#fff}.time-slot-compact.unavailable{background:#f8f9fa;border-left-color:#bdc3c7;color:#95a5a6;cursor:not-allowed;opacity:.5}.time-slot-compact.too-soon{background:#fef5f5;border-left-color:#ea4335;color:#c53030;cursor:not-allowed;position:relative}.time-slot-compact.too-soon:after{content:"🔒";opacity:.6;position:absolute;right:8px}.time-text{font-size:.9rem;font-weight:600}.icon-small{font-size:1rem;margin-left:6px}.booking-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-bottom:30px}@media (max-width:1024px){.booking-content{grid-template-columns:1fr}}.calendar-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:25px}.calendar-section h2{color:#2c3e50;margin-bottom:10px;margin-top:0}.calendar-section .hint{color:#7f8c8d;font-size:.9rem;margin-bottom:20px}.calendar-grid{display:flex;flex-direction:column;gap:20px}.date-card{border:2px solid #e0e0e0;border-radius:10px;overflow:hidden;transition:all .3s}.date-card.selected{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.date-header{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);cursor:pointer;padding:15px;transition:background .3s}.date-card.selected .date-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.date-header h3{font-size:1.2rem;margin:0}.date-header small{font-size:.9rem;opacity:.8}.time-slots{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}.time-slot{background:#fff;border-radius:8px;font-size:.95rem;font-weight:500;padding:12px;transition:all .2s}.time-slot.available{background:linear-gradient(135deg,#f0fff4,#e6f7ed);border-color:#27ae60;color:#27ae60}.time-slot.available:hover{box-shadow:0 4px 8px #27ae604d;transform:translateY(-2px)}.time-slot.available.selected,.time-slot.available:hover{background:linear-gradient(135deg,#27ae60,#229954);color:#fff}.time-slot.available.selected{border-color:#27ae60;box-shadow:0 0 0 3px #27ae6033}.time-slot.unavailable{background:#f5f5f5;border-color:#bdc3c7;color:#95a5a6;cursor:not-allowed;opacity:.6}.booking-form-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:25px}.booking-form-section h2{color:#2c3e50;margin-bottom:20px;margin-top:0}.selected-time-display{background:linear-gradient(135deg,#e8f4fd,#e0f2f7);border:2px solid #4a90e2;border-radius:10px;margin-bottom:25px;padding:20px}.selected-time-display h3{color:#4a90e2;font-size:1.1rem;margin-bottom:15px;margin-top:0}.selected-info p{color:#2c3e50;font-size:.95rem;margin:8px 0}.selected-info strong{color:#4a90e2}.selected-time-display .hint{color:#7f8c8d;font-style:italic;margin:0}.booking-form{display:flex;flex-direction:column;gap:20px}.form-group label{color:#2c3e50;font-weight:600}.form-group input,.form-group select,.form-group textarea{transition:border-color .3s}.form-group textarea{min-height:100px}.form-group .hint{color:#7f8c8d;font-size:.85rem;margin-top:5px}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 6px #667eea4d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:700;padding:16px 32px;transition:all .3s}.btn-submit:hover:not(:disabled){box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.btn-submit:disabled{background:#bdc3c7;box-shadow:none;cursor:not-allowed}.form-footer-note{color:#7f8c8d;font-size:.9rem;line-height:1.6;margin-top:10px;text-align:center}.help-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:30px}.help-section h3{color:#2c3e50;font-size:1.4rem;margin-bottom:25px;margin-top:0}.faq-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.faq-item{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-left:4px solid #667eea;border-radius:10px;padding:20px}.faq-item h4{color:#667eea;font-size:1rem;margin-bottom:12px;margin-top:0}.faq-item p{color:#666;font-size:.9rem;line-height:1.6;margin:0}.calendar-toggle-section{background:#f8f9fa;border-radius:12px;margin:30px 0;padding:20px}.calendar-toggle-section h2{color:#2c3e50;margin-bottom:16px;margin-top:0}.calendar-toggle-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px}.toggle-btn{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;flex:1 1;font-size:15px;font-weight:500;min-width:200px;padding:12px 24px;transition:all .3s ease}.toggle-btn:hover{background:#f1f7fd;border-color:#1a73e8}.toggle-btn.active{background:linear-gradient(135deg,#1a73e8,#0d47a1);border-color:#1a73e8;box-shadow:0 4px 12px #1a73e84d;color:#fff}.calendar-hint{color:#666;font-size:14px;margin:0}.flexible-calendar-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:30px 0;padding:20px}.consent-reminder{border-radius:6px;color:#f44336;font-size:14px;font-weight:500;margin-top:12px;text-align:center}.submit-button:disabled{background:#ccc!important;cursor:not-allowed!important;opacity:.6}.submit-button:disabled:hover{background:#ccc!important;box-shadow:none!important;transform:none!important}@media (max-width:768px){.student-booking-container{padding:15px}.page-header h1{font-size:1.6rem}.faq-grid,.info-grid,.time-slots{grid-template-columns:1fr}.calendar-toggle-buttons{flex-direction:column}.toggle-btn{min-width:auto;width:100%}.flexible-calendar-wrapper{padding:12px}}.vehicle-booking-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;margin:0 auto;max-width:1200px;padding:30px 20px}.booking-header{margin-bottom:40px;text-align:center}.booking-header h1{color:#1a73e8;font-size:32px;margin-bottom:10px}.booking-header .subtitle{color:#666;font-size:16px}.student-package-info{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;margin-bottom:40px;padding:25px}.student-package-info h3{font-size:20px;margin-bottom:20px;margin-top:0}.package-details{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:15px}.package-item{align-items:center;background:#ffffff26;border-radius:8px;display:flex;justify-content:space-between;padding:12px}.package-item.highlight{background:#ffffff40;border:2px solid #ffffff80;font-weight:700}.package-item .label{color:#ffffffe6;font-size:14px}.package-item .value{font-size:18px;font-weight:700}.progress-bar{background:#fff3;border-radius:5px;height:10px;margin:15px 0;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#4caf50,#8bc34a);height:100%;transition:width .3s ease}.package-note{color:#ffffffe6;font-size:14px;margin-top:15px}.package-note a{color:#fff;font-weight:700;text-decoration:underline}.date-selection{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:25px}.date-selection h3{color:#333;margin-bottom:20px;margin-top:0}.date-buttons{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:15px}.date-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:15px 10px;transition:all .3s ease}.date-btn:hover{background:#f0f7ff;border-color:#1a73e8;box-shadow:0 4px 8px #1a73e833;transform:translateY(-2px)}.date-btn.active{background:linear-gradient(135deg,#1a73e8,#0d47a1);border-color:#1a73e8;box-shadow:0 4px 12px #1a73e866;color:#fff}.date-day{font-size:18px;font-weight:700}.date-week{font-size:13px;opacity:.8}.booking-rule{background:#fff3e0;border-left:4px solid #f57c00;border-radius:4px;color:#f57c00;font-size:14px;margin-top:15px;padding:10px}.vehicle-slots-section{margin-bottom:30px}.vehicle-slots-section h3{color:#333;margin-bottom:10px}.selection-hint{color:#666;font-size:14px;margin-bottom:20px}.no-slots{background:#fff3e0;border:2px solid #f57c00;border-radius:12px;color:#f57c00;padding:30px;text-align:center}.no-slots p{margin:10px 0}.vehicle-group{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:25px;overflow:hidden;transition:all .3s ease}.vehicle-group:hover{box-shadow:0 4px 16px #00000026}.vehicle-group-header{align-items:center;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border-bottom:2px solid #ddd;display:flex;gap:15px;padding:20px}.vehicle-icon{font-size:48px;line-height:1}.vehicle-info{flex:1 1}.vehicle-info h4{color:#333;font-size:22px;margin:0 0 8px}.vehicle-description{color:#666;font-size:14px;margin:5px 0}.vehicle-pricing{color:#1a73e8;font-size:15px;font-weight:700;margin:8px 0 0}.time-slot,.time-slots{padding:15px}.time-slot{grid-gap:15px;align-items:center;background:#fafafa;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;display:grid;gap:15px;grid-template-columns:1fr 1fr auto;margin-bottom:12px;transition:all .3s ease}.time-slot:hover{background:#f0f7ff;border-color:#1a73e8;box-shadow:0 2px 8px #1a73e833;transform:translateX(5px)}.time-slot.selected{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#4caf50;box-shadow:0 4px 12px #4caf504d}.slot-time{display:flex;flex-direction:column;gap:5px}.time-range{color:#333;font-size:18px;font-weight:700}.duration{color:#666;font-size:13px}.slot-details{display:flex;flex-direction:column;gap:8px}.location,.vehicle-name{color:#666;font-size:14px}.slot-price{align-items:flex-end;display:flex;flex-direction:column;gap:10px}.price{color:#1a73e8;font-size:24px;font-weight:700}.book-btn{background:linear-gradient(135deg,#1a73e8,#0d47a1);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.book-btn:hover{background:linear-gradient(135deg,#0d47a1,#1a73e8);box-shadow:0 4px 12px #1a73e866;transform:translateY(-2px)}.time-slot.selected .book-btn{background:linear-gradient(135deg,#4caf50,#388e3c)}.booking-details-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:25px}.booking-details-form h3{color:#333;margin-bottom:20px;margin-top:0}.form-group{margin-bottom:25px}.form-group label{color:#333;display:block;font-size:15px;font-weight:700;margin-bottom:10px}.form-group label.required:after{color:#f44336;content:" *"}.form-hint{color:#666;font-size:13px;font-style:italic;margin-top:8px}.session-type-options{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.session-type-btn{background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:14px;padding:12px 15px;text-align:left;transition:all .3s ease}.session-type-btn:hover{background:#f0f7ff;border-color:#1a73e8}.session-type-btn.active{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#4caf50;font-weight:700}.form-select{border:2px solid #e0e0e0;border-radius:8px;font-size:15px;padding:12px;transition:all .3s ease;width:100%}.form-select:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a;outline:none}.language-options{display:flex;flex-wrap:wrap;gap:15px}.radio-label{align-items:center;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:10px 15px;transition:all .3s ease}.radio-label:hover{background:#f0f7ff;border-color:#1a73e8}.radio-label input[type=radio]{cursor:pointer}.radio-label input[type=radio]:checked+span{color:#1a73e8;font-weight:700}.form-textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px;resize:vertical;transition:all .3s ease;width:100%}.form-textarea:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a;outline:none}.sms-consent-section{margin:30px 0}.submit-booking-btn{background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:18px;font-weight:700;margin-top:20px;padding:18px;transition:all .3s ease;width:100%}.submit-booking-btn:hover:not(:disabled){background:linear-gradient(135deg,#388e3c,#4caf50);box-shadow:0 6px 20px #4caf5066;transform:translateY(-2px)}.submit-booking-btn:disabled{background:#9e9e9e;cursor:not-allowed;opacity:.6}.consent-reminder{background:#ffebee;border-left:4px solid #f44336;border-radius:4px;color:#c62828;font-weight:700;margin:15px 0;padding:12px}.booking-summary{background:#e3f2fd;border:2px solid #1a73e8;border-radius:12px;margin-top:20px;padding:20px}.booking-summary h4{color:#0d47a1;margin-bottom:15px;margin-top:0}.summary-item{border-bottom:1px solid #bbdefb;display:flex;justify-content:space-between;padding:10px 0}.summary-item:last-child{border-bottom:none}.summary-label{color:#1565c0;font-weight:700}.summary-value{color:#333;text-align:right}.booking-footer{background:#f5f5f5;border-radius:12px;margin-top:30px;padding:25px}.booking-footer h4{color:#333;margin-bottom:15px;margin-top:0}.booking-footer ul{list-style:none;margin:0;padding:0}.booking-footer li{color:#666;line-height:1.6;padding:10px 0}.booking-footer strong{color:#333}@media (max-width:768px){.vehicle-booking-container{padding:20px 15px}.booking-header h1{font-size:24px}.package-details{grid-template-columns:1fr}.date-buttons{grid-template-columns:repeat(2,1fr)}.time-slot{gap:10px;grid-template-columns:1fr}.slot-price{align-items:center;flex-direction:row;justify-content:space-between;width:100%}.session-type-options{grid-template-columns:1fr}.language-options,.summary-item{flex-direction:column}.summary-item{gap:5px}.summary-value{text-align:left}}.traffic-light-demo{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1200px;padding:40px 20px}.demo-header{border-bottom:3px solid #e5e7eb;margin-bottom:40px;padding-bottom:20px;text-align:center}.demo-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;margin-bottom:10px}.demo-subtitle{color:#6b7280;font-size:1.2rem;margin-bottom:20px}.current-user-info{align-items:center;display:flex;gap:10px;justify-content:center;margin-top:15px}.user-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:6px 16px}.demo-explanation{background:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;margin-bottom:40px;padding:30px}.demo-explanation h2{color:#1f2937;font-size:1.8rem;margin-bottom:20px}.status-guide{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:20px}.status-item{align-items:flex-start;border:2px solid;border-radius:12px;display:flex;gap:15px;padding:20px;transition:all .3s ease}.status-item:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-4px)}.status-item.draft{background:linear-gradient(135deg,#fef2f2,#fee2e2);border-color:#fca5a5}.status-item.published{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac}.status-item.recall{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-color:#d1d5db}.status-item .status-icon{font-size:2.5rem;line-height:1}.status-item h3{color:#1f2937;font-size:1.2rem;margin:0 0 8px}.status-item p{color:#6b7280;font-size:.95rem;margin:4px 0}.demo-sessions{margin-bottom:40px}.demo-sessions h2{color:#1f2937;font-size:1.8rem;margin-bottom:20px}.sessions-list{display:flex;flex-direction:column;gap:20px}.session-card{align-items:center;background:#fff;border:2px solid #0000;border-radius:16px;box-shadow:0 4px 12px #00000014;display:flex;justify-content:space-between;padding:25px;transition:all .3s ease}.session-card:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea33;transform:translateY(-2px)}.session-info h3{color:#1f2937;font-size:1.3rem;margin:0 0 12px}.session-details p{color:#6b7280;font-size:.95rem;margin:6px 0}.session-status{flex-shrink:0;margin-left:30px}.demo-instructions{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fcd34d;border-radius:16px;margin-bottom:40px;padding:30px}.demo-instructions h2{color:#78350f;font-size:1.6rem;margin-bottom:20px;margin-top:0}.demo-instructions ol{margin:0;padding-left:25px}.demo-instructions li{color:#92400e;font-size:1rem;line-height:1.6;margin-bottom:15px}.demo-instructions strong{color:#78350f}.demo-footer{background:#f9fafb;border:2px dashed #d1d5db;border-radius:12px;padding:30px;text-align:center}.demo-footer p{color:#6b7280;font-size:.95rem;margin:8px 0}.demo-footer strong{color:#1f2937}@media (max-width:768px){.traffic-light-demo{padding:20px 15px}.demo-header h1{font-size:2rem}.status-guide{grid-template-columns:1fr}.session-card{align-items:flex-start;flex-direction:column}.session-status{margin-left:0;margin-top:20px;width:100%}.demo-instructions ol{padding-left:20px}}.cdl-backing-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.backing-header{color:#fff;margin-bottom:40px;padding:40px 20px;text-align:center}.backing-header h1{font-size:3rem;margin-bottom:10px;text-shadow:2px 2px 4px #0000004d}.backing-header .subtitle{font-size:1.3rem;margin-bottom:15px;opacity:.95}.maneuvers-grid{grid-template-columns:repeat(auto-fit,minmax(600px,1fr));margin:0 auto 50px;max-width:1400px}.maneuver-card{overflow:hidden}.maneuver-card.selected{box-shadow:0 0 0 3px #4caf50,0 15px 40px #0006}.card-header{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-left:5px solid #4caf50;padding:25px}.card-title-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.card-header h2{color:#2c3e50;font-size:1.8rem;margin:0}.exercise-number{background:#4caf501a;border-radius:20px;color:#4caf50;font-size:.9rem;font-weight:700;padding:5px 15px}.card-meta{align-items:center;display:flex;gap:15px}.difficulty{border-radius:15px;color:#fff;font-size:.85rem;font-weight:700;padding:5px 15px}.hours{color:#666;font-size:.9rem}.card-image{background:#f9f9f9;border-bottom:3px solid #e0e0e0;border-top:3px solid #e0e0e0;overflow:hidden;width:100%}.card-image img{display:block;height:auto;transition:transform .3s ease;width:100%}.maneuver-card:hover .card-image img{transform:scale(1.02)}.card-content{padding:25px}.description{color:#555;font-size:1rem;line-height:1.7;margin-bottom:20px}.specs-row{background:#f8f9fa;border-radius:10px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:15px}.spec-item{align-items:center;color:#555;display:flex;font-size:.95rem;gap:8px}.spec-icon{font-size:1.2rem}.expanded-content h3{align-items:center;color:#2c3e50;display:flex;font-size:1.2rem;gap:10px;margin-bottom:15px}.common-mistakes,.key-points,.variants{margin-bottom:25px}.key-points ul li{color:#4caf50}.common-mistakes ul li,.key-points ul li,.variants ul li{line-height:1.6;margin-bottom:10px}.variants ul li{color:#2196f3}.expanded-content ul{padding-left:0}.expanded-content ul li{padding-left:30px}.expand-btn{background:linear-gradient(135deg,#667eea,#764ba2)}.expand-btn:hover{box-shadow:0 5px 15px #667eea66}.backing-footer{background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000004d;margin:50px auto 0;max-width:1400px;padding:40px}.info-card{border-left:4px solid #4caf50}.info-card ul li:before{color:#4caf50}@media (max-width:768px){.backing-header h1{font-size:2rem}.backing-header .subtitle{font-size:1.1rem}.maneuvers-grid{grid-template-columns:1fr}.card-title-row{align-items:flex-start}.card-title-row,.specs-row{flex-direction:column;gap:10px}.test-info-grid{grid-template-columns:1fr}}@media print{.cdl-backing-container{background:#fff}.backing-header{color:#000}.maneuver-card{page-break-inside:avoid}.expand-btn{display:none}.expanded-content{display:block!important}}.intersection-container{background:linear-gradient(135deg,#1e3c72,#2a5298);min-height:100vh;padding:20px}.intersection-header{color:#fff;margin-bottom:40px;padding:40px 20px;text-align:center}.intersection-header h1{font-size:3rem;margin-bottom:10px;text-shadow:2px 2px 4px #0000004d}.intersection-header .subtitle{font-size:1.3rem;margin-bottom:15px;opacity:.95}.header-badges{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.header-badges .badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:20px;font-size:.9rem;padding:8px 20px}.main-diagram-section{margin:0 auto 50px;max-width:1200px}.diagram-card{background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000004d;padding:30px}.diagram-card h2{color:#2c3e50;font-size:2rem}.diagram-card h2,.diagram-image{margin-bottom:25px;text-align:center}.diagram-image{background:#f5f5f5;border-radius:15px;padding:20px}.diagram-image img{border-radius:10px;box-shadow:0 5px 15px #0003;height:auto;max-width:100%}.diagram-notes{background:#f8f9fa;border-left:4px solid #2196f3;border-radius:10px;padding:20px}.diagram-notes h3{color:#2c3e50;font-size:1.3rem;margin-bottom:15px}.diagram-notes ul{list-style:none;padding:0}.diagram-notes ul li{color:#555;font-size:1rem;padding:8px 0}.maneuvers-section{margin:0 auto 50px;max-width:1400px}.section-title{color:#fff;font-size:2.5rem;margin-bottom:40px;text-align:center;text-shadow:2px 2px 4px #0000004d}.maneuvers-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr))}.maneuver-card{background:#fff;border-left:5px solid #4caf50;border-radius:20px;box-shadow:0 10px 30px #0000004d;cursor:pointer;padding:30px;transition:all .3s ease}.maneuver-card:hover{box-shadow:0 15px 40px #0006;transform:translateY(-5px)}.maneuver-card.selected{box-shadow:0 0 0 3px #ffffff80,0 15px 40px #0006}.maneuver-card .card-header{align-items:center;display:flex;gap:15px;margin-bottom:20px}.maneuver-card .icon{font-size:2.5rem}.maneuver-card h3{color:#2c3e50;flex:1 1;font-size:1.8rem;margin:0}.score-badge{border-radius:20px;color:#fff;font-size:.9rem;font-weight:700;padding:5px 15px}.maneuver-card .description{color:#555;font-size:1rem;line-height:1.7;margin-bottom:20px}.expanded-content{animation:fadeIn .3s ease;border-top:2px solid #e0e0e0;margin-top:25px;padding-top:25px}.expanded-content h4{color:#2c3e50;font-size:1.2rem;margin-bottom:15px;margin-top:20px}.expanded-content h4:first-child{margin-top:0}.expanded-content ul{list-style:none;padding:0}.expanded-content ul li{line-height:1.6;padding:8px 0 8px 30px;position:relative}.key-points ul li{color:inherit}.common-mistakes ul li{color:#f44336}.expand-btn{background:#4caf50;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:700;margin-top:20px;padding:12px;transition:all .3s ease;width:100%}.expand-btn:hover{box-shadow:0 5px 15px #0000004d;transform:scale(1.02)}.intersection-footer{background:#fff;border-radius:20px;box-shadow:0 10px 30px #0000004d;margin:50px auto 0;max-width:1400px;padding:40px}.footer-content h3{color:#2c3e50;font-size:2rem;margin-bottom:30px;text-align:center}.test-info-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:30px}.info-card{background:#f8f9fa;border-left:4px solid #2196f3;border-radius:15px;padding:25px}.info-card h4{color:#2c3e50;font-size:1.3rem;margin-bottom:15px}.info-card ul{list-style:none;padding:0}.info-card ul li{color:#555;line-height:1.6;padding:8px 0 8px 25px;position:relative}.info-card ul li:before{color:#2196f3;content:"▸";font-weight:700;left:0;position:absolute}.footer-note{border-top:2px solid #e0e0e0;color:#666;padding-top:25px;text-align:center}.footer-note p{font-size:.9rem;margin:5px 0}@media (max-width:768px){.intersection-header h1{font-size:2rem}.section-title{font-size:1.8rem}.maneuvers-grid{grid-template-columns:1fr}.maneuver-card .card-header{flex-wrap:wrap}.test-info-grid{grid-template-columns:1fr}}@media print{.intersection-container{background:#fff}.intersection-header,.section-title{color:#000}.maneuver-card{page-break-inside:avoid}.expand-btn{display:none}.expanded-content{display:block!important}}.legal-page{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);min-height:100vh;padding:40px 20px;position:relative}.legal-page:before{background-image:url(/static/media/jslogonotop.b45cade460bf2b4f58f7.png);background-repeat:repeat;background-size:280px auto;content:"";inset:0;opacity:.04;pointer-events:none;position:fixed;z-index:0}.legal-container{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin:0 auto;max-width:1000px;padding:40px;position:relative;z-index:1}.legal-back-btn{align-items:center;background:none;border:1px solid #c3cfe2;border-radius:6px;color:#1a73e8;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;margin-bottom:0;padding:8px 16px;transition:background .15s,border-color .15s}.legal-back-btn:hover{background:#f0f4ff;border-color:#1a73e8}.code-block{background:#f3f4f6;border:1px solid #dde1e8;border-radius:6px;color:#0f1d30;font-family:Courier New,Courier,monospace;font-size:13px;margin:8px 0 12px;overflow-x:auto;padding:10px 16px;word-break:break-all}.legal-container h1{color:#1a73e8;font-size:32px;font-weight:700;margin-bottom:10px;text-align:center}.last-updated{color:#5f6368;font-size:14px;font-style:italic;margin-bottom:30px;text-align:center}.legal-content{color:#202124;line-height:1.8}.language-section{border-bottom:1px solid #e0e0e0;margin-bottom:40px;padding-bottom:30px}.language-section:last-child{border-bottom:none}.language-section h2{color:#1a73e8;font-size:24px;font-weight:600;margin-bottom:16px;margin-top:32px}.language-section h3{color:#34a853;font-size:18px;font-weight:600;margin-bottom:12px;margin-top:24px}.language-section p{font-size:15px;margin-bottom:12px}.language-section ul{margin-bottom:16px;margin-left:24px}.language-section ul li{font-size:15px;margin-bottom:8px}.language-section ul ul{margin-left:20px;margin-top:8px}.critical-section{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border-left:4px solid #ff9800;border-radius:8px;margin:30px 0;padding:24px}.critical-section h2{color:#e65100}.critical-section h3{color:#f57c00}.highlight-text{background:#fff9c4;border-left:3px solid #fbc02d;font-weight:500;padding:12px 16px}.critical-text,.highlight-text{border-radius:6px;margin:16px 0}.critical-text{background:#ffebee;border-left:4px solid #f44336;color:#c62828;font-weight:600;padding:16px}.critical-text strong{color:#b71c1c}.contact-info{background:#e8f5e9;border-left:4px solid #4caf50;border-radius:8px;margin:20px 0;padding:20px}.contact-info p{font-size:15px;margin-bottom:8px}.contact-info strong{color:#2e7d32;font-size:18px}.english-section{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:8px;padding:24px}.english-section h2{color:#1565c0}.acceptance-text{background:#f3e5f5;border:2px solid #9c27b0;border-radius:8px;font-size:16px;margin-top:40px;padding:20px;text-align:center}.acceptance-text strong{color:#6a1b9a}.legal-content a{color:#1a73e8;font-weight:500;text-decoration:none}.legal-content a:hover{text-decoration:underline}@media (max-width:768px){.legal-container{padding:24px}.legal-container h1{font-size:24px}.language-section h2{font-size:20px}.language-section h3{font-size:16px}.language-section p,.language-section ul li{font-size:14px}.contact-info,.critical-section,.critical-text,.highlight-text{padding:16px}}.legal-footer-nav{align-items:center;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-top:40px;padding-top:20px}.legal-footer-links{align-items:center;display:flex;font-size:14px;gap:10px}.legal-footer-links a{color:#1a73e8;font-weight:500;text-decoration:none}.legal-footer-links a:hover{text-decoration:underline}.legal-footer-divider{color:#cbd5e1}@media print{.legal-page{background:#fff}.legal-container{box-shadow:none;padding:20px}.critical-section,.english-section{background:#fff;border:1px solid #ccc}.critical-text,.highlight-text{background:#fff;border:1px solid #999}}.policies-page{background:linear-gradient(180deg,#f8f9fa,#e9ecef);min-height:100vh;padding-bottom:40px}.policies-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 20px #0000001a;color:#fff;padding:40px 20px;text-align:center}.back-button{background:#fff3;border:2px solid #ffffff80;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;margin-bottom:20px;padding:10px 20px;transition:all .3s ease}.back-button:hover{background:#ffffff4d;transform:translateX(-5px)}.policies-header h1{font-size:2.5rem;margin:20px 0 10px}.header-subtitle{font-size:1.1rem;margin:0;opacity:.95}.policies-container{grid-gap:30px;display:grid;gap:30px;margin:40px auto;max-width:1200px;padding:0 20px}.policy-section{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;padding:30px;transition:all .3s ease}.policy-section:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-3px)}.policy-header{align-items:center;border-bottom:3px solid #667eea;display:flex;gap:15px;margin-bottom:25px;padding-bottom:15px}.policy-icon{filter:drop-shadow(2px 2px 4px rgba(0,0,0,.1));font-size:2.5rem}.policy-header h2{color:#2c3e50;font-size:1.8rem;margin:0}.policy-content{grid-gap:20px;display:grid;gap:20px}.policy-item{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;padding:15px}.policy-item h3{color:#667eea;font-size:1.1rem;font-weight:600;margin:0 0 8px}.policy-item p{color:#495057;font-size:1rem;line-height:1.6;margin:0}.policies-footer{background:#fff;border-radius:15px;box-shadow:0 4px 15px #0000001a;margin:40px auto 0;max-width:1200px;padding:30px 20px;text-align:center}.policies-footer p{color:#495057;font-size:1.1rem;line-height:1.8;margin-bottom:20px}.policies-footer strong{color:#667eea;font-weight:600}.back-button-bottom{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:15px 35px;transition:all .3s ease}.back-button-bottom:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}@media (max-width:768px){.policies-header h1{font-size:2rem}.policy-header{flex-direction:column;text-align:center}.policy-header h2{font-size:1.5rem}.policy-item h3{font-size:1rem}.policy-item p{font-size:.95rem}}.generate-token-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:24px}.token-header{color:#fff;margin-bottom:32px;text-align:center}.token-header h1{font-size:2rem;font-weight:700;margin:0 0 8px}.token-header p{font-size:1.1rem;margin:0;opacity:.95}.token-container{margin:0 auto 24px;max-width:700px}.token-form-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;padding:32px}.token-form-card h2{color:#333;font-size:1.5rem;margin:0 0 24px}.token-form{gap:20px}.form-group,.token-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#555;font-size:.95rem}.form-group label strong{color:#333}.required{color:#e74c3c;margin-left:4px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:.95rem;padding:12px;transition:all .3s ease}.form-group textarea{font-family:Courier New,monospace;min-height:120px;resize:vertical}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.helper-text{color:#888;font-size:.85rem;margin-top:-4px}.error-message{background:#fee;border:2px solid #e74c3c;border-radius:8px;color:#c0392b;font-size:.9rem;padding:12px}.generate-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:8px;justify-content:center;padding:16px 24px;transition:all .3s ease}.generate-btn:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.generate-btn:disabled{cursor:not-allowed;opacity:.6}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.token-result-card{background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;padding:32px}.success-header{margin-bottom:24px;text-align:center}.success-icon{display:block;font-size:4rem;margin-bottom:12px}.success-header h2{color:#27ae60;font-size:1.8rem;margin:0}.token-display{background:#f8f9fa;border:2px solid #27ae60;border-radius:12px;margin-bottom:24px;padding:16px}.token-display label{color:#555;display:block;font-weight:600;margin-bottom:8px}.token-value{align-items:center;display:flex;gap:12px}.token-value code{background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#667eea;flex:1 1;font-family:Courier New,monospace;font-size:.9rem;padding:12px;word-break:break-all}.copy-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:10px 16px;transition:all .2s ease;white-space:nowrap}.copy-btn:hover{background:#5568d3;transform:scale(1.05)}.token-info{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:16px}.info-row{border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:8px 0}.info-row:last-child{border-bottom:none}.info-row .label{color:#555;font-weight:600}.info-row .value{color:#333;text-align:right}.learner-list{background:#f0f4ff;border-left:4px solid #667eea;border-radius:4px;margin-bottom:20px;padding:16px}.learner-list strong{color:#333;display:block;margin-bottom:8px}.learner-list ul{color:#555;font-family:Courier New,monospace;margin:0;padding-left:20px}.learner-list li{padding:4px 0}.instructions{background:#fffbea;border-left:4px solid #f39c12;border-radius:4px;margin-bottom:20px;padding:16px}.instructions h3{color:#f39c12;font-size:1.1rem;margin:0 0 12px}.instructions ol{color:#555;margin:0;padding-left:20px}.instructions li{line-height:1.6;padding:4px 0}.instructions strong{color:#333}.reset-btn{background:#95a5a6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 24px;transition:all .3s ease;width:100%}.reset-btn:hover{background:#7f8c8d;transform:translateY(-2px)}.info-panel{background:#fffffff2;border-radius:12px;margin:0 auto;max-width:700px;padding:24px}.info-panel h3{color:#333;font-size:1.2rem;margin:0 0 16px}.info-panel ul{color:#555;margin:0;padding-left:20px}.info-panel li{line-height:1.6;padding:8px 0}.info-panel strong{color:#333}@media (max-width:768px){.generate-token-page{padding:16px}.token-header h1{font-size:1.5rem}.token-form-card,.token-result-card{padding:20px}.token-value{align-items:stretch;flex-direction:column}.copy-btn{width:100%}.info-row{flex-direction:column;gap:4px}.info-row .value{text-align:left}}.database-status-container{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0 auto;max-width:1400px;padding:40px 20px}.status-header{align-items:center;border-bottom:3px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:40px;padding-bottom:20px}.status-header h1{color:#333;font-size:32px;margin:0}.refresh-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.refresh-button:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.error-box{background:#fee;border:2px solid #e33;border-radius:8px;margin-bottom:20px;padding:20px}.error-box h3{color:#c00;margin-top:0}.error-box pre{background:#fff;border-radius:4px;color:#c00;overflow-x:auto;padding:15px}.results-container{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:40px}.status-card{background:#fff;border-left:4px solid #ccc;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:24px;transition:all .3s ease}.status-card.complete{background:linear-gradient(135deg,#fff,#f1f8f4);border-left-color:#4caf50}.status-card.incomplete{background:linear-gradient(135deg,#fff,#fff8f0);border-left-color:#ff9800}.status-card:hover{box-shadow:0 8px 20px #00000026;transform:translateY(-4px)}.status-card h2{align-items:center;color:#333;display:flex;font-size:20px;gap:8px;margin:0 0 16px}.status-content{padding:20px 0;text-align:center}.status-number{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:48px;font-weight:700;margin-bottom:8px}.status-label{color:#666;font-size:16px;font-weight:500}.status-details{border-top:1px solid #e0e0e0;color:#555;font-size:14px;margin-top:16px;padding-top:16px}.status-details div{padding:4px 0}.status-action{background:#fff3e0;border:1px dashed #ff9800;border-radius:6px;margin-top:16px;padding:12px}.status-action code{color:#e65100;display:block;font-family:Courier New,monospace;font-size:13px;padding:4px}.logs-container{background:#1e1e1e;border-radius:12px;box-shadow:0 4px 12px #0003;grid-column:1/-1;padding:24px}.logs-container h2{color:#fff;font-size:20px;margin:0 0 16px}.logs-output{background:#2d2d2d;border-radius:8px;color:#ddd;font-family:Monaco,Courier New,monospace;font-size:13px;line-height:1.6;margin:0;max-height:600px;overflow-x:auto;overflow-y:auto;padding:20px}.logs-output::-webkit-scrollbar{height:8px;width:8px}.logs-output::-webkit-scrollbar-track{background:#1e1e1e;border-radius:4px}.logs-output::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.logs-output::-webkit-scrollbar-thumb:hover{background:#777}.loading-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:60px;width:60px}.loading-overlay p{color:#fff;font-size:18px;font-weight:500;margin-top:20px}@media (max-width:768px){.status-header{align-items:flex-start;flex-direction:column;gap:16px}.status-header h1{font-size:24px}.results-container{grid-template-columns:1fr}.status-number{font-size:36px}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}:root{--primary:#2563eb;--primary-dark:#1e40af;--secondary:#10b981;--danger:#ef4444;--warning:#f59e0b;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-600:#4b5563;--gray-900:#111827}.btn{border-radius:.5rem;font-weight:500;padding:.5rem 1rem;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.btn-primary{--tw-bg-opacity:1;--tw-text-opacity:1;background-color:#2563eb;background-color:rgb(37 99 235/var(--tw-bg-opacity,1));color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.btn-primary:hover{--tw-bg-opacity:1;background-color:#1d4ed8;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.btn-primary:active{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.btn-secondary{--tw-bg-opacity:1;--tw-text-opacity:1;background-color:#e5e7eb;background-color:rgb(229 231 235/var(--tw-bg-opacity,1));color:#1f2937;color:rgb(31 41 55/var(--tw-text-opacity,1))}.btn-secondary:hover{--tw-bg-opacity:1;background-color:#d1d5db;background-color:rgb(209 213 219/var(--tw-bg-opacity,1))}.btn-secondary:active{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.btn-danger{--tw-bg-opacity:1;--tw-text-opacity:1;background-color:#dc2626;background-color:rgb(220 38 38/var(--tw-bg-opacity,1));color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.btn-danger:hover{--tw-bg-opacity:1;background-color:#b91c1c;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.btn-danger:active{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.card{--tw-bg-opacity:1;--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color);background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1));border-radius:.75rem;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);padding:1.5rem}.input{--tw-border-opacity:1;border-color:#d1d5db;border-color:rgb(209 213 219/var(--tw-border-opacity,1));border-radius:.5rem;border-width:1px;padding:.5rem 1rem;width:100%}.input: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);--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1));border-color:#0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000);outline:2px solid #0000;outline-offset:2px}.badge{border-radius:9999px;font-size:.875rem;font-weight:500;line-height:1.25rem;padding:.25rem .75rem}.badge-success{background-color:#dcfce7;background-color:rgb(220 252 231/var(--tw-bg-opacity,1));color:#166534;color:rgb(22 101 52/var(--tw-text-opacity,1))}.badge-success,.badge-warning{--tw-bg-opacity:1;--tw-text-opacity:1}.badge-warning{background-color:#fef9c3;background-color:rgb(254 249 195/var(--tw-bg-opacity,1));color:#854d0e;color:rgb(133 77 14/var(--tw-text-opacity,1))}.badge-danger{--tw-bg-opacity:1;--tw-text-opacity:1;background-color:#fee2e2;background-color:rgb(254 226 226/var(--tw-bg-opacity,1));color:#991b1b;color:rgb(153 27 27/var(--tw-text-opacity,1))}.logo-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.spinner{animation:spin 1s linear infinite;border:3px solid #0000001a;border-radius:50%;border-top:3px solid var(--primary)}@keyframes spin{to{transform:rotate(1turn)}}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100)}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#4b5563;background:var(--gray-600)}@media (max-width:768px){.card{padding:1rem}}
/*# sourceMappingURL=main.3e763e5d.css.map*/