*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}[type=text],input:where(:not([type])),[type=email],[type=url],[type=password],[type=number],[type=date],[type=datetime-local],[type=month],[type=search],[type=tel],[type=time],[type=week],[multiple],textarea,select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow: 0 0 #0000}[type=text]:focus,input:where(:not([type])):focus,[type=email]:focus,[type=url]:focus,[type=password]:focus,[type=number]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=month]:focus,[type=search]:focus,[type=tel]:focus,[type=time]:focus,[type=week]:focus,[multiple]:focus,textarea:focus,select:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}input::-moz-placeholder,textarea::-moz-placeholder{color:#6b7280;opacity:1}input::placeholder,textarea::placeholder{color:#6b7280;opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-date-and-time-value{min-height:1.5em;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-top:0;padding-bottom:0}select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}[multiple],[size]:where(select:not([size="1"])){background-image:initial;background-position:initial;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}[type=checkbox],[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow: 0 0 #0000}[type=checkbox]{border-radius:0}[type=radio]{border-radius:100%}[type=checkbox]:focus,[type=radio]:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 2px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}[type=checkbox]:checked,[type=radio]:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}[type=checkbox]:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e")}@media(forced-colors:active){[type=checkbox]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=radio]:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e")}@media(forced-colors:active){[type=radio]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:checked:hover,[type=checkbox]:checked:focus,[type=radio]:checked:hover,[type=radio]:checked:focus{border-color:transparent;background-color:currentColor}[type=checkbox]:indeterminate{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}@media(forced-colors:active){[type=checkbox]:indeterminate{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:indeterminate:hover,[type=checkbox]:indeterminate:focus{border-color:transparent;background-color:currentColor}[type=file]{background:unset;border-color:inherit;border-width:0;border-radius:0;padding:0;font-size:unset;line-height:inherit}[type=file]:focus{outline:1px solid ButtonText;outline:1px auto -webkit-focus-ring-color}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;--primary-color: #2196f3;--primary-light: #e3f2fd;--secondary-color: #757575;--background-color: #ffffff;--surface-color: #f5f5f5;--text-primary: #212121;--text-secondary: #757575;--border-color: #e0e0e0;--shadow: 0 2px 4px rgba(0, 0, 0, .1);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-width:320px;--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.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}}.form-input,.form-textarea,.form-select,.form-multiselect{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow: 0 0 #0000}.form-input:focus,.form-textarea:focus,.form-select:focus,.form-multiselect:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:#6b7280;opacity:1}.form-input::placeholder,.form-textarea::placeholder{color:#6b7280;opacity:1}.form-input::-webkit-datetime-edit-fields-wrapper{padding:0}.form-input::-webkit-date-and-time-value{min-height:1.5em;text-align:inherit}.form-input::-webkit-datetime-edit{display:inline-flex}.form-input::-webkit-datetime-edit,.form-input::-webkit-datetime-edit-year-field,.form-input::-webkit-datetime-edit-month-field,.form-input::-webkit-datetime-edit-day-field,.form-input::-webkit-datetime-edit-hour-field,.form-input::-webkit-datetime-edit-minute-field,.form-input::-webkit-datetime-edit-second-field,.form-input::-webkit-datetime-edit-millisecond-field,.form-input::-webkit-datetime-edit-meridiem-field{padding-top:0;padding-bottom:0}.form-checkbox,.form-radio{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow: 0 0 #0000}.form-checkbox{border-radius:0}.form-checkbox:focus,.form-radio:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 2px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.form-checkbox:checked,.form-radio:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}.form-checkbox:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e")}@media(forced-colors:active){.form-checkbox:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}.form-checkbox:checked:hover,.form-checkbox:checked:focus,.form-radio:checked:hover,.form-radio:checked:focus{border-color:transparent;background-color:currentColor}.form-checkbox:indeterminate{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}@media(forced-colors:active){.form-checkbox:indeterminate{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}.form-checkbox:indeterminate:hover,.form-checkbox:indeterminate:focus{border-color:transparent;background-color:currentColor}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.-top-3{top:-.75rem}.left-0{left:0}.left-3{left:.75rem}.right-0{right:0}.right-3{right:.75rem}.top-1\/2{top:50%}.z-50{z-index:50}.mx-4{margin-left:1rem;margin-right:1rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.my-4{margin-top:1rem;margin-bottom:1rem}.-mt-8{margin-top:-2rem}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.ml-3{margin-left:.75rem}.ml-5{margin-left:1.25rem}.mr-4{margin-right:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-8{height:2rem}.h-full{height:100%}.min-h-\[100px\]{min-height:100px}.w-0\.5{width:.125rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-2{width:.5rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-full{width:100%}.min-w-\[100px\]{min-width:100px}.min-w-\[160px\]{min-width:160px}.max-w-\[70\%\]{max-width:70%}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-100{--tw-scale-x: 1;--tw-scale-y: 1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-95{--tw-scale-x: .95;--tw-scale-y: .95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.resize-y{resize:vertical}.resize{resize:both}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.25rem * var(--tw-space-x-reverse));margin-left:calc(.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-bl-md{border-bottom-left-radius:.375rem}.rounded-br-md{border-bottom-right-radius:.375rem}.border{border-width:1px}.border-2{border-width:2px}.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-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-primary-500{--tw-border-opacity: 1;border-color:rgb(33 150 243 / var(--tw-border-opacity, 1))}.border-primary-600{--tw-border-opacity: 1;border-color:rgb(30 136 229 / var(--tw-border-opacity, 1))}.border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity, 1))}.border-red-600{--tw-border-opacity: 1;border-color:rgb(220 38 38 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.bg-black\/30{background-color:#0000004d}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-400{--tw-bg-opacity: 1;background-color:rgb(156 163 175 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.bg-primary-500{--tw-bg-opacity: 1;background-color:rgb(33 150 243 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.from-blue-500{--tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-purple-600{--tw-gradient-to: #9333ea var(--tw-gradient-to-position)}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-2{padding:.5rem}.p-4{padding:1rem}.px-1{padding-left:.25rem;padding-right:.25rem}.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}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pl-10{padding-left:2.5rem}.pr-10{padding-right:2.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.leading-relaxed{line-height:1.625}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-primary-500{--tw-text-opacity: 1;color:rgb(33 150 243 / var(--tw-text-opacity, 1))}.text-primary-600{--tw-text-opacity: 1;color:rgb(30 136 229 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-50{opacity:.5}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.ring-4{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;overflow-x:hidden}#root{height:100vh;overflow:hidden}h1,h2,h3,h4,h5,h6{margin:0 0 1rem;font-weight:600;line-height:1.2}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{margin:0 0 1rem}a{color:var(--primary-color);text-decoration:none;transition:color .2s ease}a:hover{color:#1976d2;text-decoration:underline}input,textarea,select{font-family:inherit;font-size:inherit}.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}.mobile-only{display:block}.desktop-only{display:none}@media(min-width:769px){.mobile-only{display:none}.desktop-only{display:block}}@media(max-width:768px){button,a,[role=button]{min-height:44px;min-width:44px}}html{scroll-behavior:smooth}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.hover\:border-primary-300:hover{--tw-border-opacity: 1;border-color:rgb(100 181 246 / var(--tw-border-opacity, 1))}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-300:hover{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.hover\:bg-primary-50:hover{--tw-bg-opacity: 1;background-color:rgb(227 242 253 / var(--tw-bg-opacity, 1))}.hover\:bg-primary-600:hover{--tw-bg-opacity: 1;background-color:rgb(30 136 229 / var(--tw-bg-opacity, 1))}.hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.hover\:bg-red-600:hover{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.hover\:bg-red-700:hover{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity, 1))}.hover\:text-gray-600:hover{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.hover\:text-primary-600:hover{--tw-text-opacity: 1;color:rgb(30 136 229 / var(--tw-text-opacity, 1))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.focus\:ring-gray-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(107 114 128 / var(--tw-ring-opacity, 1))}.focus\:ring-primary-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(33 150 243 / var(--tw-ring-opacity, 1))}.focus\:ring-red-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(239 68 68 / var(--tw-ring-opacity, 1))}.focus\:ring-offset-0:focus{--tw-ring-offset-width: 0px}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-100:disabled{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.disabled\:opacity-50:disabled{opacity:.5}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-container{width:100%;max-width:500px}.auth-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;padding:28px;margin:0 auto;max-height:calc(100vh - 48px);overflow-y:auto}.auth-top{display:flex;justify-content:flex-end;margin-bottom:8px}.form-header{text-align:center;margin-bottom:16px}.form-header h2{color:#2c3e50;font-size:28px;font-weight:600;margin:0 0 8px}.form-header p{color:#7f8c8d;font-size:16px;margin:0}.auth-form{display:flex;flex-direction:column;gap:8px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:500;color:#2c3e50;font-size:14px}.form-group .e-input-group{margin-bottom:0}.error-message{color:#e74c3c;font-size:12px;margin-top:2px}.submit-error{background-color:#fdf2f2;border:1px solid #fecaca;color:#dc2626;padding:12px;border-radius:6px;font-size:14px;text-align:center}.verification-status{text-align:center;padding:2rem 1rem}.verification-status .spinner{width:50px;height:50px;margin:0 auto 1rem;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.verification-status.success .success-icon,.verification-status.error .error-icon{width:80px;height:80px;margin:0 auto 1rem;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700}.verification-status.success .success-icon{background-color:#f0fdf4;color:#16a34a}.verification-status.error .error-icon{background-color:#fef2f2;color:#dc2626}.verification-status h2{color:#2c3e50;font-size:1.5rem;margin-bottom:.5rem}.verification-status p{color:#7f8c8d;font-size:1rem;margin-bottom:.5rem}.verification-status .error-message{color:#dc2626;font-weight:500}.verification-status .redirect-message{color:#16a34a;font-style:italic;margin-top:1rem}.form-footer{text-align:center;margin-top:12px}.form-footer p{color:#7f8c8d;font-size:14px;margin:0}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;font-weight:500;text-decoration:underline;padding:0}.link-button:hover{color:#5a67d8}@media(max-width:768px){.auth-page{padding:16px}.auth-card{padding:24px}.form-header h2{font-size:24px}.form-row{grid-template-columns:1fr;gap:20px}}.e-input-group.e-error .e-input{border-color:#e74c3c}.e-input-group.e-error .e-float-text{color:#e74c3c}.e-multiselect{width:100%}.e-multiselect .e-multi-select-wrapper{min-height:36px}.verification-message-container{text-align:center;padding:20px}.verification-icon{font-size:64px;margin-bottom:20px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.verification-message-container h2{color:#2c3e50;font-size:24px;font-weight:600;margin:0 0 16px}.verification-message{color:#555;font-size:16px;line-height:1.6;margin:0 0 12px}.verification-hint{color:#7f8c8d;font-size:14px;font-style:italic;margin:0 0 20px}.resend-message{padding:12px;border-radius:6px;font-size:14px;margin-bottom:16px;animation:slideIn .3s ease-out}.resend-message.success{background-color:#f0fdf4;border:1px solid #86efac;color:#16a34a}.resend-message.error{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626}.resend-button{width:100%;height:44px;font-size:15px;font-weight:500;margin-top:6px}.auth-form{max-width:500px;margin:0 auto;padding:2rem}.auth-form h2{margin-bottom:1rem;text-align:center}.auth-form .forgot-password-description,.auth-form .reset-password-description{margin-bottom:2rem;text-align:center;color:var(--text-secondary)}.form-field{margin-bottom:1.5rem}.field-error{color:var(--error-color);font-size:.875rem;margin-top:.25rem}.error-message{background-color:var(--error-background);color:var(--error-color);padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center}.form-actions{margin-top:1.5rem}.form-actions .e-btn{width:100%}.back-to-login{text-align:center;margin-top:1rem}.link-button{background:none;border:none;color:var(--primary-color);cursor:pointer;font-size:.875rem;text-decoration:none;padding:0}.link-button:hover{text-decoration:underline}.forgot-password-link{text-align:right;margin-top:.5rem}.forgot-password-link .link-button{font-size:.875rem}.success-container{text-align:center;padding:2rem 1rem}.success-icon{font-size:4rem;margin-bottom:1rem}.success-container h2{margin-bottom:1rem}.success-message{color:var(--text-secondary);margin-bottom:1rem}.success-note{color:var(--text-tertiary);font-size:.875rem;margin-bottom:1.5rem}.back-button{margin-top:1rem}.loading-container{text-align:center;padding:2rem}.course-catalog{padding:20px;width:100%;max-width:none;margin:0 auto}.catalog-header{margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.catalog-header h2{margin-bottom:8px;color:#0f172a;font-size:20px;font-weight:600;letter-spacing:-.01em;line-height:1.25}.catalog-header h2:after{content:"";display:block;width:48px;height:3px;margin-top:10px;border-radius:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.catalog-filters{display:flex;gap:16px;flex-wrap:wrap;align-items:stretch;width:100%;margin-top:16px}.catalog-filters .filter-search{flex:1;min-width:240px}.catalog-filters .filter-select{flex:0 0 auto;min-width:200px}.course-catalog .header-right{display:flex;align-items:center;margin-left:auto}.course-catalog .show-hidden-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;padding:4px 6px;border-radius:6px}.course-catalog .show-hidden-switch .switch-input{position:absolute;left:0;top:0;width:46px;height:26px;margin:0;opacity:0;cursor:pointer;z-index:2}.course-catalog .show-hidden-switch .switch-slider{width:46px;height:26px;background:#e5e7eb;border-radius:999px;position:relative;transition:background .2s ease;box-shadow:inset 0 1px 2px #0000000f;display:inline-block;vertical-align:middle;z-index:1}.course-catalog .show-hidden-switch .switch-slider:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .18s ease;box-shadow:0 1px 2px #0000001f}.course-catalog .show-hidden-switch .switch-input:checked+.switch-slider{background:linear-gradient(90deg,#667eea,#764ba2)}.course-catalog .show-hidden-switch .switch-input:checked+.switch-slider:after{transform:translate(20px)}.course-catalog .show-hidden-switch .switch-label{font-size:.95rem;color:#374151;font-weight:500;margin-left:6px}.catalog-title-section{display:flex;flex-direction:column;gap:6px}.courses-grid{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:30px}@media(min-width:1024px){.courses-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.course-card{border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;background:#fff;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;height:100%}.course-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.course-thumbnail{height:200px;background:#f5f5f5;display:flex;align-items:center;justify-content:center;overflow:hidden}.course-card .course-content{padding:20px;display:flex;flex-direction:column;align-items:stretch;flex:1;gap:12px}.course-title{margin:0;font-size:1.25rem;font-weight:600;color:#333;line-height:1.4}.course-description{margin:0;color:#666;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere}.course-meta{display:flex;gap:8px;flex-wrap:wrap}.course-instructor{margin:0;color:#666;font-size:.9rem}.course-stats{display:flex;gap:10px;color:#666;font-size:.9rem}.course-catalog .course-card .course-actions{display:flex;flex-direction:column;gap:10px;margin-top:auto;padding:15px 20px 20px;border-top:1px solid #f0f0f0;background:#fff}.course-catalog .course-card .course-actions button{width:100%}.pagination-info{display:flex;justify-content:space-between;align-items:center;padding:20px 0;border-top:1px solid #e0e0e0;margin-top:20px}.pagination-controls{display:flex;align-items:center;gap:15px}.no-courses{text-align:center;padding:40px;color:#666}@media(max-width:768px){.course-catalog{padding:15px}.catalog-filters{flex-direction:column;align-items:stretch}.catalog-filters .filter-search,.catalog-filters .filter-select{min-width:100%}.courses-grid{grid-template-columns:1fr}.pagination-info{flex-direction:column;gap:15px;text-align:center}.pagination-controls{justify-content:center}}.video-player{width:100%;max-width:1000px;margin:0 auto;background:#000;border-radius:8px;overflow:hidden;box-shadow:0 4px 16px #0003}.video-player.loading,.video-player.error{background:#f5f5f5;color:#333;display:flex;align-items:center;justify-content:center;min-height:400px}.error-message{text-align:center;padding:40px}.error-message p{margin-bottom:20px;color:#d32f2f}.video-container{position:relative;width:100%;aspect-ratio:16/9;background:#000}.video-element{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.video-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.play-button-overlay{pointer-events:all;cursor:pointer}.play-icon{width:80px;height:80px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;transition:all .2s ease}.play-icon:hover{background:#000000e6;transform:scale(1.1)}.buffering-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.spinner{width:40px;height:40px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}.video-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000c);padding:20px 15px;opacity:1;transition:opacity .3s ease}.video-container:hover .video-controls{opacity:1}.progress-container{position:relative;margin-bottom:10px}.progress-slider{position:absolute;top:-2px;left:0;right:0;width:100%;height:8px;background:transparent;cursor:pointer;opacity:0;z-index:10;pointer-events:auto}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#1976d2;cursor:pointer}.controls-row{display:flex;justify-content:space-between;align-items:center;color:#fff}.left-controls,.right-controls{display:flex;align-items:center;gap:10px}.control-button{background:transparent!important;border:none!important;color:#fff!important;padding:8px!important;min-width:auto!important}.control-button:hover{background:#ffffff1a!important}.time-display{font-size:.9rem;color:#fff;margin-left:10px}.volume-control{display:flex;align-items:center;gap:8px}.volume-slider{width:80px;height:4px;background:#ffffff4d;border-radius:2px;outline:none;cursor:pointer}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer}@media(max-width:768px){.video-controls{padding:15px 10px;opacity:1}.controls-row{flex-wrap:wrap;gap:8px}.left-controls,.right-controls{flex:1;min-width:0}.left-controls{justify-content:flex-start}.right-controls{justify-content:flex-end}.volume-control{display:flex}.volume-slider{width:60px}.play-icon{width:60px;height:60px;font-size:1.5rem}.time-display{font-size:.8rem;margin-left:5px}}@media(max-width:480px){.video-controls{padding:10px 8px 8px}.controls-row{gap:6px}.control-button{padding:6px!important;min-width:32px!important}.volume-slider{width:50px}.time-display{font-size:.75rem;margin-left:3px}}.video-player:fullscreen{width:100vw;height:100vh;max-width:none}.video-player:-webkit-full-screen .video-container,.video-player:-moz-full-screen .video-container,.video-player:fullscreen .video-container{width:100vw;height:100vh}.video-player:-webkit-full-screen .time-display,.video-player:-moz-full-screen .time-display,.video-player:fullscreen .time-display{font-size:1.1rem}.responsive-grid{display:grid;grid-template-columns:repeat(var(--grid-columns, 1),1fr);gap:var(--grid-gap, 1rem);width:100%}.responsive-grid-item{grid-column:span var(--grid-span, 1)}.responsive-grid-item>*{max-width:100%;overflow-wrap:break-word}@media(max-width:768px){.responsive-grid{gap:.75rem}}@media(max-width:480px){.responsive-grid{gap:.5rem}}.responsive-grid.auto-fit{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.responsive-grid.auto-fill{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.responsive-grid.dense{grid-auto-flow:dense}.responsive-grid.masonry{grid-auto-rows:max-content}.responsive-grid.center-items{place-items:center}.responsive-grid.stretch-items{place-items:stretch}.touch-optimized{position:relative;cursor:pointer;-moz-user-select:none;user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .1s ease,opacity .1s ease}.touch-optimized.pressed{transform:scale(.98);opacity:.8}.touch-optimized.disabled{cursor:not-allowed;opacity:.5;pointer-events:none}.touch-optimized{min-height:44px;min-width:44px;display:flex;align-items:center;justify-content:center}.touch-optimized:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#0000001a;border-radius:50%;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease;pointer-events:none;z-index:-1}.touch-optimized.pressed:before{width:100%;height:100%}@media(max-width:768px){.touch-optimized{min-height:48px;min-width:48px}}@media(min-resolution:192dpi){.touch-optimized{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media(prefers-reduced-motion:reduce){.touch-optimized{transition:none}.touch-optimized:before{transition:none}}.pwa-install-prompt{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid rgba(0,0,0,.08);padding:16px;max-width:400px;width:calc(100% - 40px);z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.pwa-install-content{display:flex;align-items:center;gap:12px}.pwa-install-icon{flex-shrink:0;width:40px;height:40px;background:#2563eb;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff}.pwa-install-text{flex:1;min-width:0}.pwa-install-text h3{margin:0 0 4px;font-size:16px;font-weight:600;color:#1f2937}.pwa-install-text p{margin:0;font-size:14px;color:#6b7280;line-height:1.4}.pwa-install-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.pwa-install-actions .e-btn{min-width:80px;font-size:14px}@media(max-width:480px){.pwa-install-prompt{bottom:10px;left:10px;right:10px;transform:none;width:auto;max-width:none}.pwa-install-content{flex-direction:column;text-align:center;gap:16px}.pwa-install-actions{flex-direction:row;justify-content:center;width:100%}.pwa-install-actions .e-btn{flex:1}}@media(prefers-color-scheme:dark){.pwa-install-prompt{background:#1f2937;border-color:#374151}.pwa-install-text h3{color:#f9fafb}.pwa-install-text p{color:#d1d5db}.pwa-install-actions .e-btn.e-flat{color:#93c5fd!important;border-color:#374151!important}.pwa-install-actions .e-btn.e-flat:hover{background:#374151!important;color:#dbeafe!important}.pwa-install-actions .e-btn.e-primary{background:#2563eb!important;border-color:#2563eb!important;color:#fff!important}.pwa-install-actions .e-btn.e-primary:hover{background:#1d4ed8!important;border-color:#1d4ed8!important}}.pwa-update-notification{position:fixed;top:20px;right:20px;background:#059669;color:#fff;border-radius:8px;padding:12px 16px;box-shadow:0 4px 12px #00000026;z-index:1001;animation:slideIn .3s ease-out;max-width:300px}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.pwa-update-content{display:flex;align-items:center;gap:12px}.pwa-update-icon{flex-shrink:0;animation:spin 2s linear infinite}.pwa-update-text{flex:1;font-size:14px;font-weight:500}.pwa-update-notification .e-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:12px;padding:4px 12px;height:auto}.pwa-update-notification .e-btn:hover{background:#ffffff4d}.pwa-update-notification .e-btn:disabled{background:#ffffff1a;opacity:.7}@media(max-width:480px){.pwa-update-notification{top:10px;right:10px;left:10px;max-width:none}.pwa-update-content{justify-content:space-between}}.offline-indicator{position:fixed;top:60px;left:50%;transform:translate(-50%);border-radius:20px;padding:8px 16px;box-shadow:0 2px 8px #0000001a;z-index:999;animation:slideDown .3s ease-out;font-size:14px;max-width:300px}.offline-indicator.offline{background:#dc2626;color:#fff}.offline-indicator.online{background:#059669;color:#fff}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.offline-indicator-content{display:flex;align-items:center;gap:8px}.offline-indicator-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.offline-indicator-text{flex:1;font-weight:500;white-space:nowrap}.offline-indicator .e-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;font-size:12px;padding:4px 8px;height:auto;min-width:auto}.offline-indicator .e-btn:hover{background:#ffffff4d}.offline-indicator .e-btn:disabled{background:#ffffff1a;opacity:.7}@media(max-width:480px){.offline-indicator{top:50px;left:10px;right:10px;transform:none;max-width:none}.offline-indicator-content{justify-content:space-between}.offline-indicator-text{white-space:normal;line-height:1.3}}.offline-fallback{display:flex;align-items:center;justify-content:center;min-height:400px;padding:40px 20px;text-align:center}.offline-fallback-content{max-width:500px;width:100%}.offline-fallback-icon{color:#9ca3af;margin-bottom:24px;display:flex;justify-content:center}.offline-fallback-title{font-size:24px;font-weight:600;color:#1f2937;margin:0 0 16px}.offline-fallback-message{font-size:16px;color:#6b7280;line-height:1.6;margin:0 0 32px}.offline-fallback-actions{margin-bottom:40px}.offline-fallback-tips{background:#f9fafb;border-radius:12px;padding:24px;text-align:left}.offline-fallback-tips h4{font-size:16px;font-weight:600;color:#1f2937;margin:0 0 16px}.offline-fallback-tips ul{margin:0;padding-left:20px;color:#4b5563}.offline-fallback-tips li{margin-bottom:8px;line-height:1.5}.offline-fallback-tips li:last-child{margin-bottom:0}@media(prefers-color-scheme:dark){.offline-fallback-title{color:#f9fafb}.offline-fallback-message{color:#d1d5db}.offline-fallback-tips{background:#1f2937;border:1px solid #374151}.offline-fallback-tips h4{color:#f9fafb}.offline-fallback-tips ul{color:#d1d5db}}@media(max-width:480px){.offline-fallback{min-height:300px;padding:20px}.offline-fallback-title{font-size:20px}.offline-fallback-message{font-size:14px}.offline-fallback-tips{padding:16px}}.notification-settings{max-width:600px;margin:0 auto;padding:24px}.notification-settings-header{margin-bottom:24px}.notification-settings-header h3{font-size:24px;font-weight:600;color:#1f2937;margin:0 0 8px}.notification-settings-header p{font-size:16px;color:#6b7280;margin:0;line-height:1.5}.notification-settings-status{background:#f9fafb;border-radius:8px;padding:16px;margin-bottom:24px;border:1px solid #e5e7eb}.notification-status-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.notification-status-item:last-child{margin-bottom:0}.status-label{font-weight:500;color:#374151}.status-value{font-weight:600;padding:4px 8px;border-radius:4px;font-size:14px}.status-value.granted{background:#d1fae5;color:#065f46}.status-value.denied{background:#fee2e2;color:#991b1b}.notification-settings-actions{margin-bottom:32px}.notification-actions-group{display:flex;gap:12px;flex-wrap:wrap}.notification-blocked-message{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:16px;color:#92400e}.notification-blocked-message p{margin:0 0 12px;font-weight:500}.notification-blocked-message ol{margin:0;padding-left:20px}.notification-blocked-message li{margin-bottom:4px;line-height:1.4}.notification-preferences{border-top:1px solid #e5e7eb;padding-top:24px}.notification-preferences h4{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 8px}.notification-preferences>p{font-size:14px;color:#6b7280;margin:0 0 20px}.preference-list{display:flex;flex-direction:column;gap:16px}.preference-item{display:flex;flex-direction:column;gap:4px}.preference-description{font-size:14px;color:#6b7280;margin-left:24px;line-height:1.4}@media(prefers-color-scheme:dark){.notification-settings-header h3{color:#f9fafb}.notification-settings-header p{color:#d1d5db}.notification-settings-status{background:#1f2937;border-color:#374151}.status-label{color:#d1d5db}.notification-preferences{border-top-color:#374151}.notification-preferences h4{color:#f9fafb}.notification-preferences>p{color:#d1d5db}.preference-description{color:#d1d5db}}@media(max-width:480px){.notification-settings{padding:16px}.notification-settings-header h3{font-size:20px}.notification-actions-group{flex-direction:column}.notification-actions-group .e-btn{width:100%}.notification-status-item{flex-direction:column;align-items:flex-start;gap:4px}}.notification-prompt{position:fixed;top:20px;right:20px;background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid rgba(0,0,0,.08);padding:16px;max-width:350px;width:calc(100% - 40px);z-index:1000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.notification-prompt-content{display:flex;align-items:center;gap:12px}.notification-prompt-icon{flex-shrink:0;width:48px;height:48px;background:#3b82f6;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff}.notification-prompt-text{flex:1;min-width:0}.notification-prompt-text h3{margin:0 0 4px;font-size:16px;font-weight:600;color:#1f2937;line-height:1.2}.notification-prompt-text p{margin:0;font-size:13px;color:#6b7280;line-height:1.5}.notification-prompt-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.notification-prompt-actions .e-btn{font-size:13px;padding:8px 16px;height:auto;min-width:120px;white-space:nowrap}@media(prefers-color-scheme:dark){.notification-prompt{background:#1f2937;border-color:#374151}.notification-prompt-text h3{color:#f9fafb}.notification-prompt-text p{color:#d1d5db}.notification-prompt-actions .e-btn.e-flat{color:#93c5fd!important;border-color:#374151!important}.notification-prompt-actions .e-btn.e-flat:hover{background:#374151!important;color:#dbeafe!important}.notification-prompt-actions .e-btn.e-primary{background:#3b82f6!important;border-color:#3b82f6!important;color:#fff!important}.notification-prompt-actions .e-btn.e-primary:hover{background:#2563eb!important;border-color:#2563eb!important}}@media(max-width:480px){.notification-prompt{top:10px;right:10px;left:10px;width:auto;max-width:none;padding:14px}.notification-prompt-content{flex-wrap:wrap;gap:12px}.notification-prompt-icon{width:40px;height:40px}.notification-prompt-text{flex:1 1 100%}.notification-prompt-actions{flex-direction:row;width:100%;margin-left:52px}.notification-prompt-actions .e-btn{flex:1;min-width:auto}}.native-push-notifications{position:fixed;top:20px;right:20px;z-index:10000;max-width:350px}.push-notification{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-bottom:10px;padding:16px;cursor:pointer;transition:all .3s ease;position:relative;animation:slideIn .3s ease-out}.push-notification:hover{box-shadow:0 6px 16px #0003;transform:translateY(-2px)}.notification-content{padding-right:20px}.notification-title{font-weight:600;font-size:14px;color:#333;margin-bottom:4px;line-height:1.4}.notification-body{font-size:13px;color:#666;line-height:1.4;margin-bottom:8px}.notification-type{font-size:11px;color:#2563eb;text-transform:uppercase;font-weight:500;letter-spacing:.5px}.notification-dismiss{position:absolute;top:8px;right:8px;background:none;border:none;font-size:18px;color:#999;cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.notification-dismiss:hover{background:#f5f5f5;color:#666}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media(prefers-color-scheme:dark){.push-notification{background:#2d2d2d;border-color:#404040;color:#fff}.notification-title{color:#fff}.notification-body{color:#ccc}.notification-dismiss:hover{background:#404040;color:#fff}}@media(max-width:768px){.native-push-notifications{top:10px;right:10px;left:10px;max-width:none}.push-notification{margin-bottom:8px;padding:12px}.notification-title{font-size:13px}.notification-body{font-size:12px}}.avatar{position:relative;display:inline-block;border-radius:50%;overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:50%}.avatar-initials{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;border-radius:50%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.avatar:not(.avatar-fallback) .avatar-initials{display:none}.avatar-fallback .avatar-initials{display:flex}.avatar-small{width:20px;height:20px}.avatar-small .avatar-initials{font-size:9px}.avatar-medium{width:44px;height:44px}.avatar-medium .avatar-initials{font-size:16px}.avatar-large{width:48px;height:48px}.avatar-large .avatar-initials{font-size:18px}.avatar-xs{width:20px;height:20px}.avatar-xs .avatar-initials{font-size:8px}.avatar-xl{width:64px;height:64px}.avatar-xl .avatar-initials{font-size:24px}.avatar:hover{transform:scale(1.05);transition:transform .2s ease}.avatar:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.course-viewer{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column;position:relative}.next-lesson-notification{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}.course-completed-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0009;z-index:3000;padding:24px}.course-completed-modal .modal-content{background:#fff;border-radius:12px;padding:28px;max-width:560px;width:100%;box-shadow:0 8px 40px #00000059;text-align:center}.course-completed-modal .modal-content .check-icon-large{margin:0 auto 16px}.course-completed-modal .modal-content h3{margin:0 0 8px;font-size:1.4rem;color:#111827}.course-completed-modal .modal-content p{margin:0 0 18px;color:#4b5563}.course-completed-modal .modal-actions{display:flex;gap:12px;justify-content:center;align-items:center;margin-top:8px}.course-completed-modal .modal-actions .e-btn{min-width:140px}@media(max-width:480px){.course-completed-modal{padding:12px}.course-completed-modal .modal-content{padding:18px}.course-completed-modal .modal-actions{flex-direction:column;gap:10px}.course-completed-modal .modal-actions .e-btn{width:100%;min-width:0}}.notification-content{background:#fff;border-radius:12px;padding:40px;text-align:center;box-shadow:0 4px 20px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.check-icon-large{display:inline-block;width:60px;height:60px;background:#4caf50;color:#fff;border-radius:50%;font-size:2rem;line-height:60px;margin-bottom:20px;animation:checkPulse .6s ease}@keyframes checkPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.notification-content h3{margin:0 0 10px;font-size:1.5rem;font-weight:600;color:#333}.notification-content p{margin:0;font-size:1rem;color:#666}.course-viewer.loading,.course-viewer.error,.course-viewer.not-enrolled{display:flex;align-items:center;justify-content:center;position:fixed;inset:0;z-index:1000;background:#f5f5f5e6}.loading-spinner,.error-message,.enrollment-prompt{text-align:center;padding:40px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.course-header-bar{background:#fff;padding:15px 20px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;gap:20px}.back-button{background:transparent!important;border:1px solid #ddd!important;color:#333!important;min-height:40px;padding:8px 16px;border-radius:6px;font-weight:500;transition:all .2s ease;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.back-button:hover{background:#f5f5f5!important;border-color:#bbb!important}.back-button:active{background:#e8e8e8!important;transform:translateY(1px)}.back-button{position:relative;z-index:10;pointer-events:auto;-webkit-tap-highlight-color:rgba(0,0,0,.1)}.course-header-bar{position:relative;z-index:5;overflow:visible}@media(max-width:768px){.back-button{position:relative;z-index:15;overflow:visible;box-sizing:border-box;min-height:44px!important;min-width:44px!important;touch-action:manipulation;flex-shrink:0;font-size:.9rem!important;line-height:1.2}.course-header-bar{overflow:visible;min-height:60px;display:flex;align-items:center;justify-content:flex-start}}@media(max-width:768px){.back-button.e-btn{min-height:44px!important;min-width:120px!important;padding:10px 16px!important;border-radius:6px!important;font-size:.9rem!important}.back-button.e-btn .e-btn-content{display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap}.back-button.e-btn .e-btn-icon{font-size:1rem}}@media(max-width:480px){.back-button{position:relative!important;z-index:999!important;background:#fff!important;border:2px solid #ddd!important;box-shadow:0 2px 4px #0000001a!important;min-height:48px!important;min-width:120px!important;padding:12px 16px!important;font-size:.85rem!important;font-weight:600!important;border-radius:8px!important;pointer-events:auto!important;touch-action:manipulation!important;-webkit-tap-highlight-color:rgba(0,0,0,.1)!important}.back-button:active{background:#f0f0f0!important;transform:scale(.98)!important}.course-header-bar{padding:12px 16px!important;min-height:70px!important;background:#fff!important;border-bottom:2px solid #e0e0e0!important;position:relative!important;z-index:100!important}}.course-header-bar h1{margin:0;font-size:1.5rem;font-weight:600;color:#333}.course-content{display:flex;flex-direction:column;align-items:stretch;gap:20px;padding:20px;width:100%;flex:1;min-height:0;max-width:1400px;margin:0 auto}.video-section{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;min-height:500px;max-height:80vh;display:flex;flex-direction:column;width:100%}.no-lesson-selected{display:flex;align-items:center;justify-content:center;flex:1;min-height:300px;color:#666;font-size:1.1rem;text-align:center;padding:20px}.youtube-placeholder{width:100%;height:100%;min-height:300px;background:#000;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;position:relative}.youtube-placeholder:before{content:"▶";font-size:4rem;opacity:.7}.course-sidebar{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;min-height:500px;max-height:none;display:flex;flex-direction:column;width:100%}.lesson-list{padding:20px;flex:1;overflow-y:auto;width:100%;box-sizing:border-box;min-height:0}.course-progress-summary{margin-bottom:30px;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.course-progress-summary h4{margin:0 0 15px;font-size:1.1rem;font-weight:600;color:#333}.progress-stats{display:flex;flex-direction:column;gap:8px}.progress-stats span{font-size:.9rem;color:#666}.lessons{display:flex;flex-direction:column;gap:10px}.lesson-item{display:flex;gap:15px;padding:15px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease;width:100%;box-sizing:border-box;align-items:flex-start;min-height:60px;min-width:100%}.lesson-item:hover{border-color:#1976d2;background:#f8f9ff}.lesson-item.active{border-color:#1976d2;background:#e3f2fd}.lesson-item.completed{background:#f1f8e9;border-color:#4caf50}.lesson-number{width:32px;height:32px;border-radius:50%;background:#e0e0e0;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0}.lesson-item.active .lesson-number{background:#1976d2;color:#fff}.lesson-item.completed .lesson-number{background:#4caf50;color:#fff}.lesson-item.completed.active{background:linear-gradient(90deg,#4caf500f,#1976d20f);border-color:#1976d2;box-shadow:0 0 0 4px #1976d20f}.lesson-item.completed.active .lesson-number{background:#1976d2;color:#fff}.lesson-item.completed.active .check-icon{font-size:1.05rem}.check-icon{font-size:1rem}.lesson-content{flex:1;min-width:0}.lesson-content h5{margin:0 0 5px;font-size:1rem;font-weight:600;color:#333;word-wrap:break-word;overflow-wrap:break-word}.lesson-content p{margin:0 0 10px;font-size:.9rem;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lesson-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.8rem;color:#666}.course-info{padding:24px;flex:1;overflow-y:auto;width:100%;box-sizing:border-box;min-height:0;max-width:1040px;margin:0 auto}.course-info-grid{display:grid;grid-template-columns:1fr;gap:24px}.course-info-main{display:flex;flex-direction:column;gap:16px}.course-title{margin:0;font-size:1.6rem;font-weight:600;color:#1f2937}.course-description{margin:0;color:#4b5563;line-height:1.6;font-size:.95rem;max-width:70ch}.course-meta{display:flex;flex-wrap:wrap;gap:10px;margin:0}.difficulty-badge,.category-badge{padding:6px 12px;border-radius:6px;font-size:.8rem;font-weight:500;text-transform:uppercase}.course-updated{font-size:.85rem;color:#6b7280}.course-info-side{display:flex;flex-direction:column;gap:16px}.course-info-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0f172a14}.course-info-panel h4{margin:0 0 12px;font-size:1.05rem;font-weight:600;color:#1f2937}.course-highlight-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.course-highlight-item{background:#f9fafb;border:1px solid #eef2f6;border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:6px}.course-highlight-label{font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;color:#6b7280}.course-highlight-value{font-size:1.1rem;font-weight:600;color:#111827}.course-info-side .course-info-panel:last-child{margin-bottom:0}@media(min-width:1024px){.course-info{padding:28px}.course-info-grid{grid-template-columns:minmax(0,1.75fr) minmax(280px,1fr);align-items:start}}@media(min-width:1280px){.course-info-grid{grid-template-columns:minmax(0,2fr) minmax(320px,1fr)}}.instructor-card{display:flex;gap:15px;align-items:center;padding:16px;background:#f8f9fa;border-radius:10px;border:1px solid #e5e7eb}.instructor-card img{width:60px;height:60px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.instructor-card h5{margin:0 0 5px;font-size:1rem;font-weight:600;color:#333}.instructor-card p{margin:0;font-size:.9rem;color:#666;line-height:1.4}.course-sidebar .e-tab-content{flex:1;overflow:hidden;width:100%;min-height:0;position:static}.course-sidebar .e-content{height:100%;overflow:hidden;width:100%;box-sizing:border-box;display:flex;flex-direction:column;position:static}.course-sidebar .e-tab-header{width:100%;flex-shrink:0;position:static}.course-sidebar .e-tab{width:100%;height:100%;display:flex;flex-direction:column;position:static}@media(max-width:1024px){.course-content{gap:15px;padding:15px}.video-section,.course-sidebar{min-height:400px}}@media(max-width:768px){.course-content{padding:10px;gap:10px}.course-info{padding:16px}.course-info-grid{gap:16px}.course-info-panel{padding:16px}.course-header-bar{padding:10px 15px;flex-wrap:wrap;gap:10px}.course-header-bar h1{font-size:1.25rem;word-break:break-word;flex:1;min-width:0}.back-button{margin-bottom:5px;min-height:44px!important;min-width:120px!important;padding:8px 16px!important;font-size:.9rem!important;white-space:nowrap;flex-shrink:0}.video-section{min-height:300px}.course-sidebar{min-height:350px}.lesson-item{padding:12px;gap:12px}.lesson-number{width:28px;height:28px;font-size:.8rem}.lesson-content h5{font-size:.95rem;line-height:1.3}.lesson-content p{font-size:.85rem;-webkit-line-clamp:1}.lesson-meta{font-size:.75rem}.instructor-card{flex-direction:column;text-align:center;gap:10px}.instructor-card img{width:50px;height:50px}.course-progress-summary{margin-bottom:20px;padding-bottom:15px}.progress-stats{gap:6px}.progress-stats span{font-size:.85rem}.course-highlight-list{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}}@media(max-width:480px){.course-content{padding:8px;gap:8px}.course-header-bar{padding:8px 12px;flex-direction:column;align-items:flex-start;gap:8px}.course-header-bar h1{font-size:1.1rem;width:100%;margin-top:0}.back-button{min-height:44px!important;min-width:140px!important;padding:10px 16px!important;font-size:.85rem!important;width:auto;align-self:flex-start}.course-info{padding:14px}.video-section{min-height:250px}.course-sidebar{min-height:300px}.lesson-list,.course-info{padding:15px}.lesson-item{padding:18px 10px;gap:10px;min-height:80px}.lesson-number{width:24px;height:24px;font-size:.75rem}.lesson-content h5{font-size:.9rem}.lesson-content p{font-size:.8rem}.course-meta{gap:8px}.difficulty-badge,.category-badge{padding:4px 8px;font-size:.75rem}.course-highlight-list{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}}@media(min-width:1400px){.course-content{gap:30px;padding:30px}.video-section,.course-sidebar{min-height:600px}}.course-viewer *{box-sizing:border-box}.lesson-list::-webkit-scrollbar,.course-info::-webkit-scrollbar{width:6px}.lesson-list::-webkit-scrollbar-track,.course-info::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.lesson-list::-webkit-scrollbar-thumb,.course-info::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.lesson-list::-webkit-scrollbar-thumb:hover,.course-info::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.course-header-bar h1{overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.progress-stats .e-progressbar{margin:4px 0}.lesson-content .e-progressbar{margin-top:4px}.course-sidebar .e-tab-header .e-tab-text{font-weight:500;font-size:.95rem}.instructor-card h5{word-wrap:break-word;overflow-wrap:break-word}.youtube-player{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.youtube-player iframe{width:100%;height:100%;border:none;border-radius:8px}.lesson-video{flex:1;width:100%;height:100%;position:relative}.video-section .youtube-player,.video-section .lesson-video{position:relative}@media(min-width:1024px){.video-section .video-player{margin-top:24px;margin-bottom:24px}}.lesson-item:focus,.lessons .touch-optimized:focus{outline:2px solid #1976d2;outline-offset:2px}.lessons .touch-optimized:focus-visible{outline:2px solid #1976d2;outline-offset:2px}.back-button:focus{outline:2px solid #1976d2;outline-offset:2px}.lesson-content p{word-break:break-word;overflow-wrap:break-word}.lessons>.lesson-item:last-child{margin-bottom:0}.course-content{align-items:start}@media(max-width:768px){.lesson-item{min-height:72px;padding:16px 12px}.back-button{min-height:44px;min-width:44px}}@media(max-width:480px){.youtube-player iframe{min-height:200px!important}.video-section{min-height:220px!important}}.course-viewer{position:relative}.lessons .touch-optimized{width:100%;min-height:auto;justify-content:flex-start;align-items:flex-start}.lessons .touch-optimized.lesson-item{min-height:60px}.lessons .touch-optimized.pressed{transform:scale(.99);opacity:.9}.lesson-item *{pointer-events:none}.lesson-item{pointer-events:auto}.lessons .touch-optimized{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.lesson-list{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}@media(min-width:1025px){.video-section,.course-sidebar{position:relative}}@media(max-width:768px){.course-sidebar{position:static!important;float:none!important;clear:both;width:100%!important;margin:0!important;inset:auto!important}.course-sidebar .e-tab-header,.course-sidebar .e-tab-content,.course-sidebar .e-content,.course-sidebar .e-tab{position:static!important;float:none!important}.video-section{position:static!important;float:none!important;width:100%!important}}@media(max-width:480px){.course-sidebar{position:static!important;transform:none!important}.course-sidebar .e-tab-header{position:static!important}}@media(max-width:360px){.course-header-bar{padding:6px 10px}.back-button{min-width:100px!important;font-size:.8rem!important;padding:8px 12px!important}.course-header-bar h1{font-size:1rem;line-height:1.2}}.my-enrollments{padding:20px;max-width:1200px;margin:0 auto}.my-enrollments.loading,.my-enrollments.empty{display:flex;align-items:center;justify-content:center;min-height:400px}.empty-state.no-enrollments{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:260px;padding:40px 20px;width:100%;margin:0 auto;text-align:center}.enrollments-header{margin-bottom:30px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.enrollments-header h2{margin:0 0 8px;color:#111827;font-size:20px;font-weight:600;letter-spacing:-.01em;line-height:1.25}.enrollments-header h2:after{content:"";display:block;width:48px;height:3px;margin-top:10px;border-radius:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.enrollments-header p{margin:0;color:#6b7280;font-size:1rem;font-weight:500;max-width:720px}.my-enrollments-header-left{display:flex;flex-direction:column;gap:6px}.my-enrollments .header-right{display:flex;align-items:center;margin-left:auto}.my-enrollments .show-hidden-switch{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;padding:4px 6px;border-radius:6px}.my-enrollments .show-hidden-switch .switch-input{position:absolute;left:0;top:0;width:46px;height:26px;margin:0;opacity:0;cursor:pointer;z-index:2}.my-enrollments .show-hidden-switch .switch-slider{width:46px;height:26px;background:#e5e7eb;border-radius:999px;position:relative;transition:background .2s ease;box-shadow:inset 0 1px 2px #0000000f;display:inline-block;vertical-align:middle;z-index:1}.my-enrollments .show-hidden-switch .switch-slider:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .18s ease;box-shadow:0 1px 2px #0000001f}.my-enrollments .show-hidden-switch .switch-input:checked+.switch-slider{background:linear-gradient(90deg,#667eea,#764ba2)}.my-enrollments .show-hidden-switch .switch-input:checked+.switch-slider:after{transform:translate(20px)}.my-enrollments .show-hidden-switch .switch-label{font-size:.95rem;color:#374151;font-weight:500;margin-left:6px}.my-enrollments .show-hidden-switch .switch-input:focus+.switch-slider:after{box-shadow:0 0 0 3px #667eea2e}.enrollments-grid{display:grid;grid-template-columns:1fr;gap:20px}@media(min-width:1024px){.enrollments-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.enrollment-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column;height:100%}.enrollment-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.course-thumbnail{height:180px;background:#f5f5f5;display:flex;align-items:center;justify-content:center;overflow:hidden}.course-thumbnail img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.course-placeholder{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:700}.enrollment-content{padding:20px;display:flex;flex-direction:column;flex:1;gap:12px}.course-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;gap:10px}.course-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#333;line-height:1.4;flex:1}.status-badge{padding:4px 8px;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:uppercase;flex-shrink:0}.status-badge.active{background:#e8f5e8;color:#2e7d32}.status-badge.completed{background:#e3f2fd;color:#1976d2}.status-badge.dropped{background:#ffebee;color:#c62828}.course-description{margin:0 0 15px;color:#666;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-meta{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}.difficulty-badge,.category-badge{padding:4px 8px;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:uppercase}.difficulty-badge.beginner{background:#e8f5e8;color:#2e7d32}.difficulty-badge.intermediate{background:#fff3e0;color:#f57c00}.difficulty-badge.advanced{background:#ffebee;color:#c62828}.category-badge{background:#e3f2fd;color:#1976d2}.enrollment-info{margin-bottom:20px;display:flex;flex-direction:column;gap:5px}.enrollment-info span{font-size:.9rem;color:#666}.progress-section{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-header span:first-child{font-weight:500;color:#333}.progress-header span:last-child{font-weight:600;color:#4caf50}.progress-stats{margin-top:8px;font-size:.9rem;color:#666}.enrollment-actions{display:flex;flex-direction:row;gap:10px;margin-top:auto;padding:15px 20px 20px;border-top:1px solid #f0f0f0;background:#fff}.enrollment-actions .e-btn{flex:1;max-width:none!important;display:inline-block!important;box-sizing:border-box!important;margin:0!important}@media(max-width:768px){.my-enrollments{padding:15px}.enrollments-grid{grid-template-columns:1fr}.course-header{flex-direction:column;align-items:flex-start;gap:10px}.enrollment-actions{flex-direction:column}.enrollment-info{font-size:.85rem}}.course-form{width:100%}.create-course-page .course-form{max-width:800px;margin:0 auto;padding:2rem;background:var(--surface-card);border-radius:8px;box-shadow:0 2px 8px #0000001a}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.95rem}.form-label.required:after{content:" *";color:var(--danger-color, #e74c3c)}.form-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color, #ddd);border-radius:4px;font-family:inherit;font-size:.95rem;resize:vertical;transition:border-color .2s}.form-textarea:focus{outline:none;border-color:var(--primary-color, #3b82f6)}.form-textarea.error{border-color:var(--danger-color, #e74c3c)}.form-textarea:disabled{background-color:var(--disabled-bg, #f5f5f5);cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}}.error-message{display:block;margin-top:.25rem;color:var(--danger-color, #e74c3c);font-size:.85rem}.thumbnail-preview{margin-top:1rem;border:1px solid var(--border-color, #ddd);border-radius:4px;overflow:hidden;max-width:400px}.thumbnail-preview img{width:100%;height:auto;display:block}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color, #eee)}.form-actions .e-btn{min-width:120px}.course-form .e-input-group,.course-form .e-dropdownbase{width:100%}.course-form .e-input-group.e-error{border-color:var(--danger-color, #e74c3c)}.create-course-page{max-width:1200px;margin:0 auto;padding:2rem;min-height:calc(100vh - 80px)}.create-course-header{text-align:center;margin-bottom:3rem}.create-course-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;color:var(--text-primary)}.create-course-header p{font-size:1.1rem;color:var(--text-secondary)}@media(max-width:768px){.create-course-page{padding:1rem}.create-course-header h1{font-size:2rem}.create-course-header p{font-size:1rem}}.certificates{padding:24px;max-width:1200px;margin:0 auto;min-height:100%;box-sizing:border-box}.certificates.loading,.certificates.empty{display:flex;align-items:center;justify-content:center;min-height:400px;height:100%}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.empty-state{text-align:center;padding:40px}.empty-state h3{margin:0 0 15px;color:#333;font-size:1.5rem}.empty-state p{margin:0;color:#666;font-size:1.1rem}.certificates-header{margin-bottom:30px}.certificates-header h2{margin:0 0 8px;color:#111827;font-size:20px;font-weight:600;letter-spacing:-.01em;line-height:1.25}.certificates-header p{margin:0;color:#6b7280;font-size:1rem;font-weight:500;max-width:720px}.certificates-header h2:after{content:"";display:block;width:48px;height:3px;margin-top:10px;border-radius:4px;background:linear-gradient(90deg,#667eea,#764ba2)}.certificates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px;margin-bottom:24px}.certificate-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;color:#fff;box-shadow:0 8px 24px #00000026;transition:transform .2s ease,box-shadow .2s ease;position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:320px}.certificate-card:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);pointer-events:none}.certificate-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0003}.certificate-header{display:flex;align-items:center;gap:15px;margin-bottom:20px}.certificate-icon{font-size:2.5rem;background:#fff3;border-radius:50%;width:60px;height:60px;display:flex;align-items:center;justify-content:center}.certificate-info h3{margin:0 0 5px;font-size:1.2rem;font-weight:600}.certificate-number{margin:0;font-size:.9rem;opacity:.9;font-family:monospace}.certificate-content{margin-bottom:24px;flex:1}.certificate-content h4{margin:0 0 15px;font-size:1.4rem;font-weight:700;line-height:1.3}.course-details{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}.difficulty-badge,.category-badge{padding:6px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.instructor-info{margin-bottom:8px;font-size:.95rem;opacity:.9}.certificate-date{font-size:.9rem;opacity:.8}.certificate-actions{display:flex;gap:12px}.certificate-actions .e-btn{flex:1;background:#fff3!important;border:1px solid rgba(255,255,255,.3)!important;color:#fff!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s ease}.certificate-actions .e-btn:hover{background:#ffffff4d!important;transform:translateY(-1px)}.certificate-actions .e-btn.e-primary{background:#ffffffe6!important;color:#333!important}.certificate-actions .e-btn.e-primary:hover{background:#fff!important}.certificate-actions .e-btn.e-danger{background:#d64113!important;border-color:transparent!important;color:#fff!important}.certificate-actions .e-btn.e-danger:hover{background:#db582f!important;transform:translateY(-1px)}.certificate-actions .copy-wrapper{flex:1}.certificate-actions .copy-wrapper .e-btn{width:100%}@media(max-width:768px){.certificates{padding:16px}.certificates-grid{grid-template-columns:1fr;gap:16px}.certificate-card{padding:20px;min-height:280px}.certificate-header{flex-direction:row;text-align:left;gap:12px}.certificate-actions{flex-direction:column;gap:8px}.course-details{justify-content:flex-start}}@media(max-width:480px){.certificates{padding:12px}.certificates-grid{gap:12px}.certificate-card{padding:16px;border-radius:12px;min-height:260px}.certificate-header{flex-direction:column;text-align:center;gap:8px}.certificate-icon{width:50px;height:50px;font-size:2rem}.course-details{justify-content:center}}.delete-confirm-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:100000}.delete-confirm-dialog{background:#fff;border-radius:8px;box-shadow:0 8px 24px #0003;max-width:520px;width:90%;padding:18px}.delete-confirm-header h3{margin:0 0 8px;font-size:18px}.delete-confirm-content p{margin:0 0 16px;color:#333}.delete-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.delete-confirm-cancel{background:transparent;border:1px solid #ccc;padding:8px 12px;border-radius:4px;cursor:pointer}.delete-confirm-delete{background:#e11d48;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer}.delete-confirm-delete:hover{background:#c71b45}.courses-page{min-height:100vh;background:#f8f9fa}.courses-header{background:#fff;padding:40px 20px 20px;text-align:center;border-bottom:1px solid #e0e0e0}.courses-header h1{margin:0 0 8px;font-size:28px;font-weight:700;color:#333;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.courses-header p{font-size:16px;color:#666;max-width:500px;margin:0 auto}.courses-page .e-tab-header{background:#fff;border-bottom:1px solid #e0e0e0}.courses-layout{display:flex;max-width:1200px;margin:0 auto;gap:20px;padding:0 20px}.courses-main{flex:1;max-width:none;width:100%;min-width:0}.courses-page .e-content{background:#fff;min-height:calc(100vh - 200px);overflow:hidden;border-radius:4px;box-shadow:0 0 #0000}.courses-page .e-content .e-item{height:100%;overflow-y:auto;padding:0 0 24px}.courses-page .e-content .e-item.e-active{display:flex;flex-direction:column}@media(max-width:768px){.courses-header{padding:20px 16px 16px}.courses-header h1{font-size:1.25rem}.courses-header p{font-size:14px}}@media(max-width:480px){.courses-header h1{font-size:1.125rem}}.data-table-wrapper{width:100%;background:#fff;border-radius:8px;overflow:hidden;border:1px solid #e5e7eb}.data-table-container{overflow-x:auto;overflow-y:auto}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb;position:sticky;top:0;z-index:10}.data-table th{padding:12px 16px;font-weight:600;color:#374151;text-align:left;-webkit-user-select:none;-moz-user-select:none;user-select:none}.data-table th.expand-column{width:40px;padding:12px 8px}.data-table .th-content{display:flex;align-items:center;gap:8px}.data-table .sort-icon{opacity:.5;font-size:12px}.data-table th:hover .sort-icon{opacity:1}.data-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s ease}.data-table tbody tr:hover{background:#f9fafb}.data-table tbody tr.detail-row,.data-table tbody tr.detail-row:hover{background:#f3f4f6}.data-table td{padding:12px 16px;color:#6b7280}.data-table td.expand-cell{padding:12px 8px;width:40px}.data-table td.detail-cell{padding:16px}.data-table .expand-button{width:24px;height:24px;border:1px solid #d1d5db;background:#fff;border-radius:4px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;line-height:1;transition:all .15s ease}.data-table .expand-button:hover{background:#f3f4f6;border-color:#9ca3af}.data-table .no-data{text-align:center;padding:32px;color:#9ca3af;font-style:italic}.data-table-pagination{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-top:1px solid #e5e7eb;background:#f9fafb}.pagination-info{font-size:14px;color:#6b7280}.pagination-controls{display:flex;align-items:center;gap:8px}.pagination-controls .page-numbers{padding:0 12px;font-size:14px;color:#374151;font-weight:500}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.payment-actions{display:flex;gap:8px}@media(max-width:768px){.data-table th,.data-table td{padding:8px 12px;font-size:13px}.data-table-pagination{flex-direction:column;gap:12px;align-items:stretch}.pagination-controls{justify-content:center}.pagination-info{text-align:center}}.course-management{padding:24px;max-width:1600px;margin:0 auto}.course-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.course-management-header h2{margin:0;font-size:24px;font-weight:600;color:#1e293b}.course-grid-container{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.course-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.course-dialog-panel{background:#fff;border-radius:8px;box-shadow:0 8px 32px #00000026;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.course-dialog-panel .panel-header,.confirmation-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.course-dialog-panel .panel-header h2,.confirmation-panel .panel-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.course-dialog-panel .close-button,.confirmation-panel .close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.course-dialog-panel .close-button:hover,.confirmation-panel .close-button:hover{background:#f5f5f5;color:#333}.course-dialog-panel .panel-content,.confirmation-panel .panel-content{flex:1;padding:20px 24px;overflow-y:auto;min-height:0}.course-dialog-panel .panel-footer,.confirmation-panel .panel-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e0e0e0;flex-shrink:0}.course-management .e-small svg,.course-management .e-small .lucide{display:inline-block;vertical-align:middle;margin-top:-2px}.course-management .action-buttons .e-btn.e-secondary{background-color:#10b981!important;border-color:#10b981!important;color:#fff!important}.course-management .action-buttons .e-btn.e-secondary:hover{background-color:#059669!important;border-color:#059669!important}.course-dialog-panel .panel-footer .e-btn.e-outline{background-color:#10b981!important;border-color:#10b981!important;color:#fff!important}.course-dialog-panel .panel-footer .e-btn.e-outline:hover{background-color:#059669!important;border-color:#059669!important}.delete-dialog-content{padding:0}.delete-dialog-content p{margin:0 0 16px;line-height:1.6}@media(max-width:768px){.course-management{padding:16px}.course-management-header{flex-direction:column;gap:16px;align-items:stretch}.course-management-header .e-btn{width:100%}}.channels-list{display:flex;flex-direction:column;height:100%;background:#fff;border-right:1px solid #e0e0e0;overflow:hidden}.channels-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0}.channels-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.join-channel-btn{width:32px;height:32px;border:none;border-radius:50%;background:#007bff;color:#fff;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #007bff33}.join-channel-btn:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 4px 8px #007bff4d}.join-channel-btn:active{transform:translateY(0);box-shadow:0 2px 4px #007bff33}.search-input{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;outline:none;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.search-input::-moz-placeholder{color:#6c757d}.search-input::placeholder{color:#6c757d}.channels-search{padding:16px;border-bottom:1px solid #e0e0e0}.channels-container{flex:1;overflow-y:auto;min-height:0}.channels-list-items{display:flex;flex-direction:column}.channel-item-wrapper{position:relative;display:flex;align-items:center}.channel-item-wrapper.active{border-right:3px solid #2196f3}.channel-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 48px 12px 16px;border:none;border-bottom:1px solid #f0f0f0;background:#fff;text-align:left;cursor:pointer;transition:background-color .2s ease;font:inherit;color:inherit}.channel-item:hover,.channel-item:focus-visible{background-color:#f8f9fa;outline:none}.channel-item.active{background-color:#e3f2fd}.channel-item.active:hover,.channel-item.active:focus-visible{background-color:#dbeaf9}.channels-list-items .channel-item-wrapper:last-of-type .channel-item{border-bottom:none}.channel-avatar{position:relative;width:40px;height:40px;border-radius:50%;background:#2196f3;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;flex-shrink:0}.channel-info{flex:1;min-width:0}.channel-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;background:transparent}.channel-name{font-size:14px;font-weight:600;color:#333;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.channel-time{font-size:12px;color:#666;white-space:nowrap}.private-indicator{font-size:12px;opacity:.7;margin-left:4px}.channel-preview{display:flex;justify-content:space-between;align-items:center}.channel-menu-container{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:center;justify-content:center;width:48px;background:transparent;transition:background-color .2s ease;pointer-events:auto}.channel-item-wrapper.active .channel-menu-container{background-color:#e3f2fd}.channel-item-wrapper:hover .channel-menu-container{background-color:#f8f9fa}.channel-item-wrapper.active:hover .channel-menu-container{background-color:#dbeaf9}.channel-menu-button{width:28px;height:28px;border:none;border-radius:50%;background:transparent;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:1;pointer-events:auto;position:relative;z-index:1000;outline:none}.channel-item-wrapper:hover .channel-menu-button{opacity:1}.channel-menu-button:hover{background:#6366f11a;color:#6366f1}.channel-menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #00000026;z-index:1050;min-width:140px;overflow:visible;animation:slideDown .2s ease-out;pointer-events:auto;transform:translateZ(0);will-change:transform,opacity}.channel-menu-item{width:100%;padding:10px 12px;border:none;background:#fff;color:#374151;text-align:left;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;white-space:nowrap;transition:background-color .2s ease;pointer-events:auto;position:relative;z-index:1051;outline:none}.channel-menu-item:hover{background:#f9fafb}.channel-menu-item-danger{color:#dc2626}.channel-menu-item-danger:hover{background:#fef2f2}.loading-state,.no-channels{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;text-align:center;color:#666}.no-channels p{margin-bottom:16px}.join-channel-cta{padding:8px 16px;border:none;border-radius:6px;background:#007bff;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;margin-top:12px}.join-channel-cta:hover{background:#0056b3}.error-message{padding:12px 16px;background:#fef2f2;color:#dc2626;border-bottom:1px solid #fecaca;font-size:14px}@media(max-width:768px){.channels-header,.channels-search{padding:12px}.channel-item{padding:10px 40px 10px 12px}.channel-avatar{width:40px;height:40px}.channel-name{font-size:13px}.last-message{font-size:12px}.channel-menu-container{width:40px}.channel-menu-button{width:24px;height:24px;opacity:1;pointer-events:auto}.channel-menu-dropdown{min-width:140px;right:-4px}.channel-menu-item{padding:8px 12px;font-size:12px;white-space:nowrap}.channel-meta{flex-direction:column;gap:4px}}.report-dialog-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:100000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.report-dialog-panel{background:#fff;border-radius:12px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003;animation:dialogSlideIn .2s ease-out}@keyframes dialogSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 20px;border-bottom:1px solid #e5e7eb}.panel-header h2{margin:0;font-size:1.375rem;font-weight:600;color:#111827}.close-button{background:none;border:none;cursor:pointer;color:#6b7280;padding:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.close-button:hover{background-color:#f3f4f6;color:#111827}.panel-content{padding:24px}.result-container{text-align:center;padding:20px 0}.success-message{display:flex;align-items:center;gap:12px;background-color:#ecfdf5;color:#065f46;padding:16px;border-radius:8px;border:1px solid #a7f3d0;margin-bottom:16px;font-size:.95rem}.success-icon{flex-shrink:0;color:#10b981}.success-text{flex:1;text-align:left;font-weight:500}.error-message{display:flex;align-items:center;gap:12px;background-color:#fef2f2;color:#991b1b;padding:16px;border-radius:8px;border:1px solid #fecaca;margin-bottom:16px;font-size:.95rem}.error-icon{flex-shrink:0;color:#ef4444}.error-text{flex:1;font-weight:500}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:.9375rem}.report-textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9375rem;font-family:inherit;line-height:1.5;resize:vertical;transition:all .2s}.report-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.report-textarea:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.panel-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e7eb;background-color:#f9fafb;border-radius:0 0 12px 12px}.success-message,.error-message{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.report-dialog-panel{width:95%;margin:20px}.panel-header,.panel-content,.panel-footer{padding-left:16px;padding-right:16px}.panel-footer{flex-direction:column-reverse;padding:16px}.panel-footer button{width:100%}.success-message,.error-message{flex-direction:column;text-align:center;gap:8px}.success-text,.error-text{text-align:center}}.unified-messaging-interface{display:flex;flex-direction:column;height:100%;min-height:0;background:transparent;overflow:visible;width:100%;max-width:100%}.unified-messaging-interface-empty{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(180deg,#fff,#f5f7fb)}.messaging-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid rgba(143,155,179,.2);background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0f172a0d;flex-shrink:0}.context-info{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.context-info h3{margin:0;font-size:16px;font-weight:600;color:#333}.context-description{margin:0;font-size:.85rem;color:#6c757d}.context-stats{color:#6c757d;font-size:.9rem}.messaging-back-button{width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;border:none;border-radius:50%;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-right:8px;padding:0;outline:none}.messaging-back-button:hover{background:#6366f11a;color:#6366f1}.messaging-back-button:active{transform:scale(.95)}.messaging-back-button:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.chat-container{flex:1;min-height:0;background:linear-gradient(180deg,#fff,#f5f7fb);overflow:hidden;width:100%;display:flex;flex-direction:column}.reply-preview{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#4f46e50d;border-left:4px solid #4f46e5;margin:0;gap:12px}.reply-content{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.reply-label{font-size:.75rem;font-weight:600;color:#4f46e5;text-transform:uppercase;letter-spacing:.5px}.reply-text{font-size:.875rem;color:#64748b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.messaging-header{padding:14px 18px;position:relative}.context-info h3{text-align:center;flex:1;margin:0 40px}.context-info{margin:0 40px}.messaging-back-button{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important}.header-actions{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px;z-index:5}.header-actions .close-button{width:32px;height:32px;min-width:32px;background:transparent;color:#64748b}.header-actions .close-button.mobile-close{display:inline-flex;align-items:center;justify-content:center}.messaging-header{padding-right:88px}.context-info{margin:0 56px}.context-stats{position:absolute;right:52px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:6px;z-index:6}.context-stats .member-count{white-space:nowrap;font-size:13px}.empty-state{padding:16px;max-width:280px}.empty-state h3{font-size:16px;margin-bottom:10px}.empty-state p{font-size:13px}}.channel-interface{display:flex;flex-direction:column;height:100%;background:#fff}.no-channel-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:#6c757d}.no-channel-selected h3{margin-bottom:.5rem;color:#495057}.channel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #e9ecef;background:#f8f9fa}.channel-info h3{margin:0 0 .25rem;color:#495057;font-size:1.2rem;font-weight:600}.channel-description{margin:0;color:#6c757d;font-size:.9rem}.channel-stats{color:#6c757d;font-size:.9rem}.messages-container{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:1rem;scroll-behavior:smooth;background:linear-gradient(180deg,#fafbfc,#f8f9fa)}.no-messages{display:flex;align-items:center;justify-content:center;height:100%;color:#6c757d;font-style:italic}.message-wrapper{display:flex;flex-direction:column;max-width:70%;position:relative}.message-wrapper.own-message{align-self:flex-end;align-items:flex-end}.message-wrapper.other-message{align-self:flex-start;align-items:flex-start}.message-wrapper.grouped{margin-top:-.5rem}.message-wrapper.grouped .message-bubble{border-radius:8px}.message-wrapper.grouped.own-message .message-bubble{border-radius:8px 8px 4px}.message-wrapper.grouped.other-message .message-bubble{border-radius:8px 8px 8px 4px}.message-bubble{background:#fff;border:1px solid #dee2e6;border-radius:16px 16px 16px 4px;padding:12px 16px;box-shadow:0 2px 8px #0000001f;position:relative;min-width:120px;word-wrap:break-word;transition:all .2s ease}.own-message .message-bubble{background:linear-gradient(135deg,#0056b3,#003d82);color:#fff;border:none;border-radius:16px 16px 4px;box-shadow:0 2px 8px #0056b340}.own-message .message-text,.own-message .sender-name,.own-message .message-time,.own-message .reply-to-name,.own-message .reply-content{text-shadow:0 1px 2px rgba(0,0,0,.1)}.message-bubble:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.own-message .message-bubble:hover{box-shadow:0 4px 12px #007bff4d}.message-bubble:hover .message-actions{opacity:1}.reply-context{padding:8px 12px;background:#007bff14;border-left:3px solid #007bff;border-radius:8px 8px 4px 4px;margin-bottom:8px;font-size:.85rem;border:1px solid rgba(0,123,255,.15)}.own-message .reply-context{background:#ffffff26;border-left-color:#fffc;border-color:#ffffff4d}.reply-header{margin-bottom:4px}.reply-to-name{color:#0056b3;font-weight:700;font-size:.8rem}.own-message .reply-to-name{color:#fff}.reply-content{color:#495057;font-style:italic;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.own-message .reply-content{color:#fffffff2}.message-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.sender-name{font-weight:600;font-size:.85rem;color:#495057}.own-message .sender-name{color:#fffffff2}.message-time{font-size:.75rem;color:#6c757d}.own-message .message-time{color:#ffffffe6}.message-text{color:#212529;line-height:1.4;white-space:pre-wrap;word-wrap:break-word;margin-bottom:4px;font-weight:400}.own-message .message-text{color:#fff;font-weight:400}.edited-indicator{font-size:.7rem;color:#6c757d;font-style:italic;margin-top:2px;display:block}.own-message .edited-indicator{color:#ffffffd9}.edit-form{display:flex;flex-direction:column;gap:.5rem}.edit-input{padding:.5rem;border:1px solid #ced4da;border-radius:4px;resize:vertical;min-height:60px;font-family:inherit}.edit-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.edit-actions{display:flex;gap:.5rem}.save-btn,.cancel-btn{padding:.25rem .75rem;border:none;border-radius:4px;font-size:.8rem;cursor:pointer;transition:background-color .2s}.save-btn{background:#28a745;color:#fff}.save-btn:hover{background:#218838}.cancel-btn:hover{background:#5a6268}.message-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s;margin-top:4px;justify-content:flex-end}.action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;cursor:pointer;transition:all .2s;background:#6c757d26;color:#495057}.action-btn:hover{background:#6c757d40;transform:scale(1.1)}.reply-btn:hover{background:#007bff26;color:#0056b3}.edit-btn:hover{background:#ffc10726;color:#e0a800}.delete-btn:hover{background:#dc354526;color:#c82333}.own-message .action-btn{background:#ffffff40;color:#ffffffe6}.own-message .action-btn:hover{background:#fff6;color:#fff}.typing-indicator{padding:.5rem 1rem;color:#6c757d;font-style:italic;font-size:.9rem;border-top:1px solid #e9ecef}.message-input-container{border-top:1px solid #e9ecef;background:#fff}.reply-preview{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#007bff14;border-left:3px solid #0056b3;margin:0 16px;border-radius:8px 8px 0 0;border:1px solid rgba(0,123,255,.15);border-bottom:1px solid #e9ecef}.reply-preview-content{flex:1;min-width:0}.reply-preview-header{margin-bottom:4px}.reply-preview-label{font-size:.8rem;font-weight:700;color:#0056b3}.reply-preview-text{font-size:.85rem;color:#495057;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cancel-reply{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:none;border:none;border-radius:50%;cursor:pointer;color:#6c757d;transition:all .2s;flex-shrink:0}.cancel-reply:hover{background:#dc35451a;color:#dc3545}.message-form{display:flex;gap:.75rem;padding:1rem;align-items:flex-end}.message-input{flex:1;padding:.75rem;border:1px solid #ced4da;border-radius:20px;resize:none;max-height:120px;min-height:44px;font-family:inherit;font-size:.9rem;line-height:1.4}.message-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.send-btn{padding:.75rem 1.5rem;background:#007bff;color:#fff;border:none;border-radius:20px;cursor:pointer;font-weight:500;transition:background-color .2s}.send-btn:hover:not(:disabled){background:#0056b3}.send-btn:disabled{background:#6c757d;cursor:not-allowed}.error-message{padding:.75rem 1rem;background:#f8d7da;color:#721c24;border-bottom:1px solid #f5c6cb;font-size:.9rem}@media(max-width:768px){.channel-header{flex-direction:column;align-items:flex-start;gap:.5rem}.messages-container{padding:.75rem;gap:.5rem}.message-wrapper{max-width:85%}.message-bubble{padding:10px 14px;min-width:100px}.sender-name{font-size:.8rem;font-weight:600}.message-time{font-size:.75rem}.message-text{font-size:.9rem}.message-actions{opacity:1}.action-btn{width:32px;height:32px}.reply-preview{margin:0 12px;padding:10px 14px}.reply-preview-label{font-size:.75rem}.reply-preview-text{font-size:.8rem}.message-form{padding:.75rem}.message-input{font-size:16px}}.dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.dialog-content{background:#fff;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.dialog-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid #e9ecef}.dialog-header h3{margin:0;color:#495057;font-size:1.25rem;font-weight:600}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-btn:hover:not(:disabled){background:#f8f9fa}.close-btn:disabled{cursor:not-allowed;opacity:.5}.channel-form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#495057}.name-prefix{padding:.75rem .5rem .75rem .75rem;background:#f8f9fa;color:#6c757d;font-weight:500;border-right:1px solid #ced4da}.name-input{flex:1;padding:.75rem;border:none;outline:none;font-size:1rem}.description-input{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-family:inherit;font-size:1rem;resize:vertical;transition:border-color .2s,box-shadow .2s}.description-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.description-input:disabled{background:#f8f9fa;color:#6c757d}.form-help{display:block;margin-top:.25rem;font-size:.875rem;color:#6c757d}.checkbox-label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{margin:0;margin-top:.125rem}.checkbox-text{display:flex;flex-direction:column;gap:.25rem}.checkbox-text small{color:#6c757d;font-size:.875rem}.dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid #e9ecef}.cancel-btn,.create-btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover:not(:disabled){background:#5a6268}.create-btn{background:#007bff;color:#fff}.create-btn:hover:not(:disabled){background:#0056b3}.cancel-btn:disabled,.create-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.error-message{margin:1rem 1.5rem;padding:.75rem;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:4px;font-size:.9rem}@media(max-width:768px){.dialog-overlay{padding:.5rem}.dialog-header,.channel-form{padding:1rem}.dialog-actions{flex-direction:column-reverse}.cancel-btn,.create-btn{width:100%}}.channels-page{height:100vh;display:flex;flex-direction:column;background:#f8f9fa}.channels-layout{display:flex;height:100%;overflow:hidden}.channels-panel{width:300px;min-width:300px;height:100%;border-right:1px solid #e9ecef;background:#fff;transition:transform .3s ease}.channel-interface-panel{flex:1;height:100%;overflow:hidden}.channels-layout.overlay-mode .channels-panel{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;transform:translate(-100%)}.channels-layout.overlay-mode .channel-interface-panel{width:100%}@media(max-width:768px){.channels-panel{width:100%;min-width:unset}.channels-layout:not(.overlay-mode) .channel-interface-panel{display:none}.channels-layout.overlay-mode .channels-panel{transform:translate(0)}}@media(max-width:1024px)and (min-width:769px){.channels-panel{width:250px;min-width:250px}}.join-channel-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10001;padding:20px;box-sizing:border-box}.join-channel-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;width:100%;max-width:500px;max-height:80vh;overflow:hidden;animation:scaleIn .2s ease-out;display:flex;flex-direction:column}.join-channel-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.join-channel-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.close-button{width:32px;height:32px;border:none;border-radius:50%;background:transparent;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.join-channel-search{padding:16px 24px;border-bottom:1px solid #e5e7eb;flex-shrink:0}.join-channel-search .search-input{width:100%;padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s ease}.join-channel-search .search-input:focus{border-color:#2196f3;box-shadow:0 0 0 3px #2196f31a}.join-channel-content{flex:1;overflow-y:auto;min-height:0}.join-dialog-channels-list{padding:16px 0}.join-dialog-channel-item{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.join-dialog-channel-item:hover{background:#f8f9fa}.join-dialog-channel-item:last-child{border-bottom:none}.join-dialog-channel-info{flex:1;min-width:0}.join-dialog-channel-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.join-dialog-channel-name{font-weight:600;color:#333;font-size:14px}.private-indicator{font-size:12px;opacity:.7}.join-dialog-channel-description{font-size:13px;color:#6b7280;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.join-dialog-channel-meta{display:flex;gap:16px;font-size:12px;color:#9ca3af}.join-btn{padding:8px 16px;border:none;border-radius:6px;background:#2196f3;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s ease;margin-left:16px;flex-shrink:0}.join-btn:hover:not(:disabled){background:#1976d2}.join-btn:disabled{opacity:.6;cursor:not-allowed}.loading-state,.no-channels{padding:40px 24px;text-align:center;color:#6b7280;font-style:italic}.error-message{padding:12px 24px;background:#fef2f2;color:#dc2626;border-bottom:1px solid #fecaca;font-size:14px}@media(max-width:768px){.join-channel-overlay{padding:16px}.join-channel-dialog{max-width:100%;max-height:90vh}.join-channel-header{padding:16px 20px}.join-channel-header h3{font-size:16px}.join-channel-search{padding:12px 20px}.join-dialog-channel-item{padding:12px 20px;flex-direction:column;align-items:flex-start;gap:12px}.join-btn{margin-left:0;align-self:flex-end}.join-dialog-channel-meta{flex-direction:column;gap:4px}}.channel-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-weight:500;color:#495057;font-size:.9rem}.form-input{padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;transition:border-color .2s,box-shadow .2s;font-family:inherit}.form-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.form-input:disabled{background:#f8f9fa;color:#6c757d;cursor:not-allowed}.form-input.error{border-color:#dc3545}.form-input.error:focus{border-color:#dc3545;box-shadow:0 0 0 2px #dc354540}.name-input-container{display:flex;align-items:center;border:1px solid #ced4da;border-radius:4px;overflow:hidden;transition:border-color .2s,box-shadow .2s}.name-input-container:focus-within{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.name-input-container.error{border-color:#dc3545}.name-input-container.error:focus-within{border-color:#dc3545;box-shadow:0 0 0 2px #dc354540}.name-prefix{padding:.75rem .5rem .75rem .75rem;background:#f8f9fa;color:#6c757d;font-weight:500;border-right:1px solid #ced4da;font-size:1rem}.name-input{flex:1;border:none;outline:none;padding:.75rem;font-size:1rem}.name-input:disabled{background:#f8f9fa;color:#6c757d}.description-input{resize:vertical;min-height:80px;font-family:inherit;line-height:1.4}.form-help{font-size:.875rem;color:#6c757d;margin-top:.25rem}.name-preview{margin-top:.5rem;padding:.5rem;background:#e3f2fd;border-radius:4px;font-size:.9rem;color:#1976d2}.checkbox-label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-weight:400;padding:.5rem 0}.form-checkbox{margin:0;margin-top:.125rem;cursor:pointer}.checkbox-text{display:flex;flex-direction:column;gap:.25rem;flex:1}.checkbox-text small{color:#6c757d;font-size:.875rem;font-weight:400}.error-message{color:#dc3545;font-size:.875rem;margin-top:.25rem}.general-error{padding:.75rem;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;margin-bottom:1rem}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-top:1px solid #e9ecef}@media(max-width:768px){.channel-form{gap:1rem}.form-actions{flex-direction:column-reverse}.form-actions .e-btn{width:100%}.name-input-container{flex-direction:column}.name-prefix{width:100%;text-align:center;border-right:none;border-bottom:1px solid #ced4da}.name-input{width:100%}}.form-checkbox:focus{outline:2px solid #007bff;outline-offset:2px}.checkbox-label:focus-within{outline:2px solid #007bff;outline-offset:2px;border-radius:4px}.error-message{animation:slideDown .2s ease-out}.channel-management{padding:2rem;background:#f8f9fa;min-height:100vh}.channel-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1.5rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.channel-management-header h2{margin:0;color:#495057;font-size:1.5rem;font-weight:600}.channel-grid-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.action-buttons{display:flex;gap:.5rem;align-items:center}.avatar-placeholder-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:600}.channel-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.channel-dialog-panel{background:#fff;border-radius:8px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e9ecef;background:#f8f9fa;border-radius:8px 8px 0 0}.panel-header h2{margin:0;color:#495057;font-size:1.25rem;font-weight:600}.close-button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#6c757d;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.close-button:hover{background:#e9ecef}.panel-content{flex:1;padding:1.5rem;overflow-y:auto}.panel-footer{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid #e9ecef;background:#f8f9fa;border-radius:0 0 8px 8px}.confirmation-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.confirmation-panel{background:#fff;border-radius:8px;width:100%;max-width:500px;box-shadow:0 4px 20px #00000026;display:flex;flex-direction:column}.delete-dialog-content{padding:1rem 0}.delete-dialog-content p{margin:0 0 1rem;line-height:1.5}@media(max-width:768px){.channel-management{padding:1rem}.channel-management-header{flex-direction:column;gap:1rem;align-items:stretch;text-align:center}.channel-dialog-overlay{padding:.5rem}.channel-dialog-panel{max-height:95vh}.panel-header,.panel-content{padding:1rem}.panel-footer{flex-direction:column-reverse;padding:1rem}.panel-footer .e-btn{width:100%}.action-buttons{justify-content:center}}.e-grid .e-gridheader{background:#f8f9fa;border-bottom:2px solid #e9ecef}.e-grid .e-headercell{font-weight:600;color:#495057}.e-grid .e-row:hover{background:#f8f9fa}.e-grid .e-altrow{background:#fdfdfd}.e-grid .e-altrow:hover{background:#f8f9fa}.e-btn.e-small{border-radius:4px;transition:all .2s}.e-btn.e-info{background:#17a2b8;border-color:#17a2b8}.e-btn.e-info:hover{background:#138496;border-color:#117a8b}.e-btn.e-danger{background:#dc3545;border-color:#dc3545}.e-btn.e-danger:hover{background:#c82333;border-color:#bd2130}.e-btn.e-secondary{background:#6c757d;border-color:#6c757d}.e-btn.e-secondary:hover{background:#5a6268;border-color:#545b62}.post-composer{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.post-composer-content{margin-bottom:16px}.post-content-input{width:100%;min-height:80px}.code-editor-section{margin-top:12px;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.code-editor-header{background:#f5f5f5;padding:8px 12px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;gap:8px}.code-editor-section .cm-editor{font-size:14px}.code-editor-section .cm-scroller{font-family:Monaco,Menlo,Ubuntu Mono,Consolas,source-code-pro,monospace}.language-selector{min-width:150px}.language-and-toggle{display:flex;align-items:center;gap:8px}.language-selector{width:200px}.image-preview-section{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding:12px;background:#f8f9fa;border-radius:8px}.image-preview{position:relative;width:100px;height:100px;border-radius:8px;overflow:hidden}.image-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.remove-image-btn{position:absolute;top:4px;right:4px;display:flex;align-items:center;justify-content:center;background:#000000b3;color:#fff;width:24px;height:24px;border:none;border-radius:50%;cursor:pointer;transition:background .2s ease}.remove-image-btn:hover{background:#000000e6}.post-composer-actions{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #e0e0e0;min-height:52px}.action-buttons{display:flex;align-items:center;gap:8px}.action-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:none;background:transparent;color:#666;font-size:14px;border-radius:6px;cursor:pointer;transition:all .2s ease;height:36px;min-width:-moz-fit-content;min-width:fit-content}.action-btn.active{color:#007bff;background:#007bff1a}.action-btn svg{flex-shrink:0}.video-input-section{margin-top:8px}.submit-buttons{display:flex;align-items:center;gap:8px}@media(max-width:768px){.post-composer{margin:0 -16px 20px;border-radius:0}.post-composer-actions{flex-direction:column;gap:12px;align-items:stretch}.action-buttons{justify-content:center}.submit-buttons{justify-content:flex-end}.image-preview-section{gap:6px}.image-preview{width:80px;height:80px}}.comment-section{border-top:1px solid #f0f0f0;padding-top:16px;margin-top:16px}.comments-list{margin-bottom:16px}.comment-item{margin-bottom:12px}.comment-item.level-0{padding-left:0}.comment-item.level-1{padding-left:32px}.comment-item.level-2{padding-left:48px}.comment-item.level-3{padding-left:64px}.comment-content{background:#f8f9fa;border-radius:8px;padding:12px}.comment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.comment-author{display:flex;align-items:center;gap:8px}.comment-avatar{width:24px;height:24px;border-radius:50%;overflow:hidden;flex-shrink:0}.comment-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.comment-avatar .avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:10px}.comment-info{display:flex;align-items:center;gap:8px}.author-name{font-weight:600;font-size:13px;color:#333}.comment-time{font-size:11px;color:#666}.delete-comment-btn{background:none;border:none;color:#666;width:20px;height:20px;min-width:20px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.delete-comment-btn:hover{color:#e91e63;background:#e91e631a}.comment-text{font-size:13px;line-height:1.4;color:#333;margin-bottom:8px;white-space:pre-wrap;word-wrap:break-word}.comment-actions{display:flex;gap:8px}.reply-btn{background:none;border:none;font-size:12px;color:#666;padding:2px 8px;height:auto;min-height:auto;cursor:pointer;border-radius:4px}.reply-btn:hover{color:#007bff;background:#007bff1a}.report-btn{background:none;border:none;color:#6c757d;font-size:12px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s ease}.report-btn:hover{color:#dc3545;background:#dc35451a}.comment-replies{margin-top:8px}.load-more-btn{background:none;border:none;color:#666;font-size:13px;padding:8px 0;width:100%;text-align:center;cursor:pointer;border-radius:4px}.load-more-btn:hover{color:#007bff;background:#007bff0d}.reply-input-section,.add-comment-section{background:#f8f9fa;border-radius:12px;padding:16px;margin-bottom:16px;border:1px solid #e9ecef}.add-comment-section{margin-bottom:0;margin-top:16px}.reply-input,.comment-input{width:100%;border:1px solid #ddd;background:#fff;border-radius:8px;padding:12px 16px;font-size:14px;font-family:inherit;resize:vertical;min-height:44px;line-height:1.4;transition:border-color .2s ease,box-shadow .2s ease}.reply-input:focus,.comment-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.reply-input::-moz-placeholder,.comment-input::-moz-placeholder{color:#6c757d}.reply-input::placeholder,.comment-input::placeholder{color:#6c757d}.reply-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:12px}.add-comment-section .comment-submit-btn{margin-top:12px;align-self:flex-end}.cancel-btn,.reply-submit-btn,.comment-submit-btn{border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;min-width:70px;height:36px;transition:all .2s ease}.cancel-btn{background:#fff;color:#6c757d;border:1px solid #ddd}.cancel-btn:hover{background:#f8f9fa;border-color:#adb5bd}.reply-submit-btn,.comment-submit-btn{background:#007bff;color:#fff}.reply-submit-btn:hover:not(:disabled),.comment-submit-btn:hover:not(:disabled){background:#0056b3;transform:translateY(-1px);box-shadow:0 2px 4px #007bff33}.reply-submit-btn:disabled,.comment-submit-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}@media(max-width:768px){.comment-item.level-1{padding-left:20px}.comment-item.level-2{padding-left:32px}.comment-item.level-3{padding-left:44px}.comment-content{padding:10px}.comment-info{flex-direction:column;align-items:flex-start;gap:2px}.reply-input-section,.add-comment-section{padding:12px}.reply-input,.comment-input{padding:10px 12px;font-size:13px;min-height:40px}.cancel-btn,.reply-submit-btn,.comment-submit-btn{padding:6px 12px;font-size:13px;min-width:60px;height:32px}.reply-actions{gap:6px;margin-top:10px}.add-comment-section .comment-submit-btn{margin-top:10px}}.comment-error{background:#fee;border:1px solid #fcc;border-radius:8px;padding:12px 16px;margin-bottom:16px;color:#c33;font-size:14px}.comment-section{position:relative}.comment-section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,#e9ecef 20%,#e9ecef 80%,transparent 100%)}.comments-list:empty+.add-comment-section:before{content:attr(data-first);display:block;text-align:center;color:#6c757d;font-size:14px;margin-bottom:16px;font-style:italic}.comment-section.loading{opacity:.7;pointer-events:none}.comment-section.loading:after{content:"";position:absolute;top:50%;left:50%;width:20px;height:20px;margin:-10px 0 0 -10px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.reply-input:focus,.comment-input:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.cancel-btn:active,.reply-submit-btn:active,.comment-submit-btn:active{transform:translateY(0)}.comment-item{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reply-input-section{animation:slideDown .2s ease-out}.delete-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeInOverlay .2s ease-out}.delete-dialog{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-width:400px;width:90%;max-height:90vh;overflow:hidden;animation:slideInDialog .3s ease-out}.delete-dialog-header{padding:20px 24px 16px;border-bottom:1px solid #e9ecef}.delete-dialog-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.delete-dialog-content{padding:20px 24px}.delete-dialog-content p{margin:0;font-size:14px;line-height:1.5;color:#666}.delete-dialog-actions{padding:16px 24px 24px;display:flex;justify-content:flex-end;gap:12px}.cancel-delete-btn,.confirm-delete-btn{border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;min-width:80px;height:36px;transition:all .2s ease}.cancel-delete-btn{background:#fff;color:#6c757d;border:1px solid #ddd}.cancel-delete-btn:hover:not(:disabled){background:#f8f9fa;border-color:#adb5bd}.confirm-delete-btn{background:#dc3545;color:#fff}.confirm-delete-btn:hover:not(:disabled){background:#c82333;transform:translateY(-1px);box-shadow:0 2px 4px #dc354533}.cancel-delete-btn:disabled,.confirm-delete-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}@keyframes slideInDialog{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:768px){.delete-dialog{max-width:350px;margin:20px}.delete-dialog-header{padding:16px 20px 12px}.delete-dialog-header h3{font-size:16px}.delete-dialog-content{padding:16px 20px}.delete-dialog-content p{font-size:13px}.delete-dialog-actions{padding:12px 20px 20px;gap:8px}.cancel-delete-btn,.confirm-delete-btn{padding:6px 12px;font-size:13px;min-width:70px;height:32px}}.post-card{background:#fff;border-radius:8px;padding:16px;margin-bottom:16px;box-shadow:0 2px 4px #0000001a;border:1px solid #e0e0e0}.post-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.author-info{display:flex;gap:12px}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.author-details{flex:1;display:flex;flex-direction:row;align-items:center;gap:8px;flex-wrap:nowrap;min-width:0}.author-name{font-weight:600;font-size:14px;color:#333;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.author-username{font-size:12px;color:#666;margin:0;white-space:nowrap}.post-time{font-size:12px;color:#999;margin-left:auto}.post-menu{position:relative}.post-menu .action-btn{color:#666;width:32px;height:32px;min-width:32px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:none;background:transparent;cursor:pointer;transition:background .12s ease}.post-menu .action-btn:hover{background:#0000000a}.post-content{margin-bottom:16px}.post-text{font-size:14px;line-height:1.5;color:#333;margin-bottom:12px;white-space:pre-wrap;word-wrap:break-word}.code-snippet{background:#1e1e1e;border-radius:8px;overflow:visible;margin:12px 0}.code-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#2d2d2d;border-bottom:1px solid #404040;overflow:visible}.language-tag{font-size:12px;color:gold;font-weight:500;text-transform:uppercase}.copy-btn{color:#ccc;width:24px;height:24px;min-width:24px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.copy-btn:hover{color:#fff;background:#ffffff1a}.copy-wrapper{position:relative;display:inline-flex;align-items:center}.copy-label{position:absolute;right:0;top:-28px;transform:translateY(-6px);background:#000000bf;color:#fff;font-size:12px;padding:4px 8px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s ease,transform .15s ease;z-index:1050}.copy-label.show{opacity:1;transform:translateY(0)}.code-content{padding:16px;margin:0;overflow-x:auto;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:13px;line-height:1.4;color:#d4d4d4;background:#1e1e1e}.code-content code{background:none;padding:0;border-radius:0;font-family:inherit;font-size:inherit;color:inherit}.post-images{display:grid;gap:8px;margin:12px 0;border-radius:8px;overflow:hidden;justify-items:center;align-items:center}.post-images img{width:100%;height:auto;max-height:400px;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;display:block;margin:0 auto;border-radius:8px;transform:translate(-6px,-6px)}.post-video{margin:12px 0;width:100%;display:block}.video-placeholder{width:100%;aspect-ratio:16 / 9;min-height:240px;max-height:60vh;border-radius:8px;display:flex;align-items:center;justify-content:center;position:relative;background-color:#111827;color:#fff;overflow:hidden}.video-placeholder:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0000,#00000040)}.video-play-button{width:76px;height:76px;border-radius:50%;background:#ffffffe6;border:none;position:relative;z-index:2;cursor:pointer}.video-play-button:before{content:"";position:absolute;left:50%;top:50%;transform:translate(-35%,-50%);width:0;height:0;border-left:22px solid rgba(0,0,0,.9);border-top:14px solid transparent;border-bottom:14px solid transparent}.video-placeholder:focus{outline:3px solid rgba(59,130,246,.5)}.post-video iframe,.post-video video{width:100%;aspect-ratio:16 / 9;height:auto;max-height:60vh;min-height:240px;border-radius:8px;display:block}.post-video>iframe,.post-video>video{max-width:900px;margin:0 auto}.image-carousel{position:relative;width:100%;border-radius:8px;overflow:hidden;display:flex;flex-direction:column;align-items:center}.carousel-viewport{width:100%;display:flex;align-items:center;justify-content:center}.carousel-image{width:100%;height:auto;max-height:400px;-o-object-fit:cover;object-fit:cover;border-radius:8px;display:block}.carousel-controls{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;transform:translateY(-50%);pointer-events:none}.carousel-controls .action-btn{pointer-events:auto;background:#00000073;color:#fff;width:36px;height:36px;min-width:36px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;margin:0 8px;border:none}.carousel-indicators{display:flex;gap:6px;margin:8px 0 0}.carousel-indicator{width:8px;height:8px;border-radius:50%;background:#0003;border:none;padding:0;cursor:pointer}.carousel-indicator.active{background:#000000b3}.post-images:has(img:nth-child(2)){grid-template-columns:1fr 1fr}.post-images:has(img:nth-child(3)){grid-template-columns:1fr 1fr}.post-images:has(img:nth-child(3)) img:first-child{grid-column:1 / -1}.post-images:has(img:nth-child(4)){grid-template-columns:1fr 1fr}.post-actions{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid #f0f0f0}.action-buttons{display:flex;gap:16px}.action-btn{color:#666;font-size:14px;display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;transition:all .2s ease;background:none;border:none;cursor:pointer}.action-btn:hover{background:#0000000d}.action-btn.liked{color:#e91e63}.action-btn.liked:hover{background:#e91e631a}.action-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.post-card{margin:0 0 16px;border-radius:8px;border-left:none;border-right:none}.author-avatar{width:18px;height:18px}.avatar-placeholder{font-size:12px}.post-actions{gap:12px}.action-btn{padding:6px 8px;font-size:13px}.code-content{font-size:12px;padding:12px}.post-images{margin:8px 0;border-radius:8px}.post-images img{border-radius:8px;transform:none}.carousel-indicator{width:6px;height:6px;min-width:0!important;min-height:0!important;padding:0!important;line-height:0!important}.carousel-indicators{gap:6px;margin-top:6px}.carousel-controls .action-btn{width:28px;height:28px;min-width:28px!important;min-height:28px!important}}@media(max-width:768px){.post-header{align-items:center}.post-header .header-actions{position:static!important;right:auto!important;top:auto!important;transform:none!important;z-index:auto!important;display:flex;align-items:center;gap:8px;margin-left:8px}.post-header .header-actions .close-post-btn{width:32px;height:32px;min-width:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:transparent;padding:0;color:#64748b}}@media(max-width:768px){.post-actions{gap:8px}.action-buttons{gap:12px}.post-menu .action-btn{width:28px;height:28px;min-width:28px}}.comment-section-container{margin-top:16px;border-top:1px solid #f0f0f0;padding-top:16px}.com ment-section-container{margin-top:16px;border-top:1px solid #f0f0f0;padding-top:16px;min-height:0;overflow:hidden}.comment-section-disabled{padding:16px;text-align:center;color:#666;background:#f8f9fa;border-radius:8px}.comment-section-disabled p{margin:0;font-size:14px}.post-card.pinned-post{border:2px solid #ffd700;background:linear-gradient(135deg,#fffbf0,#fff8e1);box-shadow:0 4px 8px #ffd70033}.pinned-badge{display:inline-flex;align-items:center;gap:4px;background:gold;color:#333;font-size:10px;font-weight:600;padding:2px 6px;border-radius:12px;margin-left:8px;text-transform:uppercase}.pinned-badge svg{width:10px;height:10px}.new-posts-banner{position:sticky;top:0;z-index:1050;background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;padding:12px 16px;margin:-16px -16px 16px;box-shadow:0 2px 8px #007bff33;border-radius:0 0 8px 8px;animation:bannerSlideDown .3s ease-out,bannerPulse 3s ease-in-out}.banner-content{display:flex;align-items:center;justify-content:center;gap:12px;max-width:600px;margin:0 auto}.banner-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:#fff3;border-radius:50%;animation:bannerBounce 2s infinite}.banner-text{font-size:14px;font-weight:500;flex:1;text-align:center}.banner-text-short{display:none}.banner-text-full{display:inline}.load-new-posts-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 12px;border-radius:16px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;white-space:nowrap}.btn-text-short{display:none}.btn-text-full{display:inline}.load-new-posts-btn:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.load-new-posts-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.spinning{animation:bannerSpin 1s linear infinite}@keyframes bannerSlideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}@keyframes bannerBounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-4px)}60%{transform:translateY(-2px)}}@keyframes bannerSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes bannerPulse{0%,to{box-shadow:0 2px 8px #007bff33}50%{box-shadow:0 4px 16px #007bff66}}@media(max-width:768px){.new-posts-banner{padding:10px 12px;margin:-16px -12px 12px}.banner-content{gap:6px;justify-content:space-between;max-width:none}.banner-icon{width:18px;height:18px;flex-shrink:0}.banner-text{font-size:12px;flex:1;text-align:left;margin-left:4px}.banner-text-full{display:none}.banner-text-short{display:inline}.load-new-posts-btn{padding:6px 10px;font-size:11px;border-radius:12px;flex-shrink:0;min-width:auto}.btn-text-full{display:none}.btn-text-short{display:inline}}@media(max-width:480px){.new-posts-banner{padding:8px 10px}.banner-content{gap:4px}.banner-icon{width:16px;height:16px}.banner-text{font-size:11px}.load-new-posts-btn{padding:5px 8px;font-size:10px;gap:4px}}.feed-container{max-width:600px;margin:0 auto;padding:20px 16px}.feed-container .feed-controls{width:100%;max-width:600px;border-radius:8px}.feed-controls{display:flex;gap:12px;align-items:stretch;margin-bottom:20px;padding:16px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.feed-search-section{flex:1;display:flex;align-items:center}.search-input input{font-size:14px}.clear-search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:#666;width:24px;height:24px;min-width:24px}.refresh-btn,.search-btn{color:#666;width:40px;height:40px;min-width:40px;border-radius:50%}.refresh-btn:hover{background:#0000000d}.error-message{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;margin-bottom:20px;color:#856404}.posts-list{min-height:200px}.empty-feed{text-align:center;padding:60px 20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-feed h3{margin:0 0 8px;color:#333;font-size:18px;font-weight:600}.empty-feed p{margin:0;color:#666;font-size:14px;line-height:1.5}.loading-indicator{display:flex;flex-direction:column;align-items:center;padding:40px 20px;color:#666}.loading-spinner{width:32px;height:32px;border:3px solid #f3f3f3;border-top:3px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.loading-indicator span{font-size:14px}.end-of-feed{text-align:center;padding:20px;color:#999;font-size:14px}@media(max-width:768px){.feed-container{padding:16px}.feed-container .feed-controls{margin:0 0 20px;border-radius:8px}.feed-search-section{margin-right:8px}.refresh-btn{width:36px;height:36px;min-width:36px}.empty-feed{margin:0 16px;border-radius:0;border-left:none;border-right:none}.empty-icon{font-size:40px}.loading-indicator{padding:30px 20px}.loading-spinner{width:28px;height:28px}}@media(min-width:769px)and (max-width:1024px){.feed-container{max-width:700px;padding:20px}}@media(min-width:1025px){.feed-container{max-width:600px}}.trending-posts-widget{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;border:1px solid #e0e0e0;margin:20px 0}.trending-posts-widget h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#333}.loading-trending,.no-trending{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px 0;color:#666;font-size:14px}.no-trending p{margin:0;text-align:center}.trending-posts-list{display:flex;flex-direction:column;gap:12px}.trending-post-item{display:flex;gap:12px;padding:12px;border-radius:8px;cursor:pointer;transition:background-color .2s ease;border:1px solid #f0f0f0}.trending-post-item:hover{background:#f8f9fa}.trending-rank{font-weight:700;font-size:16px;color:#ff6b35;min-width:24px;text-align:center;flex-shrink:0}.trending-post-content{flex:1;min-width:0}.post-author{display:flex;align-items:center;gap:8px;margin-bottom:6px}.author-avatar{width:20px;height:20px;border-radius:50%;overflow:hidden;flex-shrink:0}.author-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:8px}.author-name{font-size:12px;font-weight:500;color:#666}.post-preview{font-size:13px;line-height:1.4;color:#333;margin-bottom:6px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.code-indicator{margin-bottom:6px}.code-tag{display:inline-block;background:#1e1e1e;color:gold;font-size:10px;font-weight:500;padding:2px 6px;border-radius:4px;text-transform:uppercase}.post-engagement{font-size:11px;color:#999;font-weight:500}@media(max-width:768px){.trending-posts-widget{margin:0 16px 20px;border-radius:0;border-left:none;border-right:none}.trending-post-item{padding:10px}.trending-rank{font-size:14px;min-width:20px}.author-avatar{width:18px;height:18px}.avatar-placeholder{font-size:7px}.post-preview{font-size:12px}.author-name{font-size:11px}}.pinned-posts-widget{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;border:1px solid #e0e0e0;margin:20px 0}.pinned-posts-widget h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#333;display:flex;align-items:center;gap:8px}.pinned-posts-widget h3 svg{color:gold}.loading-pinned{display:flex;align-items:center;gap:8px;padding:20px 0;color:#666;font-size:14px}.loading-spinner-small{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.pinned-posts-list{display:flex;flex-direction:column;gap:16px}.pinned-post-item{padding:16px;border:1px solid #ffd700;border-radius:8px;background:linear-gradient(135deg,#fffbf0,#fff8e1);cursor:pointer;transition:all .2s ease}.pinned-post-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ffd7004d}.pinned-post-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.post-author{display:flex;gap:8px;align-items:center;flex:1}.author-avatar{width:24px;height:24px;border-radius:50%;overflow:hidden;flex-shrink:0}.author-info{display:flex;flex-direction:column;gap:2px}.author-name{font-weight:600;font-size:13px;color:#333;line-height:1.2}.post-time{font-size:11px;color:#666;line-height:1.2}.pin-indicator{color:gold;display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#ffd70033;border-radius:50%}.post-preview{font-size:13px;line-height:1.4;color:#333;margin-bottom:8px;word-wrap:break-word}.code-indicator{margin-bottom:8px}.code-tag{display:inline-block;background:#333;color:gold;font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.post-engagement{font-size:11px;color:#666;font-weight:500}@media(max-width:768px){.pinned-posts-widget{margin:0 -16px 16px;border-radius:0;border-left:none;border-right:none;padding:16px}.pinned-post-item{padding:12px}.author-avatar{width:20px;height:20px}.author-name{font-size:12px}.post-time{font-size:10px}.post-preview{font-size:12px}.post-engagement{font-size:10px}}.feed-page{min-height:100vh;background:#f8f9fa}.feed-header{text-align:center;padding:40px 20px 20px;background:#fff;border-bottom:1px solid #e0e0e0}.feed-header h1{margin:0 0 8px;font-size:28px;font-weight:700;color:#333;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.feed-header p{font-size:16px;color:#666;max-width:500px;margin:0 auto}.feed-layout{display:flex;max-width:1200px;margin:0 auto;gap:20px;padding:0 20px}.single-post-view{padding:16px 0}.single-post-header{margin-bottom:12px;display:flex;align-items:center}.back-to-feed{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;background:#fff;border:1px solid #e6e6e6;color:#333;font-weight:600;cursor:pointer;box-shadow:0 1px 2px #1018280a;transition:transform .12s ease,box-shadow .12s ease,background .12s}.back-to-feed:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10182814;background:#fbfbfd}.back-to-feed .back-text{display:inline-block;font-size:14px}@media(max-width:480px){.back-to-feed{padding:6px 8px;gap:6px}.back-to-feed .back-text{display:none}}.feed-main{flex:1;max-width:600px}.feed-sidebar{width:300px;flex-shrink:0}@media(max-width:1199px){.feed-sidebar{display:none}}@media(max-width:1024px){.feed-layout{max-width:800px}}@media(max-width:768px){.feed-header{padding:20px 16px 16px}.feed-header h1{font-size:1.25rem}.feed-header p{font-size:14px}.feed-layout{flex-direction:column;padding:0;gap:0}.feed-main{max-width:none}.feed-sidebar{display:none}}@media(max-width:480px){.feed-header h1{font-size:1.125rem}}.participant-management-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10002;pointer-events:auto}.participant-management-panel{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;position:relative;overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.panel-header h2{margin:0;font-size:18px;font-weight:600;color:#1f2937}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.close-button:hover{background:#f3f4f6;color:#374151}.panel-content{padding:20px 24px;overflow-y:auto;flex:1;min-height:0}.current-participants,.add-participants{margin-bottom:30px}.current-participants h3,.add-participants h3{margin:0 0 16px;font-size:16px;font-weight:600;color:#1f2937}.add-participants h4{margin:16px 0 12px;font-size:14px;font-weight:500;color:#374151}.participants-list,.users-list{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow-y:auto;padding-right:4px}.participants-list::-webkit-scrollbar,.users-list::-webkit-scrollbar{width:6px}.participants-list::-webkit-scrollbar-track,.users-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.participants-list::-webkit-scrollbar-thumb,.users-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.participants-list::-webkit-scrollbar-thumb:hover,.users-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.participant-item,.user-item{display:flex;align-items:center;justify-content:space-between;padding:12px;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb;gap:12px}.participant-info,.user-info{display:flex;align-items:center;gap:12px;flex:1}.participant-avatar,.user-avatar{flex-shrink:0}.participant-avatar .avatar,.user-avatar .avatar{width:40px;height:40px}.participant-avatar .avatar .avatar-initials,.user-avatar .avatar .avatar-initials{font-size:14px}.participant-details,.user-details{flex:1}.participant-name,.user-name{font-weight:500;color:#1f2937;margin-bottom:2px}.participant-username,.user-username{font-size:13px;color:#6b7280}.search-section{margin-bottom:16px}.search-loading{display:flex;align-items:center;gap:8px;padding:16px;color:#6b7280;font-size:14px}.loading-spinner{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.no-results{padding:16px;text-align:center;color:#6b7280;font-size:14px}.search-error{padding:16px;text-align:center;color:#dc2626;font-size:14px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;margin-bottom:16px}.search-error p{margin:0}.search-hint{padding:16px;text-align:center;color:#6b7280;font-size:14px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:16px}.search-hint p{margin:0}.remove-participant-btn,.add-participant-btn{padding:8px 16px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:70px}.remove-participant-btn{background:#dc2626;color:#fff}.remove-participant-btn:hover:not(:disabled){background:#b91c1c}.remove-participant-btn:disabled{background:#9ca3af;cursor:not-allowed}.add-participant-btn{background:#2563eb;color:#fff}.add-participant-btn:hover:not(:disabled){background:#1d4ed8}.add-participant-btn:disabled{background:#9ca3af;cursor:not-allowed}.confirmation-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10003;animation:fadeIn .2s ease-out}.confirmation-dialog{background:#fff;border-radius:8px;width:90%;max-width:400px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;overflow:hidden;animation:slideIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.confirmation-header{padding:20px 24px 16px;border-bottom:1px solid #e5e7eb}.confirmation-header h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.confirmation-content{padding:16px 24px 20px}.confirmation-content p{margin:0 0 12px;color:#374151;line-height:1.5}.confirmation-content p:last-child{margin-bottom:0}.confirmation-warning{font-size:14px;color:#6b7280}.confirmation-actions{display:flex;gap:12px;padding:16px 24px 20px;justify-content:flex-end}.confirmation-cancel,.confirmation-confirm{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:80px}.confirmation-cancel{background:#f3f4f6;color:#374151}.confirmation-cancel:hover{background:#e5e7eb}.confirmation-confirm{background:#dc2626;color:#fff}.confirmation-confirm:hover:not(:disabled){background:#b91c1c}.confirmation-confirm:disabled{background:#9ca3af;cursor:not-allowed}@media(max-width:768px){.confirmation-dialog{width:95%;max-width:350px}.confirmation-header{padding:16px 20px 12px}.confirmation-header h3{font-size:16px}.confirmation-content{padding:12px 20px 16px}.confirmation-actions{padding:12px 20px 16px;gap:8px}.confirmation-cancel,.confirmation-confirm{padding:10px 16px;font-size:14px;min-width:70px}}.not-owner-message{padding:20px;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;text-align:center}.not-owner-message p{margin:0;color:#92400e;font-size:14px}.leave-group-section{margin-top:16px;padding:20px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.leave-group-section h3{margin:0 0 12px;font-size:16px;font-weight:600;color:#dc2626}.leave-group-description{margin:0 0 16px;color:#7f1d1d;font-size:14px;line-height:1.5}.leave-group-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;background:#dc2626;color:#fff;min-width:120px}.leave-group-btn:hover:not(:disabled){background:#b91c1c}.leave-group-btn:disabled{background:#9ca3af;cursor:not-allowed}.leave-confirm{background:#dc2626!important}.leave-confirm:hover:not(:disabled){background:#b91c1c!important}.available-users{border-top:1px solid #e5e7eb;padding-top:16px}.panel-content::-webkit-scrollbar{width:8px}.panel-content::-webkit-scrollbar-track{background:#f8fafc;border-radius:4px}.panel-content::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.panel-content::-webkit-scrollbar-thumb:hover{background:#94a3b8}@media(max-width:768px){.participant-management-overlay{padding:20px 16px 16px;align-items:flex-start}.participant-management-panel{width:100%;max-width:none;max-height:calc(100vh - 40px);margin:0}.participants-list,.users-list{max-height:250px}.panel-header{padding:16px 20px}.panel-header h2{font-size:16px}.panel-content{padding:16px 20px}.current-participants,.add-participants{margin-bottom:24px}.participant-item,.user-item{padding:12px;flex-direction:column;align-items:stretch;gap:12px}.participant-info,.user-info{width:100%}.participant-avatar .avatar,.user-avatar .avatar{width:36px;height:36px}.participant-avatar .avatar .avatar-initials,.user-avatar .avatar .avatar-initials{font-size:12px}.participant-name,.user-name{font-size:14px}.participant-username,.user-username{font-size:12px}.remove-participant-btn,.add-participant-btn{width:100%;padding:10px 16px;font-size:14px}}@media(max-width:480px){.participant-management-overlay{padding:16px 8px 8px}.participant-management-panel{max-height:calc(100vh - 32px)}.panel-header,.panel-content{padding:12px 16px}.participant-item,.user-item{padding:10px}.participants-list,.users-list{max-height:200px}}.conversation-list{display:flex;flex-direction:column;height:100%;background:#fff;border-right:1px solid #e0e0e0;overflow:hidden}.conversation-list-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0}.conversation-header-actions{display:flex;align-items:center;gap:8px}.conversation-list-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.new-conversation-btn{width:32px;height:32px;border:none;border-radius:50%;background:#007bff;color:#fff;font-size:16px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 4px #007bff33}.new-conversation-btn:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 4px 8px #007bff4d}.new-conversation-btn:active{transform:translateY(0);box-shadow:0 2px 4px #007bff33}.search-container{padding:16px;border-bottom:1px solid #e0e0e0}.conversations-container{flex:1;overflow-y:auto;min-height:0}.conversations-list{display:flex;flex-direction:column}.conversation-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;border:none;border-bottom:1px solid #f0f0f0;background:#fff;text-align:left;cursor:pointer;transition:background-color .2s ease;font:inherit;color:inherit}.conversation-item:hover,.conversation-item:focus-visible{background-color:#f8f9fa;outline:none}.conversation-item.active{background-color:#e3f2fd}.conversation-item.active:hover,.conversation-item.active:focus-visible{background-color:#dbeaf9}.conversations-list .conversation-item:last-of-type{border-bottom:none}.conversation-avatar{position:relative}.online-indicator{position:absolute;bottom:2px;right:2px;width:12px;height:12px;background-color:#4caf50;border:2px solid #fff;border-radius:50%}.conversation-content{flex:1;min-width:0}.conversation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.conversation-name{font-size:14px;font-weight:600;color:#333;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-time{font-size:12px;color:#666;white-space:nowrap}.conversation-preview{display:flex;justify-content:space-between;align-items:center}.last-message{font-size:13px;color:#666;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.no-messages{font-size:13px;color:#999;margin:0;font-style:italic}.unread-badge{background-color:#2196f3;color:#fff;font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center;margin-left:8px}.no-conversations{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;text-align:center;color:#666}.no-conversations p{margin-bottom:16px}.start-conversation-btn{padding:8px 16px;border:none;border-radius:6px;background:#007bff;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;margin-top:12px}.start-conversation-btn:hover{background:#0056b3}.conversation-item-wrapper{position:relative;display:flex;align-items:center}.conversation-item-wrapper.active{border-right:3px solid #2196f3}.conversation-item-wrapper .conversation-item{flex:1;border-radius:0;padding-right:48px;pointer-events:auto}.conversation-item-with-menu{display:flex;align-items:center;width:100%;position:relative}.conversation-item-with-menu .conversation-item{flex:1 1 auto;width:100%;border-radius:0;padding-right:56px}.conversation-item-with-menu .conversation-menu-container{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:center;justify-content:center;width:56px}.conversation-name-edit{display:flex;align-items:center;gap:8px;flex:1;position:relative;z-index:1001}.conversation-name-input{flex:1;padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:13px;font-weight:600;background:#fff;outline:none;min-width:0;position:relative;z-index:1001}.conversation-name-input:focus{border-color:#6366f1;box-shadow:0 0 0 1px #6366f11a}.conversation-name-actions{display:flex;gap:4px;flex-shrink:0;position:relative;z-index:1001}.save-conversation-name,.cancel-conversation-name{width:20px;height:20px;border:none;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;transition:all .2s ease}.save-conversation-name{background:#10b981;color:#fff}.save-conversation-name:hover{background:#059669}.cancel-conversation-name{background:#ef4444;color:#fff}.cancel-conversation-name:hover{background:#dc2626}.conversation-menu-container{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:center;justify-content:center;width:48px;background:transparent;transition:background-color .2s ease;pointer-events:auto}.conversation-item-wrapper.active .conversation-menu-container{background-color:#e3f2fd}.conversation-item-wrapper:hover .conversation-menu-container{background-color:#f8f9fa}.conversation-item-wrapper.active:hover .conversation-menu-container{background-color:#dbeaf9}.conversation-menu-button{width:28px;height:28px;border:none;border-radius:50%;background:transparent;color:#9ca3af;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:1;pointer-events:auto;position:relative;z-index:1000;outline:none}.conversation-item-wrapper:hover .conversation-menu-button{opacity:1}.conversation-menu-button:hover{background:#6366f11a;color:#6366f1}.conversation-menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #00000026;z-index:1050;min-width:140px;overflow:visible;animation:slideDown .2s ease-out;pointer-events:auto}.conversation-menu-item{width:100%;padding:10px 12px;border:none;background:#fff;color:#374151;text-align:left;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;white-space:nowrap;transition:background-color .2s ease;pointer-events:auto;position:relative;z-index:1051;outline:none}.conversation-menu-item:hover{background:#f9fafb}.conversation-menu-item-danger{color:#dc2626}.conversation-menu-item-danger:hover{background:#fef2f2}.primary-action{background:#007bff;color:#fff;border-color:transparent;padding:8px 12px;border-radius:6px}.primary-action:hover{background:#0056b3}@media(max-width:768px){.conversation-list-header,.search-container{padding:12px}.conversation-item{padding:10px 12px}.conversation-avatar .avatar-large{width:40px;height:40px}.conversation-avatar .avatar-large .avatar-initials{font-size:16px}.conversation-name{font-size:13px}.last-message{font-size:12px}.conversation-menu-container{width:40px}.conversation-item-wrapper .conversation-item{padding-right:40px}.conversation-menu-button{width:24px;height:24px;opacity:1;pointer-events:auto}.conversation-menu-dropdown{min-width:140px;right:-4px}.conversation-menu-item{padding:8px 12px;font-size:12px;white-space:nowrap}.conversation-name-input{font-size:12px;padding:3px 6px}.save-conversation-name,.cancel-conversation-name{width:18px;height:18px;font-size:9px}.delete-confirm-overlay{padding:16px}.delete-confirm-dialog{max-width:320px}.delete-confirm-header{padding:16px 20px 12px}.delete-confirm-header h3{font-size:16px}.delete-confirm-content{padding:12px 20px 16px}.delete-confirm-content p{font-size:14px}.delete-confirm-actions{padding:12px 20px 16px;gap:8px}.delete-confirm-cancel,.delete-confirm-delete{padding:6px 12px;font-size:13px;flex:1}}.message-interface{display:flex;flex-direction:column;height:100%;min-height:0;background:transparent;overflow:visible;width:100%;max-width:100%}.message-interface-empty{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(180deg,#fff,#f5f7fb)}.empty-state{text-align:center;color:#666;padding:20px;max-width:300px;word-wrap:break-word}.empty-state h3{margin-bottom:12px;color:#333;font-size:18px;line-height:1.4}.empty-state p{margin:0;line-height:1.5;font-size:14px}.message-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid rgba(143,155,179,.2);background:#ffffffe6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);box-shadow:0 4px 16px #0f172a0d;flex-shrink:0}.message-header h3{flex:1;text-align:center;margin:0;font-size:16px;font-weight:600;color:#333}.conversation-title-container{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;position:relative}.edit-name-button{background:none;border:none;color:#64748b;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.edit-name-button:hover{background:#6366f11a;color:#6366f1}.name-editing-container{flex:1;display:flex;align-items:center;gap:8px;max-width:300px}.name-edit-input{flex:1;padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:600;background:#fff;outline:none;transition:border-color .2s ease}.name-edit-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.name-edit-actions{display:flex;gap:4px}.save-name-btn,.cancel-name-btn{width:28px;height:28px;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;transition:all .2s ease}.save-name-btn{background:#10b981;color:#fff}.save-name-btn:hover{background:#059669}.cancel-name-btn{background:#ef4444;color:#fff}.cancel-name-btn:hover{background:#dc2626}.group-menu-container{position:relative}.group-menu-button{width:32px;height:32px;border:none;border-radius:50%;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-right:8px}.group-menu-button:hover{background:#6366f11a;color:#6366f1}.group-menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #00000026;z-index:1000;min-width:160px;overflow:hidden;animation:slideDown .2s ease-out}.group-menu-item{width:100%;padding:12px 16px;border:none;background:#fff;color:#374151;text-align:left;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;transition:background-color .2s ease}.group-menu-item:hover{background:#f9fafb}.group-menu-item-danger{color:#dc2626}.group-menu-item-danger:hover{background:#fef2f2}.delete-confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.delete-confirm-dialog{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;width:100%;max-width:400px;overflow:hidden;animation:scaleIn .2s ease-out}.delete-confirm-header{padding:20px 24px 16px;border-bottom:1px solid #e5e7eb}.delete-confirm-header h3{margin:0;font-size:18px;font-weight:600;color:#dc2626}.delete-confirm-content{padding:16px 24px 20px}.delete-confirm-content p{margin:0;color:#6b7280;line-height:1.5}.delete-confirm-actions{display:flex;gap:12px;padding:16px 24px 20px;justify-content:flex-end}.delete-confirm-cancel,.delete-confirm-delete{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid transparent}.delete-confirm-cancel{background:#f9fafb;color:#374151;border-color:#d1d5db}.delete-confirm-cancel:hover{background:#f3f4f6}.delete-confirm-delete{background:#dc2626;color:#fff}.delete-confirm-delete:hover{background:#b91c1c}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.header-actions{display:flex;align-items:center;gap:8px}.close-button{width:32px;height:32px;min-width:32px;border-radius:50%;color:#64748b;transition:all .2s ease}.close-button:hover{background:#ef44441a;color:#ef4444}.close-button:active{transform:scale(.95)}.message-back-button{width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;border:none;border-radius:50%;background:transparent;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;margin-right:8px;padding:0;outline:none}.message-back-button:hover{background:#6366f11a;color:#6366f1}.message-back-button:active{transform:scale(.95)}.message-back-button:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.chat-container{flex:1;min-height:0;background:linear-gradient(180deg,#fff,#f5f7fb);overflow-x:hidden;overflow-y:visible;width:100%}.chat-container .e-chat-ui{border:none;box-shadow:none;background:transparent;overflow-x:hidden;width:100%}.chat-container .e-chat-ui .e-message-wrapper{background:linear-gradient(180deg,#fff,#f5f7fb);overflow-x:hidden;max-width:100%}.chat-container .e-chat-ui .e-message-right .e-message-content{background:linear-gradient(140deg,#4f46e5,#3730a3);color:#fff;border:none;box-shadow:0 12px 24px #4f46e54d;border-radius:16px 16px 4px}.chat-container .e-chat-ui .e-message-left .e-message-content{background:#fff;color:#212529;border:1px solid rgba(148,163,184,.3);box-shadow:0 8px 20px #0f172a1f;border-radius:16px 16px 16px 4px}.chat-container .e-chat-ui .e-message-header .e-user-name{font-size:.85rem!important;font-weight:600!important;color:#495057!important;margin-bottom:4px!important}.chat-container .e-chat-ui .e-message-right .e-message-header .e-user-name{color:#fffffff2!important;text-align:right!important}.chat-container .e-chat-ui .e-message-left .e-message-header .e-user-name{text-align:left!important}.chat-container .e-chat-ui .e-footer{padding:8px 16px!important;background:transparent!important;border-top:none!important;min-height:auto!important;height:auto!important}.message-interface .chat-container .e-chat-ui .e-input-group{display:flex!important;align-items:center!important;gap:8px!important;padding:6px 8px 6px 16px!important;min-height:40px!important;max-height:40px!important;height:40px!important;box-sizing:border-box!important;margin:0!important;border-radius:24px!important;background:#ffffffe6!important;box-shadow:inset 0 0 0 1px #94a3b826!important}.chat-container .e-chat-ui .e-input-group input,.chat-container .e-chat-ui .e-input-group .e-input{flex:1!important;border:none!important;outline:none!important;background:transparent!important;font-size:14px!important;padding:0!important;margin:0!important;min-height:20px!important;max-height:20px!important;height:20px!important;line-height:20px!important}.chat-container .e-chat-ui .e-send-button{background:linear-gradient(140deg,#6366f1,#4f46e5)!important;border:none!important;border-radius:50%!important;box-shadow:0 10px 18px #4f46e540!important;flex-shrink:0!important;margin:0!important;position:relative!important;width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important}.chat-container .e-chat-ui .e-send-button:hover{background:linear-gradient(140deg,#4f46e5,#4338ca)!important}.chat-container .e-chat-ui .e-footer .e-input-group,.chat-container .e-chat-ui .e-footer .e-input-group .e-input-group-icon,.chat-container .e-chat-ui .e-footer .e-input-group .e-input{height:40px!important;max-height:40px!important;min-height:40px!important}.chat-container .e-chat-ui .e-footer .e-input-group .e-input-group-icon{display:flex!important;align-items:center!important;justify-content:center!important;padding:0!important;margin:0!important}.chat-container .e-chat-ui .e-footer .e-input-group .e-input-group-icon .e-send-button{position:static!important;transform:none!important;inset:auto!important}.chat-container .e-chat-ui .e-footer,.chat-container .e-chat-ui .e-footer *{vertical-align:middle!important}@media(max-width:768px){.message-header{padding:14px 18px;position:relative}.message-header h3{text-align:center;flex:1;margin:0 40px}.conversation-title-container{margin:0 40px}.name-editing-container{margin:0 40px;max-width:calc(100% - 80px)}.edit-name-button{padding:2px}.name-edit-input{font-size:13px;padding:4px 8px}.save-name-btn,.cancel-name-btn{width:24px;height:24px;font-size:10px}.group-menu-button{width:28px;height:28px;margin-right:4px}.group-menu-dropdown{min-width:140px;right:-8px}.group-menu-item{padding:10px 12px;font-size:13px}.delete-confirm-overlay{padding:16px}.delete-confirm-dialog{max-width:320px}.delete-confirm-header{padding:16px 20px 12px}.delete-confirm-header h3{font-size:16px}.delete-confirm-content{padding:12px 20px 16px}.delete-confirm-content p{font-size:14px}.delete-confirm-actions{padding:12px 20px 16px;gap:8px}.delete-confirm-cancel,.delete-confirm-delete{padding:6px 12px;font-size:13px;flex:1}.message-back-button{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important}.message-interface-empty{display:none!important}.empty-state{padding:16px;max-width:280px}.empty-state h3{font-size:16px;margin-bottom:10px}.empty-state p{font-size:13px}.chat-container .e-chat-ui .e-message-content{font-size:13px;padding:10px 14px}.chat-container .e-chat-ui .e-send-button{width:36px!important;height:36px!important;min-width:36px!important;min-height:36px!important;max-width:36px!important;max-height:36px!important;margin:0!important;flex-shrink:0!important}.message-interface .chat-container .e-chat-ui .e-input-group{margin:0!important;display:flex!important;align-items:center!important;min-height:44px!important;max-height:44px!important;height:44px!important;padding:4px 6px 4px 14px!important}.chat-container .e-chat-ui .e-input-group input,.chat-container .e-chat-ui .e-input-group .e-input{flex:1!important;border:none!important;outline:none!important;background:transparent!important;padding:0!important;margin:0!important;font-size:14px!important;height:20px!important;max-height:20px!important;min-height:20px!important;line-height:20px!important}.chat-container .e-chat-ui .e-footer{padding:6px 12px!important;background:transparent!important;min-height:auto!important;height:auto!important}.chat-container .e-chat-ui .e-footer .e-input-group,.chat-container .e-chat-ui .e-footer .e-input-group .e-input-group-icon,.chat-container .e-chat-ui .e-footer .e-input-group .e-input{height:44px!important;max-height:44px!important;min-height:44px!important}}@media(max-width:480px){.empty-state{padding:12px;max-width:250px}.empty-state h3{font-size:15px}.empty-state p{font-size:12px}.message-interface .chat-container .e-chat-ui .e-input-group{margin:0!important;min-height:40px!important;max-height:40px!important;height:40px!important;padding:4px 6px 4px 12px!important}.chat-container .e-chat-ui .e-send-button{width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;max-width:32px!important;max-height:32px!important}.chat-container .e-chat-ui .e-input-group input,.chat-container .e-chat-ui .e-input-group .e-input{font-size:13px!important;padding:0!important;margin:0!important;height:18px!important;max-height:18px!important;min-height:18px!important;line-height:18px!important}.chat-container .e-chat-ui .e-footer{padding:4px 8px!important}.chat-container .e-chat-ui .e-footer .e-input-group,.chat-container .e-chat-ui .e-footer .e-input-group .e-input-group-icon,.chat-container .e-chat-ui .e-footer .e-input-group .e-input{height:40px!important;max-height:40px!important;min-height:40px!important}}.reply-preview{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#6366f10d;border-left:3px solid #6366f1;margin:8px 16px 0;border-radius:8px;animation:slideDown .2s ease-out}.reply-content{display:flex;flex-direction:column;flex:1;min-width:0}.reply-label{font-size:12px;font-weight:700;color:#3730a3;margin-bottom:2px}.reply-text{font-size:13px;color:#495057;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.custom-message{margin-bottom:8px;max-width:85%;word-wrap:break-word;box-sizing:border-box;overflow:hidden}.custom-message.has-reply{margin-bottom:12px}.custom-message:empty{display:none;margin:0}.custom-message.own-message{margin-left:auto;margin-right:0;padding-right:16px;max-width:85%}.custom-message.other-message{margin-left:0;margin-right:auto;padding-left:16px;max-width:85%}@media(min-width:768px){.custom-message{max-width:75%}.message-bubble{min-width:150px}}@media(min-width:1024px){.custom-message{max-width:65%}.message-bubble{min-width:180px}}@media(min-width:1440px){.custom-message{max-width:55%}.message-bubble{min-width:200px}}.message-content{-webkit-hyphens:auto;hyphens:auto;word-break:break-word}.reply-context{display:flex;align-items:flex-start;margin-bottom:8px;padding:8px 12px;background:#6366f114;border-radius:8px 8px 4px 4px;border-left:3px solid #6366f1}.reply-context:empty{display:none;margin:0;padding:0}.reply-indicator{width:2px;background:#6366f1;margin-right:8px;flex-shrink:0;height:100%;min-height:20px}.reply-info{flex:1;min-width:0}.reply-author{font-size:11px;font-weight:600;color:#6366f1;margin-bottom:2px}.reply-message{font-size:12px;color:#64748b;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.message-bubble{background:#fff;border:1px solid rgba(148,163,184,.25);border-radius:16px;padding:12px 16px;box-shadow:0 2px 8px #0f172a14;position:relative;min-width:120px;max-width:100%;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden;word-wrap:break-word}.own-message .message-bubble{background:linear-gradient(140deg,#6366f1,#4f46e5);color:#f8fafc;border:none;box-shadow:0 4px 12px #4f46e533}.own-message .reply-context{background:#ffffff26;border-left-color:#fff9}.own-message .reply-author{color:#ffffffe6}.own-message .reply-message{color:#fffc}.message-content{font-size:14px;line-height:1.4;margin-bottom:6px;min-width:0;word-wrap:break-word;overflow-wrap:break-word}.message-time{font-size:11px;opacity:.7;text-align:right;margin-top:2px;white-space:nowrap;flex-shrink:0}@media(max-width:767px){.custom-message{max-width:90%!important}.custom-message.own-message{padding-right:12px}.custom-message.other-message{padding-left:12px}.message-bubble{padding:10px 14px;min-width:100px}.message-content{font-size:13px;margin-bottom:4px}.message-time{font-size:10px;margin-top:2px}.reply-context{padding:6px 10px}}.message-wrapper{display:flex;align-items:flex-end;margin-bottom:8px;max-width:85%;position:relative}.message-wrapper.own-message{flex-direction:row-reverse;margin-left:auto;margin-right:16px}.message-wrapper.other-message{flex-direction:row;margin-left:16px;margin-right:auto}.message-content-area{background:#fff;border:1px solid rgba(148,163,184,.25);border-radius:16px;padding:12px 16px;box-shadow:0 2px 8px #0f172a14;max-width:100%;word-wrap:break-word;overflow-wrap:break-word}.own-message .message-content-area{background:linear-gradient(140deg,#6366f1,#4f46e5);color:#f8fafc;border:none;box-shadow:0 4px 12px #4f46e533}.message-text{font-size:14px;line-height:1.4;margin-bottom:4px}.message-time{font-size:11px;opacity:.7;text-align:right;white-space:nowrap}.own-message .message-time{color:#f8fafccc}@media(max-width:768px){.message-wrapper{max-width:90%}.message-wrapper.own-message{margin-right:12px}.message-wrapper.other-message{margin-left:12px}.message-content-area{padding:10px 14px}.message-text{font-size:13px}}.message-interface *{max-width:100%;box-sizing:border-box}.chat-container .e-chat-ui .system-message{text-align:center!important;margin:16px auto!important;max-width:80%!important}.chat-container .e-chat-ui .system-message .e-message-content{background:#6366f11f!important;color:#3730a3!important;border:1px solid rgba(99,102,241,.25)!important;border-radius:16px!important;padding:8px 16px!important;font-size:13px!important;font-style:italic!important;font-weight:500!important;box-shadow:none!important;display:inline-block!important;text-align:center!important}.chat-container .e-chat-ui .system-message .e-message-header{display:none!important}.chat-container .e-chat-ui .system-message .e-message-time{color:#3730a3!important;opacity:.8!important;font-size:11px!important;text-align:center!important;margin-top:4px!important}@media(max-width:768px){.chat-container .e-chat-ui .system-message{max-width:90%!important;margin:12px auto!important}.chat-container .e-chat-ui .system-message .e-message-content{font-size:12px!important;padding:6px 12px!important}}.chat-container .e-chat-ui .e-message-toolbar .e-toolbar-item:hover{background:#6366f11a}.chat-container .e-chat-ui .e-message-toolbar .message-toolbar-reply:hover{background:#007bff1a;color:#007bff!important}.chat-container .e-chat-ui .e-message-toolbar .message-toolbar-copy:hover{background:#6c757d1a;color:#6c757d!important}.chat-container .e-chat-ui .e-message-toolbar .message-toolbar-report:hover{background:#ef44441a;color:#ef4444!important}.chat-container .e-chat-ui .e-scroll-to-bottom,.chat-container .e-chat-ui .e-scroll-indicator,.chat-container .e-chat-ui .e-fab,.chat-container .e-chat-ui .e-floating-action-button,.chat-container .e-chat-ui [class*=scroll-bottom],.chat-container .e-chat-ui [class*=chevron-down],.chat-container .e-chat-ui [class*=arrow-down],.chat-container .e-chat-ui .e-icons.e-chevron-down,.chat-container .e-chat-ui .e-icons.e-arrow-down{display:none!important;visibility:hidden!important;opacity:0!important}.chat-container .e-chat-ui .e-chat-footer{padding:8px 16px!important;background:transparent!important;border-top:none!important;min-height:56px!important;max-height:56px!important;height:56px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-input-container{display:flex!important;align-items:center!important;gap:8px!important;height:40px!important;min-height:40px!important;max-height:40px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-input{flex:1!important;height:40px!important;min-height:40px!important;max-height:40px!important;border-radius:24px!important;background:#ffffffe6!important;box-shadow:inset 0 0 0 1px #94a3b826!important;border:none!important;padding:8px 16px!important;font-size:14px!important;line-height:24px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-send-button{width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;max-width:32px!important;max-height:32px!important;background:linear-gradient(140deg,#6366f1,#4f46e5)!important;border:none!important;border-radius:50%!important;box-shadow:0 10px 18px #4f46e540!important;flex-shrink:0!important;margin:0!important;padding:0!important}@media(max-width:768px){.chat-container .e-chat-ui .e-chat-footer{padding:6px 12px!important;min-height:52px!important;max-height:52px!important;height:52px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-input-container{height:40px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-input{height:40px!important;padding:6px 14px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-send-button{width:36px!important;height:36px!important;min-width:36px!important;min-height:36px!important;max-width:36px!important;max-height:36px!important}}@media(max-width:480px){.chat-container .e-chat-ui .e-chat-footer{padding:4px 8px!important;min-height:48px!important;max-height:48px!important;height:48px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-input-container{height:36px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-input{height:36px!important;padding:6px 12px!important;font-size:13px!important}.chat-container .e-chat-ui .e-chat-footer .e-chat-send-button{width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;max-width:32px!important;max-height:32px!important}}.chat-container .e-chat-ui .e-chat-footer,.chat-container .e-chat-ui .e-footer,.chat-container .e-chat-ui [class*=footer]{padding:16px 16px 20px!important;background:#f8fafccc!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;border-top:1px solid rgba(148,163,184,.1)!important;min-height:76px!important;max-height:none!important;height:auto!important;display:flex!important;align-items:center!important;justify-content:flex-start!important;width:100%!important;box-sizing:border-box!important;overflow:visible!important}.chat-container .e-chat-ui .e-chat-footer>*,.chat-container .e-chat-ui .e-footer>*,.chat-container .e-chat-ui [class*=footer]>*{width:100%!important;justify-content:flex-start!important;display:flex!important;align-items:center!important;height:40px!important;max-height:40px!important;flex:1!important}.chat-container .e-chat-ui [class*=input-container],.chat-container .e-chat-ui [class*=input-group],.chat-container .e-chat-ui .e-input-group{display:flex!important;align-items:center!important;justify-content:flex-start!important;height:44px!important;min-height:44px!important;max-height:44px!important;gap:0!important;border-radius:22px!important;background:#fff!important;border:1px solid rgba(148,163,184,.2)!important;box-shadow:0 2px 8px #0f172a14!important;padding:0!important;margin:4px 0!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important;transition:all .2s ease!important;position:relative!important}.chat-container .e-chat-ui input:focus-visible,.chat-container .e-chat-ui textarea:focus-visible,.chat-container .e-chat-ui .e-input:focus-visible,.chat-container .e-chat-ui [role=textbox]:focus-visible,.chat-container .e-chat-ui input:focus,.chat-container .e-chat-ui textarea:focus,.chat-container .e-chat-ui .e-input:focus,.chat-container .e-chat-ui [role=textbox]:focus{outline:none!important;outline-width:0!important;outline-offset:0!important}.chat-container .e-chat-ui input,.chat-container .e-chat-ui textarea,.chat-container .e-chat-ui [class*=input]:not([class*=container]):not([class*=group]){position:absolute!important;left:18px!important;right:48px!important;top:50%!important;transform:translateY(-50%)!important;border:none!important;outline:none!important;background:transparent!important;font-size:14px!important;padding:0!important;margin:0!important;height:20px!important;line-height:20px!important;resize:none!important;color:#1f2937!important;text-align:left!important;width:auto!important;min-width:0!important;z-index:3!important;pointer-events:auto!important;cursor:text!important}.chat-container .e-chat-ui input::-moz-placeholder,.chat-container .e-chat-ui textarea::-moz-placeholder{color:#9ca3af!important;font-size:14px!important}.chat-container .e-chat-ui input::placeholder,.chat-container .e-chat-ui textarea::placeholder{color:#9ca3af!important;font-size:14px!important}.chat-container .e-chat-ui input,.chat-container .e-chat-ui textarea{order:unset!important;flex:none!important;max-width:none!important;width:auto!important}.chat-container .e-chat-ui [class*=input-container] input,.chat-container .e-chat-ui [class*=input-group] input,.chat-container .e-chat-ui .e-input-group input,.chat-container .e-chat-ui [class*=input-container] textarea,.chat-container .e-chat-ui [class*=input-group] textarea,.chat-container .e-chat-ui .e-input-group textarea{width:auto!important;max-width:none!important;min-width:0!important;flex:none!important}.chat-container .e-chat-ui button,.chat-container .e-chat-ui [class*=send],.chat-container .e-chat-ui [class*=submit]{position:absolute!important;right:6px!important;top:50%!important;transform:translateY(-50%)!important;width:36px!important;height:36px!important;min-width:36px!important;min-height:36px!important;max-width:36px!important;max-height:36px!important;background:transparent!important;border:none!important;border-radius:50%!important;box-shadow:none!important;flex-shrink:0!important;margin:0!important;padding:0!important;cursor:pointer!important;transition:none!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:2!important;color:#6366f1!important}.chat-container .e-chat-ui button:hover,.chat-container .e-chat-ui [class*=send]:hover,.chat-container .e-chat-ui [class*=submit]:hover{background:transparent!important;transform:translateY(-50%)!important;box-shadow:none!important;color:#6366f1!important}.chat-container .e-chat-ui button:active,.chat-container .e-chat-ui [class*=send]:active,.chat-container .e-chat-ui [class*=submit]:active{background:transparent!important;transform:translateY(-50%)!important;box-shadow:none!important;color:#4f46e5!important}@media(max-width:768px){.chat-container .e-chat-ui .e-chat-footer,.chat-container .e-chat-ui .e-footer,.chat-container .e-chat-ui [class*=footer]{padding:12px 12px 16px!important;min-height:64px!important;max-height:none!important;height:auto!important}.chat-container .e-chat-ui [class*=input-container],.chat-container .e-chat-ui [class*=input-group],.chat-container .e-chat-ui .e-input-group{height:40px!important;min-height:40px!important;max-height:40px!important;border-radius:20px!important;padding:0!important;margin:0!important;gap:0!important;width:100%!important}.chat-container .e-chat-ui input,.chat-container .e-chat-ui textarea{left:16px!important;right:40px!important;font-size:14px!important;height:18px!important;line-height:18px!important}.chat-container .e-chat-ui button,.chat-container .e-chat-ui [class*=send],.chat-container .e-chat-ui [class*=submit]{right:4px!important;width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;max-width:32px!important;max-height:32px!important;background:transparent!important;box-shadow:none!important}}@media(max-width:480px){.chat-container .e-chat-ui .e-chat-footer,.chat-container .e-chat-ui .e-footer,.chat-container .e-chat-ui [class*=footer]{padding:10px 8px 14px!important;min-height:60px!important;max-height:none!important;height:auto!important}.chat-container .e-chat-ui [class*=input-container],.chat-container .e-chat-ui [class*=input-group],.chat-container .e-chat-ui .e-input-group{height:38px!important;min-height:38px!important;max-height:38px!important;border-radius:19px!important;padding:0!important;margin:0!important;gap:0!important;width:100%!important}.chat-container .e-chat-ui input,.chat-container .e-chat-ui textarea{left:14px!important;right:36px!important;font-size:13px!important;height:16px!important;line-height:16px!important}.chat-container .e-chat-ui button,.chat-container .e-chat-ui [class*=send],.chat-container .e-chat-ui [class*=submit]{right:4px!important;width:30px!important;height:30px!important;min-width:30px!important;min-height:30px!important;max-width:30px!important;max-height:30px!important;background:transparent!important;box-shadow:none!important}}.chat-container .e-chat-ui input[type=text],.chat-container .e-chat-ui input[type=search],.chat-container .e-chat-ui textarea,.chat-container .e-chat-ui .e-input,.chat-container .e-chat-ui [role=textbox]{position:absolute!important;left:18px!important;right:48px!important;top:50%!important;transform:translateY(-50%)!important;width:auto!important;max-width:none!important;min-width:0!important;flex:none!important;box-sizing:border-box!important}@media(max-width:768px){.chat-container .e-chat-ui input[type=text],.chat-container .e-chat-ui input[type=search],.chat-container .e-chat-ui textarea,.chat-container .e-chat-ui .e-input,.chat-container .e-chat-ui [role=textbox]{left:16px!important;right:40px!important}}@media(max-width:480px){.chat-container .e-chat-ui input[type=text],.chat-container .e-chat-ui input[type=search],.chat-container .e-chat-ui textarea,.chat-container .e-chat-ui .e-input,.chat-container .e-chat-ui [role=textbox]{left:14px!important;right:36px!important}}.chat-container .e-chat-ui input,.chat-container .e-chat-ui textarea,.chat-container .e-chat-ui input[type=text],.chat-container .e-chat-ui input[type=search],.chat-container .e-chat-ui .e-input,.chat-container .e-chat-ui [role=textbox]{z-index:10!important;pointer-events:auto!important;cursor:text!important;user-select:text!important;-webkit-user-select:text!important;-moz-user-select:text!important;-ms-user-select:text!important}.chat-container .e-chat-ui [class*=input-container],.chat-container .e-chat-ui [class*=input-group],.chat-container .e-chat-ui .e-input-group{pointer-events:auto!important;z-index:1!important}.chat-container .e-chat-ui button,.chat-container .e-chat-ui [class*=send],.chat-container .e-chat-ui [class*=submit]{z-index:11!important;pointer-events:auto!important}.chat-container .e-chat-ui [class*=input-container],.chat-container .e-chat-ui [class*=input-group],.chat-container .e-chat-ui .e-input-group,.chat-container .e-chat-ui,.chat-container{overflow:visible!important}@media(max-width:768px){.chat-container .e-chat-ui .e-chat-footer,.chat-container .e-chat-ui .e-footer,.chat-container .e-chat-ui [class*=footer]{overflow:visible!important}}@media(max-width:480px){.chat-container .e-chat-ui .e-chat-footer,.chat-container .e-chat-ui .e-footer,.chat-container .e-chat-ui [class*=footer]{overflow:visible!important}}.message-interface,.messaging-layout,.messages-panel,.chat-container,.chat-container .e-chat-ui{overflow:visible!important}.chat-container .e-chat-ui .e-message-wrapper{overflow-x:hidden!important;overflow-y:visible!important}.chat-container .e-chat-ui .e-chat-footer,.chat-container .e-chat-ui .e-footer,.chat-container .e-chat-ui [class*=footer]{overflow:visible!important}.chat-container .e-chat-ui *:focus,.chat-container .e-chat-ui *:focus-visible,.chat-container .e-chat-ui input:focus,.chat-container .e-chat-ui input:focus-visible,.chat-container .e-chat-ui textarea:focus,.chat-container .e-chat-ui textarea:focus-visible{outline:none!important;outline-width:0!important;outline-style:none!important;outline-color:transparent!important;border:none!important;box-shadow:none!important;-webkit-focus-ring-color:transparent!important}.chat-container .e-chat-ui .e-input-group:focus,.chat-container .e-chat-ui .e-input-group.e-input-focus,.chat-container .e-chat-ui .e-input-group.e-focus,.chat-container .e-chat-ui [class*=input]:focus{outline:none!important;border:none!important;box-shadow:none!important}.chat-container .e-chat-ui [class*=input-container]:focus-within,.chat-container .e-chat-ui [class*=input-group]:focus-within,.chat-container .e-chat-ui .e-input-group:focus-within{outline:none!important}.new-conversation-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.new-conversation-panel{background:#fff;border-radius:8px;box-shadow:0 8px 32px #00000026;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.panel-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.panel-content{flex:1;padding:20px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:20px;min-height:0}.search-section,.selected-users-section{flex-shrink:0}.selected-users-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333}.selected-users-list{display:flex;flex-wrap:wrap;gap:8px}.selected-user-chip{display:flex;align-items:center;gap:6px;background:#e3f2fd;border:1px solid #2196f3;border-radius:16px;padding:4px 8px 4px 4px;font-size:12px;color:#1976d2}.selected-user-chip .avatar-small{width:20px;height:20px}.selected-user-chip .avatar-small .avatar-initials{font-size:8px}.remove-user{background:none;border:none;color:#1976d2;cursor:pointer;font-size:16px;line-height:1;padding:0;margin-left:2px}.remove-user:hover{color:#d32f2f}.users-section{flex:1;display:flex;flex-direction:column;min-height:0}.users-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333;flex-shrink:0}.users-list{flex:1;overflow-y:auto;border:1px solid #e0e0e0;border-radius:4px;background:#fff;min-height:200px;max-height:300px}.user-item{display:flex;flex-direction:row;align-items:center;gap:4px;width:100%;padding:4px 12px;border:none;border-bottom:1px solid #f0f0f0;background:#fff;text-align:left;cursor:pointer;transition:background-color .2s ease;font:inherit;color:inherit}.user-item:hover{background-color:#f8f9fa}.user-item:last-child{border-bottom:none}.user-item.selected{background-color:#e3f2fd;border-left:3px solid #2196f3}.user-item.selected:hover{background-color:#dbeaf9}.user-avatar .avatar-medium{width:28px;height:28px}.user-avatar .avatar-medium .avatar-initials{font-size:11px}.new-conversation-user-info{flex:1}.user-name{font-size:14px;font-weight:500;color:#333;margin-bottom:0;line-height:1}.user-username{font-size:12px;color:#666;line-height:1}.selected-indicator{color:#2196f3;font-size:16px}.group-name-section{flex-shrink:0}.group-name-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333}.message-section{flex-shrink:0}.message-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#333}.loading-state,.empty-state{display:flex;align-items:center;justify-content:center;height:120px;color:#666;font-style:italic}.panel-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e0e0e0;flex-shrink:0}@media(max-width:768px){.new-conversation-overlay{padding:10px}.new-conversation-panel{max-width:100%;max-height:95vh}.panel-header{padding:16px 20px}.panel-header h2{font-size:16px}.panel-content{padding:16px 20px;gap:16px}.user-item{display:flex;flex-direction:row;align-items:center;padding:3px 10px;gap:4px;flex-wrap:nowrap}.user-avatar{flex-shrink:0}.user-avatar .avatar-medium{width:24px;height:24px}.user-avatar .avatar-medium .avatar-initials{font-size:10px}.new-conversation-user-info{flex:1;min-width:0;overflow:hidden}.user-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-username{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-footer{padding:16px 20px;gap:10px}.panel-footer .e-btn{flex:1;min-width:0}}@media(max-width:480px){.new-conversation-overlay{padding:5px}.new-conversation-panel{max-height:98vh}.panel-header,.panel-content,.panel-footer{padding:12px 16px}}.messaging-page{height:calc(100vh - 92px);max-height:calc(100vh - 92px);min-height:calc(100vh - 92px);display:flex;flex-direction:column;background:linear-gradient(180deg,#fff,#f5f7fb);overflow:hidden;box-sizing:border-box}.messaging-layout{display:flex;flex:1;min-height:0;overflow:visible}.sidebar-panel{width:320px;flex-shrink:0;border-right:1px solid #e0e0e0;background:#fff;display:flex;flex-direction:column}.sidebar-tabs{display:flex;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.tab-button{flex:1;padding:.75rem 1rem;border:none;background:transparent;color:#6c757d;font-weight:500;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent}.tab-button:hover{background:#e9ecef;color:#495057}.tab-button.active{color:#007bff;background:#fff;border-bottom-color:#007bff}.sidebar-content{flex:1;overflow:hidden;position:relative}.tab-content{position:absolute;inset:0;overflow:hidden}.tab-content.active{display:block}.tab-content.hidden{display:none}.messages-panel{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;background:linear-gradient(180deg,#fff,#f6f9ff);position:relative}.messages-panel .tab-content{display:flex;flex-direction:column}@media(max-width:768px){.messaging-page{height:calc(100vh - 144px);max-height:calc(100vh - 144px);min-height:calc(100vh - 144px);position:relative}.messaging-layout{flex-direction:column;position:relative}.sidebar-panel{width:100%;height:90%;border-right:none;border-bottom:1px solid #e0e0e0;flex-shrink:0;z-index:1}.messages-panel{flex:1;min-height:0;position:relative;z-index:2}.messaging-layout.overlay-mode .messages-panel{position:absolute;inset:0;height:100%;z-index:10;background:linear-gradient(180deg,#fff,#f6f9ff);animation:slideInFromRight .3s ease-out}.messaging-layout.overlay-mode .sidebar-panel{z-index:1}.messaging-layout.overlay-mode:before{content:"";position:absolute;inset:0;background:#0000001a;z-index:5;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}}@media(max-width:480px){.messaging-page{height:calc(100vh - 136px);max-height:calc(100vh - 136px);min-height:calc(100vh - 136px)}.sidebar-panel{height:90%}.messages-panel{flex:1;min-height:0}.messaging-layout.overlay-mode .messages-panel{position:absolute;inset:0;height:100%;z-index:10;animation:slideInFromRight .3s ease-out}}@media(max-width:1024px)and (min-width:769px){.sidebar-panel{width:280px}}@media(min-width:1200px){.sidebar-panel{width:360px}}.subscription-plans{max-width:1200px;margin:0 auto;padding:2rem}.plans-header{text-align:center;margin-bottom:3rem}.plans-header h2{font-size:2.5rem;font-weight:700;color:#1a1a1a;margin-bottom:1rem}.plans-header p{font-size:1.1rem;color:#666;max-width:600px;margin:0 auto}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;margin-bottom:2rem}.plan-card{border:2px solid #e5e7eb;border-radius:12px;padding:2rem;transition:all .3s ease;position:relative;background:#fff}.plan-card:hover{border-color:#3b82f6;box-shadow:0 10px 25px #3b82f61a;transform:translateY(-2px)}.plan-card.current-plan{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#fff)}.plan-card.current-plan:before{content:"Current Plan";position:absolute;top:-1px;right:-1px;background:#10b981;color:#fff;padding:.5rem 1rem;border-radius:0 10px;font-size:.875rem;font-weight:600}.plan-header{text-align:center;margin-bottom:2rem}.plan-name{font-size:1.5rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.plan-price{font-size:2.5rem;font-weight:800;color:#3b82f6;margin-bottom:1rem}.plan-description{color:#666;font-size:1rem;line-height:1.5}.plan-features{margin-bottom:2rem}.plan-features h4{font-size:1.1rem;font-weight:600;color:#1a1a1a;margin-bottom:1rem}.plan-features ul{list-style:none;padding:0;margin:0}.plan-features li{display:flex;align-items:center;margin-bottom:.75rem;font-size:.95rem;color:#4b5563}.feature-icon{color:#10b981;font-weight:700;margin-right:.75rem;font-size:1.1rem}.plan-action{text-align:center}.plan-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;transition:all .2s ease}.subscription-plans-loading,.subscription-plans-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.subscription-plans-error p{color:#dc2626;font-size:1.1rem;margin-bottom:1rem}@media(max-width:768px){.subscription-plans{padding:1rem}.plans-header h2{font-size:2rem}.plans-grid{grid-template-columns:1fr;gap:1.5rem}.plan-card{padding:1.5rem}.plan-price{font-size:2rem}}.stripe-checkout-dialog .e-dlg-content{padding:0}.checkout-container{padding:1.5rem}.checkout-form{display:flex;flex-direction:column;gap:1.5rem}.plan-summary{background:#f8fafc;padding:1.5rem;border-radius:8px;border:1px solid #e2e8f0;text-align:center}.plan-summary h3{font-size:1.5rem;font-weight:700;color:#1a202c;margin-bottom:.5rem}.plan-summary .plan-price{font-size:2rem;font-weight:800;color:#3182ce;margin-bottom:.5rem}.plan-summary .plan-description{color:#718096;font-size:.95rem;margin:0}.card-element-container{display:flex;flex-direction:column;gap:.5rem}.card-element-container label{font-weight:600;color:#374151;font-size:.95rem}.card-element-container .StripeElement{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;transition:border-color .2s ease}.card-element-container .StripeElement:focus{border-color:#3b82f6;outline:none}.card-element-container .StripeElement--invalid{border-color:#ef4444}.checkout-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600;border-radius:8px;margin-top:1rem}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:1rem;margin-bottom:1rem}.error-message p{color:#dc2626;font-size:.95rem;margin:0;font-weight:500}@media(max-width:768px){.stripe-checkout-dialog{width:95%!important;max-width:400px!important}.checkout-container,.plan-summary{padding:1rem}.plan-summary h3{font-size:1.25rem}.plan-summary .plan-price{font-size:1.75rem}}.subscription-dashboard{max-width:1200px;margin:0 auto;padding:2rem;display:flex;flex-direction:column;gap:2rem}.dashboard-header{text-align:center;margin-bottom:1rem}.dashboard-header h1{font-size:2.5rem;font-weight:700;color:#1a1a1a;margin-bottom:.5rem}.dashboard-header p{font-size:1.1rem;color:#666}.subscription-status-card,.payment-history-card{border:1px solid #e5e7eb;border-radius:12px;padding:2rem;background:#fff;box-shadow:0 1px 3px #0000001a}.card-header{margin-bottom:1.5rem}.card-header h2{font-size:1.5rem;font-weight:600;color:#1a1a1a;margin:0}.subscription-details{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.subscription-info{display:flex;flex-direction:column;gap:1rem;flex:1}.info-item{display:flex;align-items:center;gap:1rem}.info-item label{font-weight:600;color:#374151;min-width:120px}.plan-name{font-weight:600;color:#3b82f6;font-size:1.1rem}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.status-active{background:#d1fae5;color:#065f46}.status-canceled{background:#fee2e2;color:#991b1b}.status-past-due{background:#fef3c7;color:#92400e}.status-trialing{background:#dbeafe;color:#1e40af}.subscription-actions{display:flex;flex-direction:column;gap:1rem;min-width:200px}.no-subscription{text-align:center;padding:2rem}.no-subscription p{font-size:1.1rem;color:#666;margin-bottom:1.5rem}.payment-history-grid{margin-top:1rem}.payment-actions{display:flex;gap:.5rem}.no-payments{text-align:center;padding:2rem;color:#666}.cancel-confirmation{padding:1rem 0}.cancel-confirmation p{margin-bottom:1rem;line-height:1.5}.cancel-confirmation p:first-child{font-weight:600;color:#1a1a1a}.cancel-confirmation p:last-child{color:#666;font-size:.95rem}.subscription-dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.subscription-plans-dialog .e-dlg-content{padding:0}@media(max-width:768px){.subscription-dashboard{padding:1rem}.dashboard-header h1{font-size:2rem}.subscription-status-card,.payment-history-card{padding:1.5rem}.subscription-details{flex-direction:column;gap:1.5rem}.subscription-actions{min-width:auto;width:100%}.info-item{flex-direction:column;align-items:flex-start;gap:.25rem}.info-item label{min-width:auto;font-size:.9rem}.subscription-plans-dialog{width:95%!important}}.mobile-subscription-plans{padding:20px;max-width:100%;margin:0 auto}.subscription-header{text-align:center;margin-bottom:30px}.subscription-header h2{color:#2563eb;margin-bottom:10px;font-size:1.8rem;font-weight:600}.subscription-header p{color:#6b7280;font-size:1rem}.mobile-subscription-loading,.mobile-subscription-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.mobile-subscription-error h3{color:#dc2626;margin-bottom:10px}.mobile-subscription-error p{color:#6b7280;margin-bottom:20px}.current-subscription{margin-bottom:30px}.subscription-status-card{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-radius:12px;padding:0;border:none;box-shadow:0 4px 12px #10b9814d}.subscription-status{padding:20px}.subscription-status h3{margin:0 0 10px;font-size:1.2rem;font-weight:600}.subscription-status p{margin:5px 0;opacity:.9;font-size:.9rem}.offerings-container,.offering-section{margin-bottom:30px}.offering-section h3{color:#1f2937;margin-bottom:20px;font-size:1.3rem;font-weight:600;text-align:center}.packages-grid{display:grid;grid-template-columns:1fr;gap:16px}@media(min-width:640px){.packages-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.packages-grid{grid-template-columns:repeat(3,1fr)}}.package-card{border-radius:12px;border:2px solid #e5e7eb;transition:all .3s ease;cursor:pointer;background:#fff;box-shadow:0 2px 8px #0000001a}.package-card:hover{border-color:#2563eb;box-shadow:0 4px 16px #2563eb33;transform:translateY(-2px)}.package-card.active-package{border-color:#10b981;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);box-shadow:0 4px 16px #10b98133}.package-content{padding:20px;height:100%;display:flex;flex-direction:column}.package-header{text-align:center;margin-bottom:16px}.package-header h4{color:#2563eb;margin:0 0 8px;font-size:1.1rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.package-price{margin-bottom:10px}.price{font-size:1.5rem;font-weight:700;color:#1f2937}.package-details{flex:1;margin-bottom:20px}.package-details h5{color:#1f2937;margin:0 0 8px;font-size:1rem;font-weight:600}.package-details p{color:#6b7280;font-size:.9rem;line-height:1.4;margin:0}.package-actions{margin-top:auto}.package-actions .e-btn{width:100%;padding:12px;font-weight:600;border-radius:8px}.no-offerings{text-align:center;padding:40px 20px;color:#6b7280}.subscription-actions{display:flex;justify-content:center;margin-top:30px}.subscription-actions .e-btn{padding:12px 24px;font-weight:600;border-radius:8px}.purchase-confirmation{padding:20px 0;text-align:center}.purchase-confirmation h4{color:#1f2937;margin:0 0 10px;font-size:1.2rem;font-weight:600}.purchase-confirmation p{color:#6b7280;margin:8px 0;line-height:1.4}.confirmation-price{margin:20px 0;padding:16px;background:#f3f4f6;border-radius:8px}.confirmation-price strong{font-size:1.4rem;color:#2563eb}.confirmation-note{font-size:.85rem;color:#9ca3af;font-style:italic}.dialog-actions .e-btn{padding:10px 20px;font-weight:600;border-radius:6px;min-width:100px}@media(max-width:640px){.mobile-subscription-plans{padding:16px}.subscription-header h2{font-size:1.5rem}.package-content{padding:16px}.dialog-actions{flex-direction:column}.dialog-actions .e-btn{width:100%;margin:4px 0}}@media(prefers-color-scheme:dark){.mobile-subscription-plans{background:#1f2937;color:#f9fafb}.subscription-header h2{color:#60a5fa}.package-card{background:#374151;border-color:#4b5563;color:#f9fafb}.package-card:hover{border-color:#60a5fa}.package-card.active-package{background:linear-gradient(135deg,#064e3b,#065f46);border-color:#34d399}.package-header h4{color:#60a5fa}.price,.package-details h5{color:#f9fafb}.confirmation-price{background:#374151}}.mobile-subscription-flow{padding:20px;max-width:100%}.flow-header{text-align:center;margin-bottom:30px}.flow-header h2{color:#2563eb;margin-bottom:10px;font-size:1.8rem;font-weight:600}.flow-header p{color:#6b7280;font-size:1rem}.initialization-message,.error-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #2563eb;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.loading-spinner.large{width:60px;height:60px;border-width:6px}.error-message h3{color:#dc2626;margin-bottom:10px}.error-message p{color:#6b7280;margin-bottom:20px}.subscription-plans,.offering-group{margin-bottom:30px}.offering-group h3{color:#1f2937;margin-bottom:20px;font-size:1.3rem;font-weight:600;text-align:center}.packages-list{display:flex;flex-direction:column;gap:16px}.package-item{display:flex;align-items:center;justify-content:space-between;padding:20px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.package-item:hover{border-color:#2563eb;box-shadow:0 4px 16px #2563eb33;transform:translateY(-2px)}.package-info{flex:1;margin-right:16px}.package-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.package-header h4{color:#1f2937;margin:0;font-size:1.1rem;font-weight:600}.package-price{color:#2563eb;font-size:1.2rem;font-weight:700}.package-description{color:#6b7280;font-size:.9rem;line-height:1.4;margin:8px 0}.package-type{color:#059669;font-size:.8rem;font-weight:500;text-transform:capitalize;background:#ecfdf5;padding:4px 8px;border-radius:4px;display:inline-block}.package-select-btn{min-width:120px;padding:12px 20px;font-weight:600;border-radius:8px}.flow-actions{display:flex;justify-content:center;margin-top:30px}.flow-actions .e-btn{padding:12px 24px;font-weight:600;border-radius:8px}.purchase-flow-content{padding:20px 0}.purchase-steps{display:flex;flex-direction:column;gap:16px;margin-bottom:30px}.step{display:flex;align-items:center;gap:16px;padding:12px;border-radius:8px;transition:all .3s ease}.step.active{background:#eff6ff;border:1px solid #2563eb}.step.completed{background:#f0fdf4;border:1px solid #10b981}.step-indicator{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0}.step.active .step-indicator{background:#2563eb;color:#fff}.step.completed .step-indicator{background:#10b981;color:#fff}.step:not(.active):not(.completed) .step-indicator{background:#f3f4f6;color:#6b7280;border:2px solid #e5e7eb}.step-content h4{color:#1f2937;margin:0 0 4px;font-size:1rem;font-weight:600}.step-content p{color:#6b7280;margin:0;font-size:.9rem}.step.active .step-content h4{color:#2563eb}.step.completed .step-content h4{color:#10b981}.confirm-step{text-align:center}.confirm-step h3{color:#1f2937;margin-bottom:20px;font-size:1.3rem;font-weight:600}.purchase-summary{background:#f8fafc;padding:20px;border-radius:8px;margin-bottom:20px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e5e7eb}.summary-item:last-child{border-bottom:none;font-weight:600;color:#1f2937}.summary-item span:first-child{color:#6b7280}.summary-item span:last-child{color:#1f2937;font-weight:500}.purchase-note{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:16px;margin-bottom:20px}.purchase-note p{color:#92400e;font-size:.9rem;line-height:1.4;margin:0}.purchase-error{background:#fef2f2;border:1px solid #f87171;border-radius:8px;padding:16px;margin-top:16px}.purchase-error p{color:#dc2626;font-size:.9rem;margin:0}.processing-step{text-align:center;padding:40px 20px}.processing-animation{margin-bottom:20px}.processing-step h3{color:#1f2937;margin-bottom:10px;font-size:1.3rem;font-weight:600}.processing-step p{color:#6b7280;font-size:1rem}.success-step{text-align:center;padding:40px 20px}.success-step h3{color:#10b981;margin-bottom:10px;font-size:1.5rem;font-weight:600}.success-step p{color:#6b7280;font-size:1rem;line-height:1.5}.dialog-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb}.dialog-actions .e-btn{padding:10px 20px;font-weight:600;border-radius:6px;min-width:120px}@media(max-width:640px){.mobile-subscription-flow{padding:16px}.flow-header h2{font-size:1.5rem}.package-item{flex-direction:column;text-align:center;gap:16px}.package-info{margin-right:0}.package-header{flex-direction:column;gap:8px}.package-select-btn{width:100%}.purchase-steps{gap:12px}.step{padding:10px}.step-indicator{width:28px;height:28px;font-size:.8rem}.dialog-actions{flex-direction:column}.dialog-actions .e-btn{width:100%;margin:4px 0}}@media(prefers-color-scheme:dark){.mobile-subscription-flow{background:#1f2937;color:#f9fafb}.flow-header h2{color:#60a5fa}.offering-group h3{color:#f9fafb}.package-item{background:#374151;border-color:#4b5563;color:#f9fafb}.package-item:hover{border-color:#60a5fa}.package-header h4{color:#f9fafb}.package-price{color:#60a5fa}.package-description{color:#d1d5db}.step.active{background:#1e3a8a;border-color:#60a5fa}.step.completed{background:#064e3b;border-color:#34d399}.step-content h4{color:#f9fafb}.step-content p{color:#d1d5db}.step.active .step-content h4{color:#60a5fa}.step.completed .step-content h4{color:#34d399}.confirm-step h3{color:#f9fafb}.purchase-summary{background:#374151}.summary-item{border-color:#4b5563}.summary-item span:first-child{color:#d1d5db}.summary-item span:last-child{color:#f9fafb}.processing-step h3{color:#f9fafb}.processing-step p{color:#d1d5db}.success-step h3{color:#34d399}.success-step p{color:#d1d5db}}.subscription-migration{padding:20px;max-width:800px;margin:0 auto}.migration-header{text-align:center;margin-bottom:30px}.migration-header h3{color:#2563eb;margin-bottom:10px;font-size:1.5rem;font-weight:600}.migration-header p{color:#6b7280;font-size:1rem}.no-subscription-message{text-align:center;padding:40px 20px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.no-subscription-message h3{color:#1f2937;margin-bottom:10px}.no-subscription-message p{color:#6b7280}.current-subscription-info{background:#f8fafc;padding:20px;border-radius:12px;border:1px solid #e2e8f0;margin-bottom:30px}.current-platform h4{color:#1f2937;margin-bottom:12px;font-size:1.1rem;font-weight:600}.platform-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.platform-badge.current{background:#10b981;color:#fff}.platform-badge:not(.current){background:#2563eb;color:#fff}.current-platform p{color:#6b7280;font-size:.9rem;margin:0}.migration-options{margin-bottom:30px}.migration-options h4{color:#1f2937;margin-bottom:20px;font-size:1.2rem;font-weight:600}.platform-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-bottom:20px}.platform-option{background:#fff;padding:24px;border-radius:12px;border:2px solid #e5e7eb;box-shadow:0 2px 8px #0000001a;transition:all .3s ease}.platform-option:hover{border-color:#2563eb;box-shadow:0 4px 16px #2563eb33;transform:translateY(-2px)}.option-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.option-header h5{color:#1f2937;margin:0;font-size:1.1rem;font-weight:600}.platform-option p{color:#6b7280;font-size:.95rem;line-height:1.5;margin-bottom:20px}.platform-option .e-btn{width:100%;padding:12px;font-weight:600;border-radius:8px}.compatibility-reasons{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:16px}.compatibility-reasons h5{color:#92400e;margin:0 0 12px;font-size:1rem;font-weight:600}.compatibility-reasons ul{margin:0;padding-left:20px;color:#92400e}.compatibility-reasons li{margin:4px 0;font-size:.9rem}.migration-recommendations{background:#ecfdf5;border:1px solid #10b981;border-radius:8px;padding:16px;margin-bottom:20px}.migration-recommendations h4{color:#065f46;margin:0 0 12px;font-size:1.1rem;font-weight:600}.migration-recommendations ul{margin:0;padding-left:20px;color:#065f46}.migration-recommendations li{margin:6px 0;font-size:.9rem;line-height:1.4}.migration-error{background:#fef2f2;border:1px solid #f87171;border-radius:8px;padding:16px;margin-bottom:20px}.migration-error p{color:#dc2626;margin:0;font-size:.9rem}.migration-dialog-content{padding:20px 0}.migration-stepper{margin-bottom:30px}.migration-step-content{padding:20px 0}.migration-step-content h4{color:#1f2937;margin-bottom:16px;font-size:1.3rem;font-weight:600}.migration-step-content p{color:#6b7280;line-height:1.6;margin-bottom:20px}.migration-details{background:#f8fafc;padding:16px;border-radius:8px;margin-bottom:20px}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e5e7eb}.detail-item:last-child{border-bottom:none}.detail-item span:first-child{color:#6b7280;font-weight:500}.detail-item span:last-child{color:#1f2937;font-weight:600}.migration-plan{margin-bottom:20px}.plan-summary{background:#f8fafc;padding:16px;border-radius:8px;margin-bottom:20px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.summary-item span:first-child{color:#6b7280;font-weight:500}.summary-item span:last-child{color:#1f2937;font-weight:600}.migration-steps h5{color:#1f2937;margin-bottom:16px;font-size:1.1rem;font-weight:600}.migration-step{display:flex;align-items:flex-start;gap:16px;padding:16px;border-radius:8px;margin-bottom:12px;border:1px solid #e5e7eb;transition:all .3s ease}.migration-step.completed{background:#f0fdf4;border-color:#10b981}.step-indicator{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.9rem;flex-shrink:0;background:#f3f4f6;color:#6b7280;border:2px solid #e5e7eb}.migration-step.completed .step-indicator{background:#10b981;color:#fff;border-color:#10b981}.step-content{flex:1}.step-content h6{color:#1f2937;margin:0 0 6px;font-size:1rem;font-weight:600}.step-content p{color:#6b7280;margin:0 0 8px;font-size:.9rem;line-height:1.4}.user-action-badge{background:#fef3c7;color:#92400e;padding:4px 8px;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.migration-complete{text-align:center;padding:20px}.success-icon{font-size:4rem;margin-bottom:20px}.migration-complete h4{color:#10b981;margin-bottom:16px;font-size:1.5rem;font-weight:600}.migration-complete p{color:#6b7280;font-size:1.1rem;margin-bottom:20px}.completed-steps,.migration-errors{text-align:left;margin:20px 0;padding:16px;border-radius:8px}.completed-steps{background:#f0fdf4;border:1px solid #10b981}.migration-errors{background:#fef2f2;border:1px solid #f87171}.completed-steps h5{color:#065f46;margin:0 0 12px;font-size:1rem;font-weight:600}.migration-errors h5{color:#dc2626;margin:0 0 12px;font-size:1rem;font-weight:600}.completed-steps ul{margin:0;padding-left:20px;color:#065f46}.migration-errors ul{margin:0;padding-left:20px;color:#dc2626}.completed-steps li,.migration-errors li{margin:4px 0;font-size:.9rem}.step-actions{display:flex;justify-content:center;margin-top:30px}.step-actions .e-btn{padding:12px 24px;font-weight:600;border-radius:8px;min-width:160px}@media(max-width:768px){.subscription-migration{padding:16px}.platform-options{grid-template-columns:1fr;gap:16px}.platform-option{padding:20px}.option-header{flex-direction:column;align-items:flex-start;gap:8px}.migration-step{padding:12px}.step-indicator{width:28px;height:28px;font-size:.8rem}.detail-item{flex-direction:column;align-items:flex-start;gap:4px}}@media(prefers-color-scheme:dark){.subscription-migration{background:#1f2937;color:#f9fafb}.migration-header h3{color:#60a5fa}.no-subscription-message,.current-subscription-info{background:#374151;border-color:#4b5563}.no-subscription-message h3,.current-platform h4,.migration-options h4{color:#f9fafb}.platform-option{background:#374151;border-color:#4b5563}.platform-option:hover{border-color:#60a5fa}.option-header h5{color:#f9fafb}.migration-details,.plan-summary{background:#374151}.detail-item,.summary-item{border-color:#4b5563}.detail-item span:last-child,.summary-item span:last-child{color:#f9fafb}.migration-step{background:#374151;border-color:#4b5563}.migration-step.completed{background:#064e3b;border-color:#34d399}.step-content h6{color:#f9fafb}.migration-complete h4{color:#34d399}.completed-steps{background:#064e3b;border-color:#34d399}.completed-steps h5,.completed-steps ul{color:#34d399}}.profile-view{max-width:900px;margin:0 auto;padding:24px;background:#fff;border-radius:16px;box-shadow:0 2px 12px #00000014}.profile-header{display:flex;gap:30px;margin-bottom:30px;align-items:flex-start;padding-bottom:24px;border-bottom:2px solid #f0f0f0}.profile-avatar-section{flex-shrink:0}.profile-avatar{width:120px;height:120px;border-radius:50%;overflow:hidden;border:4px solid #e0e0e0;box-shadow:0 4px 12px #0000001a;transition:transform .2s ease}.profile-avatar:hover{transform:scale(1.05)}.profile-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;color:#fff;font-size:2rem;font-weight:700}.profile-info{flex:1}.profile-name{font-size:2rem;font-weight:700;margin:0 0 5px;color:#333}.profile-username{font-size:1.1rem;color:#666;margin:0 0 15px}.profile-bio{font-size:1rem;color:#555;line-height:1.5;margin:0 0 20px}.profile-stats{display:flex;gap:30px;margin-bottom:20px}.stat{display:flex;flex-direction:column;align-items:center}.stat-number{font-size:1.5rem;font-weight:700;color:#333}.stat-label{font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.profile-actions{display:flex;gap:10px}.profile-actions{align-items:center;width:100%;max-width:600px}.profile-action-button-wrapper{display:inline-flex;align-items:center;justify-content:center;margin:0 0 8px;padding:0}.subscription-manage{display:flex;flex-direction:column;align-items:flex-start;gap:12px;margin-top:16px;padding:20px;background:#f8f9fa;border-radius:12px;border:1px solid #e0e0e0;width:100%;max-width:600px}.subscription-manage:not(.no-subscription){background:#f8f9fa;border:1px solid #e0e0e0}.subscription-manage.no-subscription{background:#f8f9fa;color:#333;border:1px solid #e0e0e0;box-shadow:none}.subscription-line{margin:0;color:#666;font-size:.95rem;font-weight:500}.subscription-manage.no-subscription .subscription-line{color:#333;font-size:1rem;font-weight:600}.subscription-hint{margin:0;color:#777;font-size:.9rem}.subscription-manage.no-subscription .subscription-hint{color:#666;font-size:.9rem}.subscription-loading{display:inline-flex;align-items:center;gap:8px;color:#666;font-size:.9rem}.subscription-loading .loading-spinner{width:16px;height:16px;border-width:2px}.subscription-error{margin:0;color:#d32f2f;font-size:.9rem}.subscription-manage.no-subscription .subscription-error{color:#d32f2f;background:#d32f2f1a;padding:12px;border-radius:6px;width:100%;text-align:center}.subscription-error-block{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding:12px;background:#d32f2f1a;border-radius:8px;width:100%}.subscription-manage.no-subscription .subscription-error-block{background:#d32f2f1a}.subscription-cta{display:flex;flex-direction:column;gap:16px;width:100%;margin-top:8px}.subscription-option{display:flex;flex-direction:column;align-items:stretch;gap:8px;padding:16px;background:#fff;border-radius:8px;border:1px solid #e0e0e0;box-shadow:0 1px 3px #00000014;transition:transform .2s ease,box-shadow .2s ease;position:relative}.subscription-option:hover{transform:translateY(-1px);box-shadow:0 2px 6px #0000001f}.subscription-option.highlighted{border:2px solid #667eea;box-shadow:0 2px 8px #667eea26}.subscription-option.highlighted:before{content:"✨ " attr(data-badge);position:absolute;top:-10px;right:16px;background:#667eea;color:#fff;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600;box-shadow:0 2px 6px #667eea33}.subscription-manage.no-subscription .subscription-option{background:#fff;border:1px solid #e0e0e0}.subscription-manage.no-subscription .subscription-option.highlighted{background:#fff;border:2px solid #667eea;box-shadow:0 2px 8px #667eea26}.subscription-manage.no-subscription .subscription-option:hover{border-color:#e0e0e0;background:#fff}.subscription-option .e-btn{width:100%;min-width:auto;font-weight:600;padding:12px 20px;font-size:.95rem}.subscription-price{font-size:1rem;color:#444;font-weight:600;text-align:center;padding-top:4px}.profile-interests{background:linear-gradient(135deg,#f8f9fa,#e8eaf6);padding:24px;border-radius:12px;margin-top:24px;border:1px solid #e0e0e0;box-shadow:0 2px 8px #0000000d}.profile-interests h3{margin:0 0 16px;color:#333;font-size:1.2rem;font-weight:600}.interests-tags{display:flex;flex-wrap:wrap;gap:10px}.interest-tag{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:500;box-shadow:0 2px 6px #667eea33;transition:transform .2s ease,box-shadow .2s ease}.interest-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.interest-tag.small{padding:6px 12px;font-size:.8rem}.profile-edit{max-width:600px;margin:0 auto;padding:20px}.profile-edit-header h2{margin:0 0 30px;color:#333}.profile-edit-form{display:flex;flex-direction:column;gap:25px}.avatar-edit-section{display:flex;align-items:center;gap:20px;padding:20px;background:#f8f9fa;border-radius:8px}.current-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;border:2px solid #e0e0e0}.profile-avatar .avatar,.profile-avatar .avatar img{width:100%!important;height:100%!important}.profile-avatar .avatar-initials{font-size:2rem!important}.avatar-wrapper .avatar,.avatar-wrapper .avatar img,.current-avatar .avatar,.current-avatar .avatar img{width:100%!important;height:100%!important}.avatar-wrapper .avatar-initials,.current-avatar .avatar-initials{font-size:1.6rem!important}.avatar-wrapper{position:relative;display:inline-block}.avatar-delete-icon{position:absolute;right:-8px;bottom:-8px;width:28px;height:28px;border-radius:50%;background:#e53935;color:#fff;border:none;display:flex;align-items:center;justify-content:center;font-size:18px;cursor:pointer;box-shadow:0 2px 6px #00000026;z-index:2}.avatar-delete-icon:disabled{opacity:.6;cursor:not-allowed}.current-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.form-row{display:flex;gap:20px}.form-field{display:flex;flex-direction:column;gap:8px;flex:1}.form-field label{font-weight:500;color:#333;font-size:.9rem}.interests-input{display:flex;gap:10px;align-items:flex-end}.interests-input .e-textbox{flex:1}.learning-interest-input{flex:1;padding:10px 12px;border:1px solid #dcdcdc;border-radius:4px;font-size:.95rem}.learning-interest-input:focus{outline:none;border-color:#7aa7ff;box-shadow:0 0 0 3px #7aa7ff1f}.interests-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.interest-chip{display:flex;align-items:center;background:#e3f2fd;color:#1976d2;padding:6px 12px;border-radius:16px;font-size:.85rem;gap:8px}.remove-interest{background:none;border:none;color:#1976d2;cursor:pointer;font-size:1.2rem;line-height:1;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.remove-interest:hover{background:#1976d21a;border-radius:50%}.form-actions{display:flex;gap:15px;justify-content:flex-end;padding-top:20px;border-top:1px solid #e0e0e0}.user-search{max-width:800px;margin:0 auto;padding:20px}.search-header{margin-bottom:30px}.search-header h2{margin:0 0 20px;color:#333}.search-input{width:100%}.users-list{display:flex;flex-direction:column;gap:15px}.user-search-item{display:flex;align-items:flex-start;gap:15px;padding:20px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;transition:box-shadow .2s ease}.user-search-item:hover{box-shadow:0 2px 8px #0000001a}.user-search-item .user-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;border:2px solid #e0e0e0;flex-shrink:0}.user-search-item .user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}@media(max-width:600px){.profile-header{flex-direction:column;align-items:center;gap:16px}.profile-avatar{width:100px;height:100px}.profile-info{width:100%;text-align:center}.profile-actions{flex-direction:column;align-items:center;gap:10px}.profile-action-button-wrapper,.subscription-manage{width:100%;display:flex;justify-content:center;gap:8px}.subscription-manage{padding:16px}.subscription-manage.no-subscription{align-items:center;text-align:center;max-width:none;padding:20px 16px}.subscription-manage.no-subscription .subscription-line,.subscription-manage.no-subscription .subscription-hint,.subscription-hint{text-align:center}.subscription-cta{grid-template-columns:1fr}.subscription-option{align-items:stretch}.subscription-error-block{justify-content:center}.subscription-manage .e-outline,.profile-action-button-wrapper .e-primary{min-width:160px;max-width:100%;width:auto}}.user-search-item .avatar-placeholder{font-size:1.2rem}.profile-user-info{flex:1}.profile-user-name{font-size:1.1rem;font-weight:600;color:#333;margin-bottom:2px}.user-username{font-size:.9rem;color:#666;margin-bottom:8px}.user-bio{font-size:.9rem;color:#555;line-height:1.4;margin-bottom:8px}.user-stats{display:flex;gap:15px;font-size:.85rem;color:#666;margin-bottom:10px}.user-interests{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.more-interests{font-size:.75rem;color:#666;font-style:italic}.user-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.pagination{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:30px;padding:20px}.page-info{font-size:.9rem;color:#666}.profile-loading,.search-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.profile-error,.no-results{text-align:center;padding:60px 20px;color:#666}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:4px;border-left:4px solid #c62828;margin-bottom:20px}.delete-confirmation p{margin:0 0 10px;color:#333}.dialog-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:12px}.confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.confirm-panel{background:#fff;border-radius:8px;box-shadow:0 8px 32px #00000026;width:100%;max-width:420px;display:flex;flex-direction:column;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.panel-header h2{margin:0;font-size:16px}.close-button{background:none;border:none;font-size:20px;color:#666;cursor:pointer;padding:4px;border-radius:4px}.close-button:hover{background:#f5f5f5;color:#333}.panel-content{padding:20px}.panel-footer{display:flex;justify-content:flex-end;gap:12px;padding:12px 20px;border-top:1px solid #e0e0e0}@media(max-width:768px){.profile-header{flex-direction:column;align-items:center;text-align:center;gap:20px}.profile-stats{justify-content:center}.form-row{flex-direction:column;gap:15px}.user-search-item{flex-direction:column;align-items:center;text-align:center}.user-actions{flex-direction:row;justify-content:center}.form-actions{flex-direction:column}}.change-password-container{padding:20px}.change-password-container h3{margin-top:0;margin-bottom:20px;font-size:1.5rem}.change-password-form{display:flex;flex-direction:column;gap:20px}.change-password-form .form-field{margin-bottom:15px}.change-password-form .form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:10px}.error-message{padding:10px;border-radius:4px;background-color:#fee;color:#c33;border:1px solid #fcc}.success-message{padding:10px;border-radius:4px;background-color:#efe;color:#3c3;border:1px solid #cfc}.password-section{padding:20px;border:1px solid #e0e0e0;border-radius:8px;margin-top:20px;background-color:#fafafa}.password-section label{font-weight:600;margin-bottom:10px;display:block}.password-panel{max-width:500px;width:100%}.password-panel .panel-content{padding:20px}.password-panel .change-password-container{padding:0}.password-panel .change-password-container h3{display:none}.user-management{padding:24px;max-width:1400px;margin:0 auto}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.user-management-header h2{margin:0;font-size:24px;font-weight:600;color:#1e293b}.user-grid-container{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.user-avatar-small{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover;display:block;border:2px solid #e5e7eb}.avatar-placeholder-small{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;text-transform:uppercase}.role-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.role-badge.student{background:#dbeafe;color:#1e40af}.role-badge.instructor{background:#fef3c7;color:#92400e}.role-badge.admin{background:#fecaca;color:#dc2626}.user-form{padding:20px 0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.user-grid-container .e-grid{border:none}.user-grid-container .e-grid .e-headercell{background:#f9fafb;font-weight:600;color:#374151}.user-grid-container .e-grid .e-row:hover{background:#f9fafb}.user-dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.user-dialog-panel{background:#fff;border-radius:8px;box-shadow:0 8px 32px #00000026;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.user-dialog-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.user-dialog-panel .panel-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.user-dialog-panel .close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.user-dialog-panel .close-button:hover{background:#f5f5f5;color:#333}.user-dialog-panel .panel-content{flex:1;padding:20px 24px;overflow-y:auto;min-height:0}.user-dialog-panel .panel-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e0e0e0;flex-shrink:0}.action-buttons{display:flex;gap:8px;align-items:center}.action-buttons .e-btn{min-width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center}.confirmation-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1050;padding:20px;box-sizing:border-box}.confirmation-panel{background:#fff;border-radius:8px;box-shadow:0 8px 32px #00000026;width:100%;max-width:450px;display:flex;flex-direction:column;overflow:hidden}.confirmation-panel .panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.confirmation-panel .panel-header h2{margin:0;font-size:18px;font-weight:600;color:#333}.confirmation-panel .close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.confirmation-panel .close-button:hover{background:#f5f5f5;color:#333}.confirmation-panel .panel-content{padding:20px 24px}.confirmation-panel .panel-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e0e0e0;flex-shrink:0}.delete-dialog-content p{margin:0 0 16px;line-height:1.5}.delete-dialog-content p:last-child{margin-bottom:0}.app-header{display:flex;align-items:center;justify-content:space-between;height:60px;padding:0 1rem;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000001a;z-index:1000}.header-left{display:flex;align-items:center;gap:1rem}.logo h1{margin:0;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-link{color:inherit;text-decoration:none;display:inline-block}.logo-link,.logo-link:link,.logo-link:visited,.logo-link:hover,.logo-link:active,.logo-link:focus{text-decoration:none;color:inherit}.header-center{flex:1;display:flex;justify-content:center;max-width:500px;margin:0 2rem}.header-right{display:flex;align-items:center;gap:.5rem}.user-menu{position:relative}.user-dropdown-menu{position:fixed;top:68px;right:1rem;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:160px;max-width:200px;z-index:1001;overflow:hidden}.user-dropdown-menu:before{content:"";position:absolute;top:-6px;right:12px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid #e0e0e0}.user-dropdown-menu:after{content:"";position:absolute;top:-5px;right:12px;width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid white}.menu-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background-color .2s ease;font-size:.875rem}.menu-item svg{flex-shrink:0;color:#64748b}.menu-item:hover{background-color:#f5f5f5}.menu-item:hover svg{color:#475569}.menu-item:first-child{border-radius:8px 8px 0 0}.menu-item:last-child{border-radius:0 0 8px 8px}.menu-separator{height:1px;background-color:#e0e0e0;margin:.25rem 0}.header-user-info{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.25rem;border-radius:8px;transition:background-color .2s ease}.header-user-info:hover{background-color:#f5f5f5}.user-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#2196f3;color:#fff;font-weight:500;font-size:.875rem}.user-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.header-avatar{width:32px!important;height:32px!important}.avatar-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;text-transform:uppercase}.header-user-name{font-weight:500;color:#333;white-space:nowrap}@media(max-width:768px){.app-header{padding:.5rem .75rem;height:auto;min-height:60px}.header-center{display:none}.logo{display:flex;align-items:center;height:100%;padding:0 0 0 .5rem;margin-top:1rem}.logo h1{font-size:1.25rem}.header-user-name{display:none}.user-avatar{width:28px;height:28px;font-size:.75rem}.user-dropdown-menu{right:.75rem;min-width:140px}}@media(max-width:480px){.app-header{padding:.5rem;height:auto;min-height:60px}.header-left{gap:.5rem}.logo{display:flex;align-items:center;height:100%;padding:0 0 0 .5rem}.logo h1{font-size:1.125rem}.user-dropdown-menu{right:.5rem}}.bottom-navigation{background:#fff;border:1px solid #e0e0e0;z-index:1100;box-shadow:0 -2px 8px #0000001a;transform:translateZ(0);will-change:transform;overscroll-behavior:none}.bottom-navigation.mobile{position:fixed;bottom:0;left:0;right:0;height:60px;padding-bottom:env(safe-area-inset-bottom);border-top:1px solid #e0e0e0;border-left:none;border-right:none;border-bottom:none}.bottom-navigation.sidebar{position:fixed;left:0;top:60px;bottom:0;width:200px;border-left:none;border-right:1px solid #e0e0e0;border-top:none;border-bottom:none;box-shadow:2px 0 8px #0000001a;transition:width .3s ease;overflow:hidden}.bottom-navigation.sidebar.collapsed{width:64px}.bottom-nav-container{display:flex;height:100%;width:100%;padding:0;margin:0}.bottom-navigation.mobile .bottom-nav-container{flex-direction:row;align-items:stretch;justify-content:space-around}.bottom-navigation.sidebar .bottom-nav-container{flex-direction:column;align-items:stretch;justify-content:flex-start;padding:8px 0;gap:4px}.sidebar-toggle-container{display:flex;justify-content:flex-end;padding:12px;border-bottom:1px solid #e0e0e0}.sidebar-toggle-btn{background:transparent;border:none;cursor:pointer;padding:8px;border-radius:4px;color:#666;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-tap-highlight-color:transparent}.sidebar-toggle-btn:hover{background:#0000000a;color:#333}.sidebar-toggle-btn:active{transform:scale(.95)}.nav-item{display:flex;align-items:center;justify-content:center;gap:4px;background:transparent;border:none;cursor:pointer;transition:all .2s ease;color:#666;text-decoration:none;position:relative;min-width:0;min-height:44px;-webkit-tap-highlight-color:transparent}.bottom-navigation.mobile .nav-item{flex:1;flex-direction:column;padding:8px 4px}.bottom-navigation.sidebar .nav-item{flex-direction:row;padding:12px 16px;margin:0 8px;border-radius:8px;min-height:48px;justify-content:flex-start;gap:12px}.bottom-navigation.sidebar.collapsed .nav-item{flex-direction:column;justify-content:center;align-items:center;padding:12px;margin:0;gap:4px}.nav-item:hover{background:#0000000a}.nav-item:active{transform:scale(.95)}.nav-item.active{color:#2196f3}.bottom-navigation.mobile .nav-item.active,.bottom-navigation.sidebar .nav-item.active{background-color:#e3f2fd}.nav-icon{flex-shrink:0;transition:all .2s ease}.nav-item:active .nav-icon{transform:scale(.9)}.nav-label{font-size:11px;font-weight:500;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.2;-moz-user-select:none;user-select:none;-webkit-user-select:none}.bottom-navigation.mobile .nav-label{display:none}.bottom-navigation.sidebar .nav-label{display:block;font-size:14px;text-align:left;white-space:nowrap}.bottom-navigation.sidebar.collapsed .nav-label{display:none}.nav-item.active .nav-label{font-weight:600}@keyframes tabSwitch{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}.nav-item.active .nav-icon{animation:tabSwitch .3s ease}@media(prefers-color-scheme:dark){.bottom-navigation{background:#1e1e1e;border-color:#333}.sidebar-toggle-container{border-bottom-color:#333}.sidebar-toggle-btn{color:#b0b0b0}.sidebar-toggle-btn:hover{background:#ffffff14;color:#fff}.nav-item{color:#b0b0b0}.nav-item:hover{background:#ffffff14}.nav-item.active{color:#64b5f6}.bottom-navigation.mobile .nav-item.active,.bottom-navigation.sidebar .nav-item.active{background-color:#2196f31f}}@media(max-width:768px){.bottom-navigation.sidebar{display:none}}@media(min-width:769px){.bottom-navigation.mobile{display:none}}@media(max-width:375px){.bottom-navigation.mobile .nav-icon{width:20px;height:20px}.bottom-navigation.mobile{height:56px}.bottom-navigation.mobile .nav-item{padding:6px 4px}}@media(max-width:320px){.bottom-navigation.mobile .nav-icon{width:18px;height:18px}}@supports (padding-bottom: env(safe-area-inset-bottom)){.bottom-navigation.mobile{height:calc(60px + env(safe-area-inset-bottom))}}@media(orientation:landscape)and (max-height:500px){.bottom-navigation.mobile{height:50px}.bottom-navigation.mobile .nav-item{padding:4px}.bottom-navigation.mobile .nav-icon{width:20px;height:20px}}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden;position:relative}.app-content{display:flex;flex-direction:row;flex:1;overflow:hidden}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:1rem;transition:margin-left .3s ease;position:relative;-webkit-overflow-scrolling:touch}@media(min-width:769px){.main-content{margin-left:200px}.main-content.sidebar-collapsed{margin-left:64px}}.app-layout.mobile{padding-bottom:60px}.app-layout.mobile .main-content{padding:.75rem}.app-layout.tablet .main-content{padding:1rem}.app-layout.orientation-landscape.mobile .main-content{padding:.5rem .75rem}.app-layout.orientation-landscape.tablet .main-content{padding:.75rem 1rem}.app-layout.mobile{padding-bottom:max(60px,env(safe-area-inset-bottom))}.app-layout.mobile .main-content{transform:translateZ(0);will-change:scroll-position}@media(max-width:480px){.app-layout.mobile .main-content{padding:.5rem}}@media(max-width:768px){.app-layout{padding-bottom:max(60px,env(safe-area-inset-bottom))}.main-content{padding:.75rem}}@media(min-width:769px)and (max-width:1024px){.main-content{padding:1rem;order:1}}@media(min-width:1025px){.app-layout{padding-bottom:0}.main-content{order:1}}@media(orientation:landscape)and (max-height:500px){.app-layout.mobile .main-content{padding:.5rem}.app-layout.tablet .main-content{padding:.75rem}}@media(min-resolution:192dpi){.main-content{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media(prefers-reduced-motion:reduce){.main-content{transition:none}}.main-content>*{max-width:100%;overflow-wrap:break-word}.main-content::-webkit-scrollbar{width:6px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.main-content::-webkit-scrollbar-thumb:hover{background:#0000004d}@media(max-width:768px){.main-content::-webkit-scrollbar{display:none}.main-content{scrollbar-width:none;-ms-overflow-style:none}}@media(min-width:769px){.app-content{flex-direction:row!important}.sidebar{order:0!important}.main-content{order:1!important}}@media(min-width:769px)and (max-width:1200px){.app-content{flex-direction:row}.sidebar{position:relative;left:0;right:auto}}.app{min-height:100vh}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard{padding:40px;max-width:1200px;margin:0 auto}.dashboard-header{text-align:center;margin-bottom:40px}.dashboard-header h1{color:#2c3e50;font-size:32px;margin-bottom:20px}.user-info{background:#f8f9fa;padding:20px;border-radius:8px;text-align:left;max-width:400px;margin:20px auto}.user-info p{margin:8px 0;color:#2c3e50}.user-info ul{margin:8px 0;padding-left:20px}.user-info li{color:#667eea;margin:4px 0}.logout-button{margin-top:20px}
