@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";/*! tailwindcss v4.1.3 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:rotateX(0);--tw-rotate-y:rotateY(0);--tw-rotate-z:rotateZ(0);--tw-skew-x:skewX(0);--tw-skew-y:skewY(0);--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-red-100:oklch(93.6% .032 17.717);--color-red-300:oklch(80.8% .114 19.571);--color-red-400:oklch(70.4% .191 22.216);--color-red-500:oklch(63.7% .237 25.331);--color-red-600:oklch(57.7% .245 27.325);--color-orange-100:oklch(95.4% .038 75.164);--color-orange-500:oklch(70.5% .213 47.604);--color-orange-600:oklch(64.6% .222 41.116);--color-yellow-100:oklch(97.3% .071 103.193);--color-yellow-300:oklch(90.5% .182 98.111);--color-yellow-400:oklch(85.2% .199 91.936);--color-yellow-500:oklch(79.5% .184 86.047);--color-yellow-600:oklch(68.1% .162 75.834);--color-yellow-800:oklch(47.6% .114 61.907);--color-green-100:oklch(96.2% .044 156.743);--color-green-300:oklch(87.1% .15 154.449);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-blue-500:oklch(62.3% .214 259.815);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:calc(1/.75);--text-sm:.875rem;--text-sm--line-height:calc(1.25/.875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75/1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--radius-md:.375rem;--radius-lg:.5rem;--shadow-sm:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--ease-out:cubic-bezier(0,0,.2,1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4,0,.6,1)infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.invisible{visibility:hidden}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.top-2{top:calc(var(--spacing)*2)}.right-2{right:calc(var(--spacing)*2)}.right-4{right:calc(var(--spacing)*4)}.bottom-4{bottom:calc(var(--spacing)*4)}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mt-1{margin-top:calc(var(--spacing)*1)}.mt-2{margin-top:calc(var(--spacing)*2)}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-6{margin-top:calc(var(--spacing)*6)}.mt-8{margin-top:calc(var(--spacing)*8)}.mr-2{margin-right:calc(var(--spacing)*2)}.mb-1{margin-bottom:calc(var(--spacing)*1)}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-3{margin-bottom:calc(var(--spacing)*3)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.h-4{height:calc(var(--spacing)*4)}.h-32{height:calc(var(--spacing)*32)}.w-4{width:calc(var(--spacing)*4)}.w-32{width:calc(var(--spacing)*32)}.w-full{width:100%}.max-w-3\/4{max-width:75%}.transform{transform:var(--tw-rotate-x)var(--tw-rotate-y)var(--tw-rotate-z)var(--tw-skew-x)var(--tw-skew-y)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-not-allowed{cursor:not-allowed}.resize{resize:both}.list-disc{list-style-type:disc}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-2{gap:calc(var(--spacing)*2)}.gap-4{gap:calc(var(--spacing)*4)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*2)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*4)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-y-reverse)))}:where(.space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*2)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*2)*calc(1 - var(--tw-space-x-reverse)))}:where(.space-x-4>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing)*4)*var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing)*4)*calc(1 - var(--tw-space-x-reverse)))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-md{border-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-l-2{border-left-style:var(--tw-border-style);border-left-width:2px}.border-l-4{border-left-style:var(--tw-border-style);border-left-width:4px}.border-gray-200{border-color:var(--color-gray-200)}.border-gray-300{border-color:var(--color-gray-300)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-gray-400{background-color:var(--color-gray-400)}.bg-gray-700{background-color:var(--color-gray-700)}.bg-green-100{background-color:var(--color-green-100)}.bg-green-500{background-color:var(--color-green-500)}.bg-orange-100{background-color:var(--color-orange-100)}.bg-red-100{background-color:var(--color-red-100)}.bg-red-500{background-color:var(--color-red-500)}.bg-white{background-color:var(--color-white)}.bg-yellow-100{background-color:var(--color-yellow-100)}.bg-yellow-500{background-color:var(--color-yellow-500)}.p-1{padding:calc(var(--spacing)*1)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.p-4{padding:calc(var(--spacing)*4)}.p-8{padding:calc(var(--spacing)*8)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-3{padding-inline:calc(var(--spacing)*3)}.px-4{padding-inline:calc(var(--spacing)*4)}.py-1{padding-block:calc(var(--spacing)*1)}.py-2{padding-block:calc(var(--spacing)*2)}.pt-2{padding-top:calc(var(--spacing)*2)}.pt-4{padding-top:calc(var(--spacing)*4)}.pl-4{padding-left:calc(var(--spacing)*4)}.pl-5{padding-left:calc(var(--spacing)*5)}.text-center{text-align:center}.text-right{text-align:right}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.break-all{word-break:break-all}.whitespace-nowrap{white-space:nowrap}.text-black{color:var(--color-black)}.text-gray-300{color:var(--color-gray-300)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-green-500{color:var(--color-green-500)}.text-green-600{color:var(--color-green-600)}.text-orange-500{color:var(--color-orange-500)}.text-orange-600{color:var(--color-orange-600)}.text-red-400{color:var(--color-red-400)}.text-red-500{color:var(--color-red-500)}.text-red-600{color:var(--color-red-600)}.text-white{color:var(--color-white)}.text-yellow-400{color:var(--color-yellow-400)}.text-yellow-500{color:var(--color-yellow-500)}.text-yellow-600{color:var(--color-yellow-600)}.text-yellow-800{color:var(--color-yellow-800)}.lowercase{text-transform:lowercase}.italic{font-style:italic}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-300{--tw-duration:.3s;transition-duration:.3s}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}@media (hover:hover){.hover\:bg-gray-200:hover{background-color:var(--color-gray-200)}.hover\:bg-gray-300:hover{background-color:var(--color-gray-300)}.hover\:bg-gray-600:hover{background-color:var(--color-gray-600)}.hover\:bg-gray-700:hover{background-color:var(--color-gray-700)}.hover\:bg-green-600:hover{background-color:var(--color-green-600)}.hover\:bg-red-600:hover{background-color:var(--color-red-600)}.hover\:bg-yellow-600:hover{background-color:var(--color-yellow-600)}}.focus\:border-transparent:focus{border-color:#0000}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-blue-500:focus{--tw-ring-color:var(--color-blue-500)}.focus\:ring-green-300:focus{--tw-ring-color:var(--color-green-300)}.focus\:ring-red-300:focus{--tw-ring-color:var(--color-red-300)}.focus\:ring-yellow-300:focus{--tw-ring-color:var(--color-yellow-300)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}@media (min-width:48rem){.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (prefers-color-scheme:dark){.dark\:border-gray-700{border-color:var(--color-gray-700)}.dark\:bg-gray-800{background-color:var(--color-gray-800)}.dark\:text-gray-400{color:var(--color-gray-400)}}}@keyframes gradientShift{0%,to{background-position:0%}50%{background-position:100%}}.gradient-text{background:linear-gradient(45deg,rgb(var(--color-primary)),rgb(var(--color-secondary)));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}:root{--color-primary:90,79,207;--color-secondary:244,63,94;--color-background:255,255,255;--color-text:17,24,39;--color-text-secondary:107,114,128;color-scheme:light}.dark{--color-primary:129,140,248;--color-secondary:251,113,133;--color-background:17,24,39;--color-text:249,250,251;--color-text-secondary:209,213,219;color-scheme:dark}body{background-color:rgb(var(--color-background));color:rgb(var(--color-text));font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.6;transition:background-color .3s,color .3s}:focus-visible{outline:2px solid rgb(var(--color-primary));outline-offset:2px}.glass-morphism{background:rgba(var(--color-primary),.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(var(--color-primary),.2)}.gradient-text{background:linear-gradient(45deg,rgb(var(--color-primary)),rgb(var(--color-secondary)));-webkit-text-fill-color:transparent;-webkit-background-clip:text}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}.state-active{background-color:rgba(var(--color-primary),.2);color:rgb(var(--color-primary))}.state-hover:hover{background-color:rgba(var(--color-primary),.1);transition:background-color .2s}.accessibility-focus{box-shadow:0 0 0 3px rgba(var(--color-primary),.5)}@property --tw-rotate-x{syntax:"*";inherits:false;initial-value:rotateX(0)}@property --tw-rotate-y{syntax:"*";inherits:false;initial-value:rotateY(0)}@property --tw-rotate-z{syntax:"*";inherits:false;initial-value:rotateZ(0)}@property --tw-skew-x{syntax:"*";inherits:false;initial-value:skewX(0)}@property --tw-skew-y{syntax:"*";inherits:false;initial-value:skewY(0)}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes pulse{50%{opacity:.5}}:root{--color-bg-primary: #ffffff;--color-bg-secondary: #f8fafc;--color-bg-tertiary: #f1f5f9;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--color-accent: #3b82f6;--color-accent-hover: #2563eb;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--sidebar-width: 280px;--header-height: 80px;--border-radius: .75rem;--border-radius-sm: .5rem;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}[data-theme=dark]{--color-bg-primary: #0f172a;--color-bg-secondary: #1e293b;--color-bg-tertiary: #334155;--color-text-primary: #f8fafc;--color-text-secondary: #cbd5e1;--color-text-muted: #94a3b8;--color-border: #334155;--color-border-light: #475569;--color-accent: #60a5fa;--color-accent-hover: #3b82f6}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;transition:background-color var(--transition-normal),color var(--transition-normal)}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg-primary)}.skip-link{position:absolute;top:-40px;left:var(--spacing-md);background-color:var(--color-accent);color:#fff;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;border-radius:var(--border-radius-sm);font-weight:600;z-index:1000;transition:top var(--transition-normal)}.brand{display:flex;align-items:center;gap:10px}.brand-logo{max-width:70px;height:auto}.skip-link:focus{top:var(--spacing-md);outline:2px solid white;outline-offset:2px}.app-header{background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#f8fafcf2}[data-theme=dark] .app-header{background-color:#1e293bf2}.brand{display:flex;flex-direction:column;gap:var(--spacing-xs)}.brand-title{font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,var(--color-accent),var(--color-accent-hover));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.025em}.header-controls{display:flex;align-items:center;gap:var(--spacing-md)}.menu-toggle{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-md)}.menu-toggle:hover{background-color:var(--color-accent-hover);transform:scale(1.05)}.menu-toggle:focus{outline:2px solid var(--color-accent);outline-offset:2px}.app-layout{flex:1;display:flex;position:relative;max-width:1400px;width:100%;margin:0 auto;min-height:calc(100vh - var(--header-height))}.sidebar-container{width:var(--sidebar-width);background-color:var(--color-bg-secondary);border-right:1px solid var(--color-border);transition:transform var(--transition-normal);position:relative;z-index:30}.sidebar-container.closed{transform:translate(-100%)}.sidebar-container.open{transform:translate(0)}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:20;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.main-container{flex:1;display:flex;flex-direction:column;min-width:0;transition:margin-left var(--transition-normal)}.main-container.with-sidebar{margin-left:0}.content-area{flex:1;display:flex;flex-direction:column;padding:var(--spacing-xl);gap:var(--spacing-lg)}.content-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border-light)}.content-title{font-size:2rem;font-weight:700;color:var(--color-text-primary);background:linear-gradient(135deg,var(--color-accent),var(--color-accent-hover));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.025em}.content-body{flex:1;display:flex;flex-direction:column;background-color:var(--color-bg-primary);border-radius:var(--border-radius);box-shadow:var(--shadow-sm);overflow:hidden}@media (max-width: 768px){.header-container{padding:0 var(--spacing-md);height:70px}.brand-title{font-size:1.5rem}.brand-subtitle{font-size:.8rem}.sidebar-container{position:fixed;top:70px;left:0;bottom:0;z-index:30;box-shadow:var(--shadow-xl)}.content-area{padding:var(--spacing-lg)}.content-title{font-size:1.5rem}.menu-toggle{width:40px;height:40px}}@media (max-width: 480px){.header-container{padding:0 var(--spacing-sm);height:60px}.brand-title{font-size:1.25rem}.brand-subtitle{display:none}.content-area{padding:var(--spacing-md)}.content-title{font-size:1.25rem}.sidebar-container{top:60px;width:100vw;max-width:320px}}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-header{animation:slideInFromTop var(--transition-slow)}.sidebar-container{animation:slideInFromLeft var(--transition-slow)}.content-area{animation:fadeIn var(--transition-slow)}*:focus{outline:2px solid var(--color-accent);outline-offset:2px}button:focus,a:focus{outline:2px solid var(--color-accent);outline-offset:2px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}@media (prefers-contrast: high){:root{--color-border: #000000;--color-text-secondary: #000000}[data-theme=dark]{--color-border: #ffffff;--color-text-secondary: #ffffff}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.p-sm{padding:var(--spacing-sm)}.p-md{padding:var(--spacing-md)}.p-lg{padding:var(--spacing-lg)}.m-sm{margin:var(--spacing-sm)}.m-md{margin:var(--spacing-md)}.m-lg{margin:var(--spacing-lg)}.rounded{border-radius:var(--border-radius)}.rounded-sm{border-radius:var(--border-radius-sm)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}@media print{.app-header,.sidebar-container,.menu-toggle,.header-controls{display:none!important}.main-container{margin:0!important;padding:0!important}.content-area{padding:0!important;box-shadow:none!important}.app{background:#fff!important;color:#000!important}}.app-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);opacity:.3}.brand:hover .brand-title{transform:scale(1.02);transition:transform var(--transition-fast)}.content-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--color-accent),var(--color-accent-hover));border-radius:1px}.loading{opacity:.7;pointer-events:none}.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin 1s linear infinite}.sidebar-container,.main-container,.content-area{will-change:transform}.app-header{will-change:background-color}.app.fullscreen .app-header,.app.fullscreen .sidebar-container{display:none}.app.fullscreen .main-container{margin:0;max-width:100%}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:background-color var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg-tertiary)}.header-container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg);height:var(--header-height);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-lg)}.brand-link{text-decoration:none;color:inherit;display:inline-flex;align-items:center}.brand{display:flex;flex-direction:row;align-items:center;gap:var(--spacing-sm)}.brand-logo{max-width:60px;max-height:45px;height:auto;width:auto}.brand-subtitle{font-size:.875rem;color:var(--color-text-secondary);font-weight:500;letter-spacing:.025em}.brand-link:hover .brand-subtitle{text-decoration:underline;color:var(--color-accent)}.brand-link:hover .brand-logo{opacity:.9}@media (max-width: 480px){.brand-subtitle{display:none}.brand-logo{max-width:50px;max-height:40px}.brand{gap:var(--spacing-xs)}}.sidebar{height:100%;display:flex;flex-direction:column;background:linear-gradient(180deg,#f8fafc,#f1f5f9);border-right:1px solid #e2e8f0;overflow:hidden;transition:all .3s ease}.sidebar.dark{background:linear-gradient(180deg,#1e293b,#0f172a);border-right-color:#334155}.sidebar-header{padding:1.5rem;border-bottom:1px solid #e2e8f0;background:#ffffff80}.sidebar.dark .sidebar-header{border-bottom-color:#334155;background:#1e293b80}.sidebar-brand{display:flex;align-items:center;gap:.75rem}.sidebar-brand-icon{color:#3b82f6;flex-shrink:0;max-width:60px}.sidebar.dark .sidebar-brand-icon{color:#60a5fa}.sidebar-brand-text h2{font-size:1.125rem;font-weight:700;color:#1e293b;margin:0;line-height:1.2}.sidebar.dark .sidebar-brand-text h2{color:#f8fafc}.sidebar-brand-text span{font-size:.75rem;color:#64748b;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.sidebar.dark .sidebar-brand-text span{color:#94a3b8}.sidebar-menu{flex:1;padding:1rem;overflow-y:auto}.menu-section{margin-bottom:1.5rem}.menu-section-title{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem;padding:0 .75rem}.sidebar.dark .menu-section-title{color:#94a3b8}.menu-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem}.menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem;background:transparent;border:none;border-radius:.75rem;cursor:pointer;transition:all .2s ease;text-align:left;position:relative;overflow:hidden}.menu-item:hover{background:#3b82f614;transform:translate(2px)}.sidebar.dark .menu-item:hover{background:#60a5fa1a}.menu-item.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.menu-item.active:hover{transform:translate(0);background:linear-gradient(135deg,#2563eb,#1d4ed8)}.menu-item:focus{outline:2px solid #3b82f6;outline-offset:2px}.menu-item-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#ffffff1a;border-radius:.5rem;flex-shrink:0;transition:all .2s ease}.menu-item.active .menu-item-icon{background:#fff3;color:#fff!important}.menu-item-content{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.menu-item-label{font-size:.875rem;font-weight:600;color:#1e293b;line-height:1.2}.sidebar.dark .menu-item-label{color:#f8fafc}.menu-item.active .menu-item-label{color:#fff}.menu-item-description{font-size:.75rem;color:#64748b;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar.dark .menu-item-description{color:#94a3b8}.menu-item.active .menu-item-description{color:#fffc}.menu-item-arrow{opacity:0;transform:translate(-4px);transition:all .2s ease;color:#64748b}.sidebar.dark .menu-item-arrow{color:#94a3b8}.menu-item:hover .menu-item-arrow,.menu-item.active .menu-item-arrow{opacity:1;transform:translate(0)}.menu-item.active .menu-item-arrow{color:#fff}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#ffffff4d}.sidebar.dark .sidebar-footer{border-top-color:#334155;background:#1e293b4d}.sidebar-info{text-align:center}.sidebar-version{font-size:.75rem;font-weight:600;color:#3b82f6;margin:0 0 .25rem}.sidebar.dark .sidebar-version{color:#60a5fa}.sidebar-copyright{font-size:.625rem;color:#64748b;margin:0}.sidebar.dark .sidebar-copyright{color:#94a3b8}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.menu-item{animation:slideInFromLeft .3s ease}.menu-item:nth-child(1){animation-delay:.1s}.menu-item:nth-child(2){animation-delay:.15s}.menu-item:nth-child(3){animation-delay:.2s}.menu-item:nth-child(4){animation-delay:.25s}@media (max-width: 768px){.sidebar{width:100%;max-width:320px}.sidebar-header{padding:1rem}.sidebar-brand-text h2{font-size:1rem}.menu-item{padding:.75rem}.menu-item-icon{width:36px;height:36px}.menu-item-label{font-size:.8rem}.menu-item-description{font-size:.7rem}}@media (max-width: 480px){.sidebar-header{padding:.75rem}.sidebar-brand{gap:.5rem}.sidebar-brand-icon{font-size:1.25rem}.menu-item{padding:.625rem}.menu-item-content{gap:.0625rem}}.menu-item:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.menu-item.loading{pointer-events:none}.menu-item.loading .menu-item-icon:after{content:"";position:absolute;width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.menu-item,.menu-item-arrow,.menu-item-icon{animation:none!important;transition:none!important}}@media (prefers-contrast: high){.menu-item{border:1px solid currentColor}.menu-item.active{border-color:#fff}}.sidebar-menu::-webkit-scrollbar{width:4px}.sidebar-menu::-webkit-scrollbar-track{background:transparent}.sidebar-menu::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:2px}.sidebar-menu::-webkit-scrollbar-thumb:hover{background:#94a3b880}.sidebar.dark .sidebar-menu::-webkit-scrollbar-thumb{background:#94a3b833}.sidebar.dark .sidebar-menu::-webkit-scrollbar-thumb:hover{background:#94a3b866}.menu-item:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.1));opacity:0;transition:opacity .2s ease;border-radius:inherit}.menu-item:hover:before{opacity:1}.menu-item.active:before{background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:1}.menu-item-badge{position:absolute;top:.5rem;right:.5rem;background:#ef4444;color:#fff;font-size:.625rem;font-weight:600;padding:.125rem .375rem;border-radius:9999px;min-width:1.25rem;text-align:center;line-height:1}.menu-item.active:after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:#fff;border-radius:0 2px 2px 0}.theme-toggle-container{position:relative;display:inline-block}.theme-toggle-button{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm, .5rem);padding:var(--spacing-sm, .5rem);background-color:transparent;color:var(--color-text-secondary, #64748b);border:1px solid transparent;border-radius:var(--border-radius-sm, .5rem);cursor:pointer;transition:background-color var(--transition-fast, .15s ease),color var(--transition-fast, .15s ease),border-color var(--transition-fast, .15s ease)}.theme-toggle-button:hover{background-color:var(--color-bg-tertiary, #f1f5f9);color:var(--color-text-primary, #1e293b)}.theme-toggle-button:focus,.theme-toggle-button:focus-visible{outline:2px solid var(--color-accent, #3b82f6);outline-offset:2px;border-color:var(--color-accent, #3b82f6)}[data-theme=dark] .theme-toggle-button{color:var(--color-text-secondary, #cbd5e1)}[data-theme=dark] .theme-toggle-button:hover{background-color:var(--color-bg-tertiary, #334155);color:var(--color-text-primary, #f8fafc)}.theme-dropdown-menu{position:absolute;right:0;margin-top:var(--spacing-xs, .25rem);padding:var(--spacing-sm, .5rem);background-color:var(--color-bg-primary, #ffffff);border:1px solid var(--color-border, #e2e8f0);border-radius:var(--border-radius, .75rem);box-shadow:var(--shadow-lg, 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1));z-index:50;min-width:220px}.theme-options-list{display:flex;flex-direction:column;gap:var(--spacing-xs, .25rem)}.theme-option{display:flex;align-items:center;gap:var(--spacing-md, 1rem);width:100%;padding:var(--spacing-sm, .5rem) var(--spacing-md, 1rem);background-color:transparent;color:var(--color-text-primary, #1e293b);border:none;border-radius:var(--border-radius-sm, .5rem);cursor:pointer;transition:background-color var(--transition-fast, .15s ease),color var(--transition-fast, .15s ease);text-align:left;font-size:.875rem;font-weight:500}[data-theme=dark] .theme-option{color:var(--color-text-primary, #f8fafc)}.theme-option:hover{background-color:var(--color-bg-tertiary, #f1f5f9);color:var(--color-accent-hover, #2563eb)}[data-theme=dark] .theme-option:hover{background-color:var(--color-bg-tertiary, #334155);color:var(--color-accent, #60a5fa)}.theme-option.active{background-color:var(--color-accent, #3b82f6);color:#fff}[data-theme=dark] .theme-option.active{background-color:var(--color-accent, #60a5fa);color:var(--color-bg-primary)}.theme-option:focus,.theme-option:focus-visible{outline:2px solid var(--color-accent, #3b82f6);outline-offset:1px;background-color:var(--color-bg-tertiary, #f1f5f9)}[data-theme=dark] .theme-option:focus,[data-theme=dark] .theme-option:focus-visible{background-color:var(--color-bg-tertiary, #334155)}.theme-option svg{flex-shrink:0;color:var(--color-text-secondary)}.theme-option:hover svg,.theme-option.active svg{color:inherit}.theme-dropdown-footer{padding-top:var(--spacing-sm, .5rem);margin-top:var(--spacing-sm, .5rem);border-top:1px solid var(--color-border-light, #f1f5f9)}[data-theme=dark] .theme-dropdown-footer{border-top-color:var(--color-border-light, #475569)}.theme-dropdown-footer p{font-size:.75rem;color:var(--color-text-muted, #94a3b8);padding:0 var(--spacing-sm, .5rem);line-height:1.4}.chat-container{display:flex;flex-direction:column;height:100%;max-width:64rem;margin:0 auto;width:100%}.chat-container.fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;z-index:50;padding:1rem;max-width:none}.chat-messages-area{flex:1;overflow-y:auto;padding:1rem;border-radius:.5rem;border:1px solid #d1d5db;background-color:#fff;box-shadow:inset 0 2px 4px #0000000f;margin-bottom:1rem;min-height:400px}.dark .chat-messages-area{border-color:#374151;background-color:#1f2937;color:#e5e7eb}.chat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:0 .25rem;gap:.75rem}.chat-title{font-size:1.25rem;font-weight:600;display:flex;align-items:center;color:#3b82f6}.dark .chat-title{color:#60a5fa}.chat-controls{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.message-container{display:flex;width:100%;margin-bottom:1rem}.message-container.user{justify-content:flex-end}.message-container.bot{justify-content:flex-start}.message-content{display:flex;align-items:flex-end;gap:.5rem;max-width:75%}.message-bubble{position:relative;padding:.75rem 1rem;border-radius:1rem 1rem 1rem .25rem;box-shadow:0 1px 3px #0000001a}.message-bubble.user{background-color:#3b82f6;color:#fff;border-radius:1rem 1rem .25rem}.message-bubble.bot{background-color:#f3f4f6;color:#1f2937;border-radius:1rem 1rem 1rem .25rem}.dark .message-bubble.bot{background-color:#374151;color:#e5e7eb}.message-text{font-size:.875rem;white-space:pre-wrap;word-break:break-words;line-height:1.5}.message-timestamp{font-size:.75rem;opacity:.7;margin-top:.375rem;text-align:right}.message-avatar{flex-shrink:0;width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.message-avatar.bot{background-color:#3b82f626;color:#3b82f6}.message-avatar.user{background-color:#10b98126;color:#10b981}.chat-input-area{position:relative;background-color:#fff;border-radius:.5rem;border:1px solid #d1d5db;padding:.5rem;box-shadow:0 1px 3px #0000001a}.dark .chat-input-area{background-color:#1f2937;border-color:#4b5563}.input-container{display:flex;align-items:flex-end;gap:.5rem}.chat-textarea{flex-grow:1;padding:.625rem;background-color:transparent;resize:none;border:none;outline:none;font-size:.875rem;color:#1f2937;min-height:40px;max-height:120px;line-height:1.5}.dark .chat-textarea{color:#e5e7eb}.chat-textarea::placeholder{color:#6b7280}.dark .chat-textarea::placeholder{color:#9ca3af}.chat-button{padding:.625rem;border-radius:50%;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.chat-button:focus{outline:2px solid #3b82f6;outline-offset:1px}.chat-button.primary{background-color:#3b82f6;color:#fff}.chat-button.primary:hover:not(:disabled){background-color:#2563eb}.chat-button.primary:disabled{background-color:#d1d5db;color:#6b7280;cursor:not-allowed}.chat-button.secondary{background-color:#f3f4f6;color:#6b7280}.chat-button.secondary:hover{background-color:#e5e7eb}.dark .chat-button.secondary{background-color:#374151;color:#9ca3af}.dark .chat-button.secondary:hover{background-color:#4b5563}.typing-indicator{display:flex;align-items:flex-end;gap:.5rem;max-width:75%}.typing-bubble{position:relative;padding:.75rem 1rem;border-radius:1rem 1rem 1rem .25rem;background-color:#f3f4f6;color:#1f2937;box-shadow:0 1px 3px #0000001a}.dark .typing-bubble{background-color:#374151;color:#e5e7eb}.typing-dots{display:flex;gap:.375rem;align-items:center;height:1.25rem}.typing-dot{width:.375rem;height:.375rem;border-radius:50%;background-color:#3b82f6;animation:bounce 1.4s infinite ease-in-out}.typing-dot:nth-child(1){animation-delay:-.32s}.typing-dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@media (max-width: 768px){.chat-header{flex-direction:column;align-items:flex-start}.chat-controls{width:100%}.chat-messages-area{min-height:300px;padding:.5rem}.message-content{max-width:90%}.chat-title{font-size:1.125rem}.message-avatar{width:1.5rem;height:1.5rem}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.voice-settings-panel{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.voice-settings-panel input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:6px;border-radius:3px;background:#d1d5db;outline:none;transition:background .3s}.voice-settings-panel input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#3b82f6;cursor:pointer;transition:background .3s}.voice-settings-panel input[type=range]::-webkit-slider-thumb:hover{background:#2563eb}.voice-settings-panel input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#3b82f6;cursor:pointer;border:none;transition:background .3s}.voice-settings-panel input[type=range]::-moz-range-thumb:hover{background:#2563eb}.dark .voice-settings-panel input[type=range]{background:#4b5563}.dark .voice-settings-panel input[type=range]::-webkit-slider-thumb{background:#60a5fa}.dark .voice-settings-panel input[type=range]::-webkit-slider-thumb:hover{background:#3b82f6}.dark .voice-settings-panel input[type=range]::-moz-range-thumb{background:#60a5fa}.dark .voice-settings-panel input[type=range]::-moz-range-thumb:hover{background:#3b82f6}.voice-settings-panel select:focus,.voice-settings-panel input:focus{outline:2px solid #3b82f6;outline-offset:2px}.dark .voice-settings-panel select:focus,.dark .voice-settings-panel input:focus{outline-color:#60a5fa}.url-analyzer{max-width:1200px;margin:0 auto;padding:var(--spacing-xl, 2rem);font-family:inherit;line-height:1.6;background-color:var(--color-bg-primary);color:var(--color-text-primary);transition:background-color var(--transition-normal),color var(--transition-normal)}.url-analyzer__header{text-align:center;margin-bottom:var(--spacing-xl, 2rem)}.url-analyzer__title{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-sm, .5rem);color:var(--color-accent)}.url-analyzer__description{font-size:1.1rem;color:var(--color-text-secondary);margin:0}.url-analyzer__input-section{margin-bottom:var(--spacing-xl, 2rem)}.url-analyzer__input-group{display:flex;gap:var(--spacing-md, 1rem);max-width:600px;margin:0 auto}.url-analyzer__input{flex:1;padding:.875rem 1rem;border:1px solid var(--color-border);border-radius:var(--border-radius-sm, .5rem);font-size:1rem;background-color:var(--color-bg-secondary);color:var(--color-text-primary);transition:border-color var(--transition-fast, .15s ease),box-shadow var(--transition-fast, .15s ease)}.url-analyzer__input:focus,.url-analyzer__input:focus-visible{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(var(--color-accent-rgb, 59, 130, 246),.25)}.url-analyzer__button{display:inline-flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:.875rem 1.5rem;border:1px solid transparent;border-radius:var(--border-radius-sm, .5rem);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color var(--transition-fast, .15s ease),color var(--transition-fast, .15s ease),transform var(--transition-fast, .15s ease),box-shadow var(--transition-fast, .15s ease);text-decoration:none;white-space:nowrap}.url-analyzer__button:disabled{opacity:.6;cursor:not-allowed}.url-analyzer__button--primary{background-color:var(--color-accent);color:#fff}.url-analyzer__button--primary:hover:not(:disabled){background-color:var(--color-accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.url-analyzer__button--secondary{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-border)}.url-analyzer__button--secondary:hover:not(:disabled){background-color:var(--color-border-light)}.url-analyzer__button-icon{display:flex;align-items:center}.url-analyzer__spinner{animation:spin 1s linear infinite}.url-analyzer__error{display:flex;align-items:flex-start;gap:var(--spacing-md, 1rem);padding:var(--spacing-md, 1rem);background-color:rgba(var(--color-error-rgb, 239, 68, 68),.1);border:1px solid var(--color-error, #ef4444);color:var(--color-error, #ef4444);border-radius:var(--border-radius, .75rem);margin-bottom:var(--spacing-xl, 2rem)}.url-analyzer__error-icon{font-size:1.25rem;margin-top:.125rem}.url-analyzer__error-title{font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.url-analyzer__error-message{margin:0;opacity:.9;color:var(--color-text-primary)}[data-theme=dark] .url-analyzer__error-message{color:var(--color-text-primary)}.url-analyzer__result{background-color:var(--color-bg-secondary);border-radius:var(--border-radius, .75rem);padding:var(--spacing-lg, 1.5rem);margin-bottom:var(--spacing-xl, 2rem);border:1px solid var(--color-border);box-shadow:var(--shadow-md)}.url-analyzer__result-header{margin-bottom:var(--spacing-xl, 2rem);padding-bottom:var(--spacing-lg, 1.5rem);border-bottom:1px solid var(--color-border-light)}.url-analyzer__score-section{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-lg, 1.5rem)}.url-analyzer__score{display:flex;align-items:center;gap:var(--spacing-md, 1rem)}.url-analyzer__score-icon{font-size:2rem}.url-analyzer__score-info{display:flex;flex-direction:column}.url-analyzer__score-number{font-size:2.5rem;font-weight:700;line-height:1}.url-analyzer__score-label{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:.25rem}.url-analyzer__score-description{font-size:.875rem;font-weight:500;color:var(--color-text-primary)}.url-analyzer__actions{display:flex;gap:var(--spacing-sm, .75rem)}.url-analyzer__analyzed-url,.url-analyzer__analysis-date,.url-analyzer__test-engine{margin-bottom:var(--spacing-xs, .5rem);font-size:.875rem;color:var(--color-text-secondary)}.url-analyzer__analyzed-url strong,.url-analyzer__analysis-date strong,.url-analyzer__test-engine strong{color:var(--color-text-primary)}.url-analyzer__stats{margin-bottom:var(--spacing-xl, 2rem)}.url-analyzer__stats-title{font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md, 1rem);color:var(--color-text-primary)}.url-analyzer__stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-lg, 1.5rem)}.url-analyzer__stat-card{background-color:var(--color-bg-primary);padding:var(--spacing-md, 1rem);border-radius:var(--border-radius-sm, .5rem);text-align:center;border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.url-analyzer__stat-number{font-size:1.875rem;font-weight:700;color:var(--color-accent);line-height:1}.url-analyzer__stat-label{font-size:.875rem;color:var(--color-text-secondary);margin-top:.25rem}.url-analyzer__impact-stats h4{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-sm, .75rem);color:var(--color-text-primary)}.url-analyzer__impact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:var(--spacing-sm, .75rem)}.url-analyzer__impact-stat{padding:var(--spacing-sm, .75rem);border-radius:var(--border-radius-sm, .5rem);text-align:center;border:1px solid transparent}.url-analyzer__impact-count{font-size:1.5rem;font-weight:700;line-height:1}.url-analyzer__impact-name{font-size:.75rem;text-transform:capitalize;margin-top:.25rem}.url-analyzer__impact-stat--critical{background-color:rgba(var(--color-error-rgb, 239, 68, 68),.1);color:var(--color-error, #ef4444);border-color:rgba(var(--color-error-rgb, 239, 68, 68),.3)}.url-analyzer__impact-stat--serious{background-color:rgba(var(--color-warning-rgb, 245, 158, 11),.1);color:var(--color-warning, #f59e0b);border-color:rgba(var(--color-warning-rgb, 245, 158, 11),.3)}.url-analyzer__impact-stat--moderate{background-color:rgba(var(--color-info-rgb, 59, 130, 246),.1);color:var(--color-info, #3b82f6);border-color:rgba(var(--color-info-rgb, 59, 130, 246),.3)}.url-analyzer__impact-stat--minor{background-color:rgba(var(--color-success-rgb, 16, 185, 129),.1);color:var(--color-text-secondary);border-color:rgba(var(--color-success-rgb, 16, 185, 129),.2)}.url-analyzer__violations{margin-bottom:var(--spacing-xl, 2rem)}.url-analyzer__violations-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-lg, 1.5rem);padding-bottom:var(--spacing-md, 1rem);border-bottom:1px solid var(--color-border-light)}.url-analyzer__violations-title{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);font-size:1.25rem;font-weight:600;color:var(--color-error);margin:0}.url-analyzer__violations-icon{font-size:1.125rem}.url-analyzer__category-filters{display:flex;flex-wrap:wrap;gap:var(--spacing-sm, .5rem)}.url-analyzer__filter-btn{display:flex;align-items:center;gap:.375rem;padding:var(--spacing-xs, .5rem) var(--spacing-sm, .75rem);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm, .375rem);font-size:.875rem;color:var(--color-text-primary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);text-transform:capitalize}.url-analyzer__filter-btn:hover{background-color:var(--color-border-light)}.url-analyzer__filter-btn--active{background-color:var(--color-accent);color:#fff;border-color:var(--color-accent)}.url-analyzer__filter-btn--active:hover{background-color:var(--color-accent-hover)}.url-analyzer__violations-list{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.url-analyzer__violation{background-color:var(--color-bg-primary);border:1px solid var(--color-border);border-left-width:4px;border-radius:var(--border-radius-sm, .5rem);padding:var(--spacing-md, 1.25rem);box-shadow:var(--shadow-sm)}.url-analyzer__violation.impact-critical{border-left-color:var(--color-error)}.url-analyzer__violation.impact-serious{border-left-color:var(--color-warning)}.url-analyzer__violation.impact-moderate{border-left-color:var(--color-info, #3b82f6)}.url-analyzer__violation.impact-minor{border-left-color:var(--color-text-muted, #94a3b8)}.url-analyzer__violation-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md, 1rem);margin-bottom:var(--spacing-sm, .75rem)}.url-analyzer__violation-title{display:flex;align-items:center;gap:var(--spacing-sm, .75rem);flex-wrap:wrap}.url-analyzer__violation-id{font-family:Monaco,Menlo,monospace;font-size:.875rem;background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);padding:.25rem .5rem;border-radius:.25rem}.url-analyzer__impact-badge{padding:.25rem .5rem;border-radius:var(--border-radius-sm, .25rem);font-size:.75rem;font-weight:600;text-transform:uppercase;color:#fff}.url-analyzer__impact-badge--critical{background-color:var(--color-error)}.url-analyzer__impact-badge--serious{background-color:var(--color-warning)}.url-analyzer__impact-badge--moderate{background-color:var(--color-info, #3b82f6)}.url-analyzer__impact-badge--minor{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.url-analyzer__violation-wcag{display:flex;flex-wrap:wrap;gap:.25rem}.url-analyzer__wcag-tag{background-color:var(--color-accent-transparent-equivalent, rgba(59,130,246,.1));color:var(--color-accent);padding:.125rem .375rem;border-radius:.25rem;font-size:.75rem;font-weight:500}.url-analyzer__violation-name{font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-xs, .25rem)}.url-analyzer__violation-help{font-size:.875rem;color:var(--color-text-secondary);margin:var(--spacing-sm, .5rem) 0;padding:var(--spacing-sm, .5rem);background-color:var(--color-bg-tertiary);border-radius:var(--border-radius-sm)}.url-analyzer__violation-help strong{color:var(--color-text-primary)}.url-analyzer__violation-link a{font-size:.875rem;color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}.url-analyzer__violation-link a:hover{color:var(--color-accent-hover);text-decoration:underline}.url-analyzer__violation-elements{margin-top:var(--spacing-md, 1rem);font-size:.875rem}.url-analyzer__violation-elements strong{color:var(--color-text-primary)}.url-analyzer__elements-list{margin-top:var(--spacing-xs, .5rem);max-height:150px;overflow-y:auto;background-color:var(--color-bg-tertiary);padding:var(--spacing-sm, .5rem);border-radius:var(--border-radius-sm);border:1px solid var(--color-border-light)}.url-analyzer__element{margin-bottom:var(--spacing-xs, .5rem)}.url-analyzer__element-selector{font-family:Monaco,Menlo,monospace;background-color:var(--color-bg-primary);color:var(--color-text-secondary);padding:.25rem .5rem;border-radius:.25rem;display:inline-block;border:1px solid var(--color-border);word-break:break-all}.url-analyzer__element-failure{font-size:.8rem;color:var(--color-text-muted);margin-left:var(--spacing-sm, .5rem);padding-left:var(--spacing-sm, .5rem);border-left:2px solid var(--color-border)}.url-analyzer__more-elements{font-size:.8rem;color:var(--color-text-muted);font-style:italic}.url-analyzer__passes,.url-analyzer__incomplete,.url-analyzer__recommendations{margin-bottom:var(--spacing-xl, 2rem);padding:var(--spacing-lg, 1.5rem);background-color:var(--color-bg-secondary);border-radius:var(--border-radius);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.url-analyzer__passes-title,.url-analyzer__incomplete-title,.url-analyzer__recommendations-title{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);font-size:1.25rem;font-weight:600;margin-bottom:var(--spacing-md, 1rem);color:var(--color-text-primary)}.url-analyzer__passes-icon{color:var(--color-success)}.url-analyzer__incomplete-icon{color:var(--color-warning)}.url-analyzer__recommendations-icon{color:var(--color-info, #3b82f6)}.url-analyzer__passes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--spacing-md, 1rem)}.url-analyzer__pass-item,.url-analyzer__incomplete-item,.url-analyzer__recommendation{background-color:var(--color-bg-primary);padding:var(--spacing-md, 1rem);border-radius:var(--border-radius-sm);border:1px solid var(--color-border-light);display:flex;align-items:flex-start;gap:var(--spacing-sm, .75rem)}.url-analyzer__pass-icon{color:var(--color-success);margin-top:.125rem}.url-analyzer__pass-id,.url-analyzer__incomplete-id{font-family:Monaco,Menlo,monospace;font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--spacing-xs, .25rem);display:block}.url-analyzer__pass-description,.url-analyzer__incomplete-desc,.url-analyzer__recommendation p{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5}.url-analyzer__recommendation h4{font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs, .25rem)}.url-analyzer__incomplete-description,.url-analyzer__more-passes{font-size:.875rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-md, 1rem)}.url-analyzer__incomplete-list,.url-analyzer__recommendations-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-md, 1rem)}.url-analyzer__incomplete-help{font-size:.8rem;color:var(--color-text-muted);margin-top:var(--spacing-xs, .5rem);padding-left:var(--spacing-md, 1rem);border-left:2px solid var(--color-border)}@media (max-width: 768px){.url-analyzer__title{font-size:1.5rem}.url-analyzer__input-group{flex-direction:column}.url-analyzer__stats-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.url-analyzer__impact-grid{grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.url-analyzer__filter-toggle{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm);font-size:.875rem;color:var(--color-text-primary);cursor:pointer}.url-analyzer__category-filters{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm);background-color:var(--color-bg-secondary);border-radius:var(--border-radius)}}@media print{.url-analyzer__input-section,.url-analyzer__actions,.url-analyzer__filter-toggle,.url-analyzer__category-filters{display:none}.url-analyzer,.url-analyzer__result,.url-analyzer__stat-card,.url-analyzer__violation,.url-analyzer__pass-item,.url-analyzer__incomplete-item,.url-analyzer__recommendation{background-color:#fff!important;color:#000!important;box-shadow:none!important;border:1px solid #ccc!important}.url-analyzer__score-number,.url-analyzer__stat-number,.url-analyzer__violations-title,.url-analyzer__pass-icon{color:#000!important}.url-analyzer__impact-badge{color:#000!important;background-color:#eee!important}}.url-analyzer__loading,.url-analyzer__empty{padding:var(--spacing-2xl, 3rem) var(--spacing-md, 1rem);text-align:center;background-color:var(--color-bg-secondary);border-radius:var(--border-radius);border:1px solid var(--color-border);margin:var(--spacing-xl) 0}.url-analyzer__loading-spinner,.url-analyzer__empty-icon{font-size:2.5rem;color:var(--color-accent);margin-bottom:var(--spacing-md, 1rem)}.url-analyzer__loading-text,.url-analyzer__empty-text{font-size:1.125rem;color:var(--color-text-secondary)}.url-analyzer__tooltip:hover:after{background-color:var(--color-text-primary);color:var(--color-bg-primary)}.url-analyzer__tooltip:hover:before{border-top-color:var(--color-text-primary)}.url-analyzer__violations-list::-webkit-scrollbar-track,.url-analyzer__elements-list::-webkit-scrollbar-track{background:var(--color-bg-tertiary)}.url-analyzer__violations-list::-webkit-scrollbar-thumb,.url-analyzer__elements-list::-webkit-scrollbar-thumb{background:var(--color-border)}.url-analyzer__violations-list::-webkit-scrollbar-thumb:hover,.url-analyzer__elements-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.url-analyzer__violations-list,.url-analyzer__elements-list{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-bg-tertiary)}.url-analyzer__result{animation:fadeInUp .5s ease-out}.url-analyzer__violation{animation:fadeInUp .3s ease-out;animation-fill-mode:both}@media (prefers-reduced-motion: reduce){.url-analyzer__result,.url-analyzer__violation{animation:none}}.file-uploader-container{padding:var(--spacing-xl, 2rem);background-color:var(--color-bg-primary);color:var(--color-text-primary);border-radius:var(--border-radius, .75rem);height:100%;display:flex;flex-direction:column}.file-uploader-header{margin-bottom:var(--spacing-lg, 1.5rem);padding-bottom:var(--spacing-md, 1rem);border-bottom:1px solid var(--color-border-light)}.file-uploader-header-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-sm, .5rem)}.file-uploader-title{font-size:1.75rem;font-weight:700;color:var(--color-text-primary)}.file-uploader-description{color:var(--color-text-secondary);font-size:.9rem;margin-top:var(--spacing-xs, .25rem)}.auto-read-toggle{display:flex;align-items:center;padding:var(--spacing-xs, .25rem) var(--spacing-sm, .5rem);border-radius:var(--border-radius, .75rem);font-size:.8rem;cursor:pointer;border:1px solid transparent;transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.auto-read-toggle.active{background-color:var(--color-accent);color:#fff;border-color:var(--color-accent-hover)}.auto-read-toggle.inactive{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);border-color:var(--color-border)}.auto-read-toggle:hover{opacity:.8}.auto-read-toggle svg{margin-right:var(--spacing-xs, .25rem)}.upload-form-container{margin-bottom:var(--spacing-lg, 1.5rem)}.file-uploader-label{display:block;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm, .5rem)}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--border-radius-sm, .5rem);padding:var(--spacing-xl, 2rem);text-align:center;cursor:pointer;background-color:var(--color-bg-secondary);transition:border-color var(--transition-fast),background-color var(--transition-fast)}.drop-zone:hover,.drop-zone.drag-over{border-color:var(--color-accent);background-color:var(--color-bg-tertiary)}.drop-zone:focus,.drop-zone:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-color:var(--color-accent)}.drop-zone-icon{font-size:2.5rem;margin:0 auto var(--spacing-md, 1rem) auto;color:var(--color-text-muted)}.drop-zone:hover .drop-zone-icon,.drop-zone.drag-over .drop-zone-icon{color:var(--color-accent)}.drop-zone-text{font-size:1rem;font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-xs, .25rem)}.drop-zone-prompt{font-size:.875rem;color:var(--color-text-muted)}.file-info-bar{display:flex;align-items:center;padding:var(--spacing-md, 1rem);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-sm, .5rem);border:1px solid var(--color-border-light);margin-bottom:var(--spacing-lg, 1.5rem)}.file-info-icon{color:var(--color-accent);margin-right:var(--spacing-sm, .5rem);font-size:1.25rem}.file-info-name{font-weight:500;color:var(--color-text-primary)}.file-info-size{margin-left:var(--spacing-sm, .5rem);font-size:.875rem;color:var(--color-text-secondary)}.error-message-fileuploader{background-color:rgba(var(--color-error-rgb, 239, 68, 68),.1);color:var(--color-error, #ef4444);padding:var(--spacing-md, 1rem);border-radius:var(--border-radius-sm, .5rem);border:1px solid var(--color-error, #ef4444);margin-bottom:var(--spacing-lg, 1.5rem);font-size:.9rem}.analyze-button-container{display:flex;justify-content:flex-end}.analyze-button{display:inline-flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:.75rem 1.5rem;background-color:var(--color-accent);color:#fff;border:none;border-radius:var(--border-radius-sm, .5rem);font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),opacity var(--transition-fast)}.analyze-button:hover:not(:disabled){background-color:var(--color-accent-hover)}.analyze-button:disabled{opacity:.5;cursor:not-allowed}.analyze-button svg{animation:spin 1s linear infinite}.loading-indicator-fileuploader{padding:var(--spacing-xl, 2rem);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-sm, .5rem);text-align:center;border:1px solid var(--color-border-light)}.loading-indicator-fileuploader svg{font-size:2.5rem;color:var(--color-accent);margin:0 auto var(--spacing-md, 1rem) auto;animation:spin 1s linear infinite}.loading-indicator-fileuploader .loading-text{font-size:1.125rem;font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-xs, .25rem)}.loading-indicator-fileuploader .loading-subtext{font-size:.875rem;color:var(--color-text-secondary)}.report-section-fileuploader{border:1px solid var(--color-border);border-radius:var(--border-radius, .75rem);overflow:hidden;background-color:var(--color-bg-primary);margin-top:var(--spacing-lg, 1.5rem);box-shadow:var(--shadow-sm)}.report-header{padding:var(--spacing-md, 1rem);background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border-light)}.report-header-title{font-size:1.25rem;font-weight:600;color:var(--color-text-primary)}.report-body{padding:var(--spacing-lg, 1.5rem)}.report-score-display{text-align:center;margin-bottom:var(--spacing-lg, 1.5rem)}.report-score-wrapper{display:inline-block;padding:var(--spacing-lg, 1.5rem);border-radius:50%;background-color:var(--color-bg-secondary);border:4px solid;width:120px;height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center}.report-score-value{font-size:2.5rem;font-weight:700}.report-score-label{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-xs, .25rem)}.report-score-description{margin-top:var(--spacing-sm, .5rem);font-size:.9rem;color:var(--color-text-secondary)}.report-violations-header{font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md, 1rem)}.report-violations-list{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.report-violation-item{padding:var(--spacing-md, 1rem);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-sm, .5rem);border-left-width:4px;border-left-style:solid;box-shadow:var(--shadow-sm)}.violation-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm, .5rem);flex-wrap:wrap;gap:var(--spacing-xs, .25rem)}.violation-title{font-weight:600;color:var(--color-text-primary)}.violation-impact-badge{padding:.25rem .6rem;border-radius:var(--border-radius, .75rem);font-size:.7rem;font-weight:700;text-transform:uppercase;color:#fff}.violation-impact-badge.critical{background-color:var(--color-error)}.violation-impact-badge.serious{background-color:var(--color-warning)}.violation-impact-badge.moderate{background-color:var(--color-info, #3b82f6)}.violation-impact-badge.minor{background-color:var(--color-bg-tertiary);color:var(--color-text-secondary);border:1px solid var(--color-border)}.violation-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-sm, .5rem);font-size:.9rem}.violation-code-snippet-container{background-color:var(--color-bg-primary);padding:var(--spacing-sm, .5rem);border-radius:var(--border-radius-sm, .5rem);margin-bottom:var(--spacing-sm, .5rem);border:1px solid var(--color-border-light)}.violation-code-snippet-label{font-size:.8rem;font-weight:500;color:var(--color-text-muted);margin-bottom:var(--spacing-xs, .25rem)}.violation-code-snippet{font-family:Monaco,Menlo,monospace;font-size:.8rem;color:var(--color-text-secondary);display:block;overflow-x:auto;white-space:pre-wrap;padding:var(--spacing-xs, .25rem);background-color:var(--color-bg-tertiary);border-radius:.2rem}.violation-help-text-label{font-size:.8rem;font-weight:500;color:var(--color-text-muted);margin-bottom:var(--spacing-xs, .25rem)}.violation-help-text{font-size:.875rem;color:var(--color-text-secondary)}.export-button-container{margin-top:var(--spacing-lg, 1.5rem);padding-top:var(--spacing-md, 1rem);border-top:1px solid var(--color-border-light);display:flex;justify-content:center}.export-button{display:inline-flex;align-items:center;gap:var(--spacing-sm, .5rem);padding:.75rem 1.5rem;background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm, .5rem);font-weight:600;cursor:pointer;transition:background-color var(--transition-fast)}.export-button:hover{background-color:var(--color-border-light)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wcag-guide-container{padding:var(--spacing-xl, 2rem);background-color:var(--color-bg-primary);color:var(--color-text-primary);border-radius:var(--border-radius, .75rem);height:100%;display:flex;flex-direction:column}.wcag-guide-header{margin-bottom:var(--spacing-lg, 1.5rem);padding-bottom:var(--spacing-md, 1rem);border-bottom:1px solid var(--color-border-light)}.wcag-guide-main-title{font-size:1.75rem;font-weight:700;color:var(--color-text-primary);margin-bottom:var(--spacing-xs, .25rem)}.wcag-guide-description{color:var(--color-text-secondary);font-size:.9rem}.controls-container{margin-bottom:var(--spacing-lg, 1.5rem)}.search-form-group{margin-bottom:var(--spacing-md, 1rem)}.wcag-form-label{display:block;font-weight:500;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm, .5rem)}.search-input-wrapper{position:relative}.search-input-icon{position:absolute;left:var(--spacing-md, 1rem);top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.search-input-wcag{width:100%;padding:.75rem 1rem .75rem 2.5rem;background-color:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);border-radius:var(--border-radius-sm, .5rem);font-size:.9rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input-wcag:focus,.search-input-wcag:focus-visible{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(var(--color-accent-rgb, 59, 130, 246),.25)}.principles-filter-section{margin-bottom:var(--spacing-md, 1rem)}.principle-filter-header{display:flex;align-items:center;margin-bottom:var(--spacing-sm, .5rem);font-weight:500;color:var(--color-text-primary)}.principle-filter-header svg{margin-right:var(--spacing-sm, .5rem);color:var(--color-accent)}.principle-filter-group{display:flex;flex-wrap:wrap;gap:var(--spacing-sm, .5rem)}.principle-filter-button{padding:.5rem 1rem;border-radius:var(--border-radius, .75rem);font-size:.8rem;font-weight:500;cursor:pointer;border:1px solid var(--color-border);background-color:var(--color-bg-secondary);color:var(--color-text-secondary);transition:background-color var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.principle-filter-button:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-accent-hover);color:var(--color-accent-hover)}.principle-filter-button.active{background-color:var(--color-accent);color:#fff;border-color:var(--color-accent)}.principle-filter-button.active:hover{background-color:var(--color-accent-hover)}.principle-filter-button:focus,.principle-filter-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px}.rules-list-container{flex-grow:1;overflow-y:auto}.rules-list{display:flex;flex-direction:column;gap:var(--spacing-md, 1rem)}.no-rules-found{padding:var(--spacing-xl, 2rem);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-sm, .5rem);text-align:center;color:var(--color-text-muted);border:1px dashed var(--color-border)}.rule-item{padding:var(--spacing-md, 1rem);background-color:var(--color-bg-secondary);border-radius:var(--border-radius-sm, .5rem);border:1px solid var(--color-border-light);transition:background-color var(--transition-fast),box-shadow var(--transition-fast);cursor:pointer}.rule-item:hover{background-color:var(--color-bg-tertiary);box-shadow:var(--shadow-sm)}.rule-item:focus,.rule-item:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}.rule-item.active{background-color:var(--color-bg-tertiary);border-left:4px solid var(--color-accent);padding-left:calc(var(--spacing-md, 1rem) - 4px + var(--spacing-xs, .25rem))}.rule-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm, .5rem);gap:var(--spacing-sm, .5rem)}.rule-main-title{font-weight:600;color:var(--color-text-primary);font-size:1rem}.rule-actions{display:flex;align-items:center;gap:var(--spacing-sm, .5rem);flex-shrink:0}.rule-level-tag{padding:.2rem .5rem;border-radius:var(--border-radius-sm, .25rem);font-size:.7rem;font-weight:700;text-transform:uppercase;color:#fff}.rule-level-tag.level-a{background-color:var(--color-success)}.rule-level-tag.level-aa{background-color:var(--color-warning)}.rule-level-tag.level-aaa{background-color:var(--color-error)}.speak-rule-button{padding:var(--spacing-xs, .25rem);border-radius:50%;background-color:transparent;color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);border:1px solid transparent}.speak-rule-button:hover{background-color:var(--color-bg-tertiary);color:var(--color-accent)}.speak-rule-button:focus,.speak-rule-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:0px;border-color:var(--color-accent)}.rule-description-text{color:var(--color-text-secondary);font-size:.9rem;margin-bottom:var(--spacing-sm, .5rem);line-height:1.5}.rule-details-section{margin-top:var(--spacing-md, 1rem);padding-top:var(--spacing-md, 1rem);border-top:1px solid var(--color-border-light)}.rule-details-title{font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-xs, .25rem);font-size:.9rem}.rule-details-text{font-size:.85rem;color:var(--color-text-secondary);line-height:1.5}.rule-link-container{display:flex;justify-content:flex-end;margin-top:var(--spacing-sm, .5rem)}.rule-external-link{font-size:.8rem;color:var(--color-accent);text-decoration:none;font-weight:500}.rule-external-link:hover{text-decoration:underline;color:var(--color-accent-hover)}.app-footer{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-top:1px solid #e2e8f0;padding:2rem 1rem 1rem;margin-top:auto;transition:all .3s ease}.app-footer.dark{background:linear-gradient(135deg,#1f2937,#111827);border-top:1px solid #374151}.footer-content{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr;gap:2rem}@media (min-width: 768px){.footer-content{grid-template-columns:2fr 1fr 1fr;gap:3rem}}.footer-section.development{display:flex;flex-direction:column;gap:1.5rem}.love-message{display:flex;align-items:center;gap:.5rem;font-size:1.1rem;font-weight:500;color:#374151}.app-footer.dark .love-message{color:#e5e7eb}.heart-icon{color:#ef4444;animation:heartbeat 2s ease-in-out infinite}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.developers{display:flex;flex-direction:column;gap:1rem}@media (min-width: 640px){.developers{flex-direction:row;align-items:center;gap:1.5rem}}.developer{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#ffffffb3;border-radius:.75rem;border:1px solid #e5e7eb;transition:all .3s ease}.app-footer.dark .developer{background:#1f2937b3;border-color:#4b5563}.developer:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.app-footer.dark .developer:hover{box-shadow:0 4px 12px #0000004d}.developer-info{display:flex;align-items:center;gap:.75rem}.developer-icon{color:#3b82f6;flex-shrink:0}.app-footer.dark .developer-icon{color:#60a5fa}.developer-details{display:flex;flex-direction:column}.developer-name{font-size:1rem;font-weight:600;color:#1f2937;margin:0}.app-footer.dark .developer-name{color:#f9fafb}.developer-role{font-size:.875rem;color:#6b7280}.app-footer.dark .developer-role{color:#9ca3af}.social-links{display:flex;gap:.5rem}.social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;transition:all .3s ease;text-decoration:none}.social-link.linkedin{background:#0077b5;color:#fff}.social-link.linkedin:hover{background:#005885;transform:scale(1.1)}.social-link.github{background:#333;color:#fff}.social-link.github:hover{background:#24292e;transform:scale(1.1)}.orientation{display:flex;align-items:center;justify-content:center;padding:.5rem}.orientation-text{font-style:italic;color:#6b7280;font-size:.9rem}.app-footer.dark .orientation-text{color:#9ca3af}.footer-section.institutions{display:flex;flex-direction:column;gap:1.5rem}.institution{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#ffffff80;border-radius:.5rem;border:1px solid #e5e7eb;transition:all .3s ease}.app-footer.dark .institution{background:#1f293780;border-color:#4b5563}.institution:hover{background:#fffc;transform:translate(4px)}.app-footer.dark .institution:hover{background:#1f2937cc}.institution-info{display:flex;align-items:center;gap:.75rem;flex:1}.institution-icon{color:#059669;flex-shrink:0}.app-footer.dark .institution-icon{color:#10b981}.institution-details{display:flex;flex-direction:column}.institution-name{font-size:.9rem;font-weight:600;color:#1f2937;margin:0}.app-footer.dark .institution-name{color:#f9fafb}.institution-role{font-size:.8rem;color:#6b7280}.app-footer.dark .institution-role{color:#9ca3af}.institution-link{color:#6b7280;transition:all .3s ease;padding:.5rem;border-radius:.25rem}.institution-link:hover{color:#3b82f6;background:#3b82f61a}.app-footer.dark .institution-link{color:#9ca3af}.app-footer.dark .institution-link:hover{color:#60a5fa;background:#60a5fa1a}.footer-section.project-info{display:flex;flex-direction:column;gap:1.5rem}.project-description h4{font-size:1.1rem;font-weight:600;color:#1f2937;margin:0 0 .5rem}.app-footer.dark .project-description h4{color:#f9fafb}.project-description p{font-size:.875rem;color:#6b7280;line-height:1.5;margin:0}.app-footer.dark .project-description p{color:#9ca3af}.project-links{display:flex;flex-direction:column;gap:.5rem}.project-link{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#3b82f61a;color:#3b82f6;text-decoration:none;border-radius:.5rem;border:1px solid rgba(59,130,246,.2);transition:all .3s ease;font-size:.875rem;font-weight:500}.project-link:hover{background:#3b82f633;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f633}.app-footer.dark .project-link{background:#60a5fa1a;color:#60a5fa;border-color:#60a5fa33}.app-footer.dark .project-link:hover{background:#60a5fa33;box-shadow:0 2px 8px #60a5fa33}.footer-bottom{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;display:flex;flex-direction:column;gap:.5rem;align-items:center;text-align:center}.app-footer.dark .footer-bottom{border-top-color:#374151}@media (min-width: 768px){.footer-bottom{flex-direction:row;justify-content:space-between;text-align:left}}.copyright{font-size:.875rem;color:#6b7280}.app-footer.dark .copyright{color:#9ca3af}.tech-info{font-size:.8rem;color:#9ca3af;font-style:italic}.app-footer.dark .tech-info{color:#6b7280}@media (max-width: 640px){.app-footer{padding:1.5rem .75rem 1rem}.footer-content{gap:1.5rem}.developers{gap:1rem}.developer{padding:.75rem}.developer-name{font-size:.9rem}.developer-role{font-size:.8rem}.institution{padding:.75rem}.institution-name{font-size:.85rem}.institution-role{font-size:.75rem}.love-message{font-size:1rem}.orientation-text{font-size:.85rem}}.footer-section{animation:fadeInUp .6s ease-out}.footer-section:nth-child(2){animation-delay:.1s}.footer-section:nth-child(3){animation-delay:.2s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.social-link:focus,.institution-link:focus,.project-link:focus{outline:2px solid #3b82f6;outline-offset:2px}.app-footer.dark .social-link:focus,.app-footer.dark .institution-link:focus,.app-footer.dark .project-link:focus{outline-color:#60a5fa}.developer.advisor{border-left:3px solid #10b981}.app-footer.dark .developer.advisor{border-left-color:#34d399}.developer.advisor .developer-icon{color:#10b981}.app-footer.dark .developer.advisor .developer-icon{color:#34d399}.developer.advisor:before{content:"👩‍🏫";position:absolute;top:-8px;right:-8px;font-size:1.2rem;background:#fff;border-radius:50%;padding:2px;border:2px solid #10b981}.app-footer.dark .developer.advisor:before{background:#1f2937;border-color:#34d399}.developer{position:relative}.institution:first-child .institution-icon{color:#dc2626}.app-footer.dark .institution:first-child .institution-icon{color:#f87171}.institution:last-child .institution-icon{color:#7c3aed}.app-footer.dark .institution:last-child .institution-icon{color:#a78bfa}
