/* profile-foundation.css: consolidated legacy shared stack for control-center/resource-hub */
/* Generated on 2026-02-26 from tailwind.generated.css + custom.css + page-style-extracted.css */

*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(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:rgba(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: }/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{color:inherit;font-family:inherit;font-feature-settings:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color: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,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{color:#9ca3af;opacity:1}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.\!container{width:100%!important}.container{width:100%}@media (min-width:640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width:768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width:1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width:1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width:1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.sr-only{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border-width:0;white-space:nowrap}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.-bottom-1{bottom:-.25rem}.-bottom-10{bottom:-2.5rem}.-bottom-16{bottom:-4rem}.-bottom-6{bottom:-1.5rem}.-bottom-7{bottom:-1.75rem}.-bottom-8{bottom:-2rem}.-left-10{left:-2.5rem}.-left-8{left:-2rem}.-right-1{right:-.25rem}.-right-1\.5{right:-.375rem}.-right-12{right:-3rem}.-right-8{right:-2rem}.-top-1{top:-.25rem}.-top-1\.5{top:-.375rem}.-top-10{top:-2.5rem}.-top-12{top:-3rem}.-top-3{top:-.75rem}.-top-8{top:-2rem}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.left-10{left:2.5rem}.left-12{left:3rem}.left-4{left:1rem}.right-0{right:0}.right-2{right:.5rem}.right-4{right:1rem}.right-6{right:1.5rem}.top-0{top:0}.top-10{top:2.5rem}.top-2{top:.5rem}.top-24{top:6rem}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.order-1{order:1}.order-2{order:2}.order-3{order:3}.col-span-1{grid-column:span 1/span 1}.col-span-2{grid-column:span 2/span 2}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-1\.5{margin-left:.375rem;margin-right:.375rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-bottom:.25rem;margin-top:.25rem}.my-4{margin-bottom:1rem;margin-top:1rem}.my-auto{margin-bottom:auto;margin-top:auto}.-ml-1{margin-left:-.25rem}.-mr-1{margin-right:-.25rem}.-mt-14{margin-top:-3.5rem}.-mt-16{margin-top:-4rem}.-mt-8{margin-top:-2rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-1\.5{margin-bottom:.375rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-1\.5{margin-right:.375rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.line-clamp-2{display:-webkit-box;overflow:hidden;-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}.contents{display:contents}.hidden{display:none}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-20{height:5rem}.h-24{height:6rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-32{height:8rem}.h-36{height:9rem}.h-4{height:1rem}.h-40{height:10rem}.h-44{height:11rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-52{height:13rem}.h-56{height:14rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1\.1rem\]{height:1.1rem}.h-\[500px\]{height:500px}.h-fit{height:-moz-fit-content;height:fit-content}.h-full{height:100%}.h-screen{height:100vh}.max-h-40{max-height:10rem}.max-h-64{max-height:16rem}.max-h-72{max-height:18rem}.max-h-\[200px\]{max-height:200px}.max-h-\[42rem\]{max-height:42rem}.max-h-\[62vh\]{max-height:62vh}.max-h-\[70vh\]{max-height:70vh}.max-h-\[78vh\]{max-height:78vh}.min-h-\[3\.5rem\]{min-height:3.5rem}.min-h-\[320px\]{min-height:320px}.min-h-\[420px\]{min-height:420px}.min-h-\[520px\]{min-height:520px}.min-h-\[560px\]{min-height:560px}.min-h-\[600px\]{min-height:600px}.min-h-\[72vh\]{min-height:72vh}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-11\/12{width:91.666667%}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-20{width:5rem}.w-24{width:6rem}.w-28{width:7rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-36{width:9rem}.w-4{width:1rem}.w-40{width:10rem}.w-44{width:11rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-52{width:13rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-72{width:18rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-fit{width:-moz-fit-content;width:fit-content}.w-full{width:100%}.min-w-0{min-width:0}.min-w-\[1\.1rem\]{min-width:1.1rem}.min-w-\[20px\]{min-width:20px}.min-w-\[280px\]{min-width:280px}.min-w-\[300px\]{min-width:300px}.min-w-\[720px\]{min-width:720px}.min-w-\[760px\]{min-width:760px}.min-w-full{min-width:100%}.min-w-max{min-width:-moz-max-content;min-width:max-content}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[130px\]{max-width:130px}.max-w-\[140px\]{max-width:140px}.max-w-\[160px\]{max-width:160px}.max-w-\[180px\]{max-width:180px}.max-w-\[75\%\]{max-width:75%}.max-w-\[85\%\]{max-width:85%}.max-w-\[86\%\]{max-width:86%}.max-w-\[9rem\]{max-width:9rem}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.flex-grow,.grow{flex-grow:1}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.translate-y-0{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-0{--tw-translate-y:0px}.translate-y-2{--tw-translate-y:0.5rem}.rotate-90,.translate-y-2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-90{--tw-rotate:90deg}.scale-100{--tw-scale-x:1;--tw-scale-y:1}.scale-100,.scale-110{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes ping{75%,to{opacity:0;transform:scale(2)}}.animate-ping{animation:ping 1s cubic-bezier(0,0,.2,1) infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-none{resize:none}.resize{resize:both}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.list-none{list-style-type:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-start{justify-content:flex-start}.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-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-y-1{row-gap:.25rem}.gap-y-2{row-gap:.5rem}.-space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(-.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(-.5rem*var(--tw-space-x-reverse))}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-1\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.375rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.375rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.75rem*var(--tw-space-x-reverse))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.125rem*var(--tw-space-y-reverse));margin-top:calc(.125rem*(1 - var(--tw-space-y-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.375rem*var(--tw-space-y-reverse));margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-2\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.625rem*var(--tw-space-y-reverse));margin-top:calc(.625rem*(1 - var(--tw-space-y-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.space-y-3\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.875rem*var(--tw-space-y-reverse));margin-top:calc(.875rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.25rem*var(--tw-space-y-reverse));margin-top:calc(1.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-bottom-width:calc(1px*var(--tw-divide-y-reverse));border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(229 231 235/var(--tw-divide-opacity,1))}.divide-slate-100>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(241 245 249/var(--tw-divide-opacity,1))}.divide-slate-200>:not([hidden])~:not([hidden]){--tw-divide-opacity:1;border-color:rgb(226 232 240/var(--tw-divide-opacity,1))}.self-start{align-self:flex-start}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.rounded-b-lg{border-bottom-left-radius:.5rem;border-bottom-right-radius:.5rem}.rounded-l-md{border-bottom-left-radius:.375rem;border-top-left-radius:.375rem}.rounded-r-md{border-bottom-right-radius:.375rem;border-top-right-radius:.375rem}.rounded-t-2xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.rounded-t-xl{border-top-left-radius:.75rem;border-top-right-radius:.75rem}.rounded-bl-lg{border-bottom-left-radius:.5rem}.rounded-br-md{border-bottom-right-radius:.375rem}.rounded-tl-md{border-top-left-radius:.375rem}.rounded-tl-none{border-top-left-radius:0}.rounded-tl-sm{border-top-left-radius:.125rem}.rounded-tr-none{border-top-right-radius:0}.rounded-tr-sm{border-top-right-radius:.125rem}.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-b-4{border-bottom-width:4px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-r-4{border-right-width:4px}.border-t{border-top-width:1px}.border-t-4{border-top-width:4px}.border-dashed{border-style:dashed}.border-amber-100{--tw-border-opacity:1;border-color:rgb(254 243 199/var(--tw-border-opacity,1))}.border-amber-200{--tw-border-opacity:1;border-color:rgb(253 230 138/var(--tw-border-opacity,1))}.border-amber-300{--tw-border-opacity:1;border-color:rgb(252 211 77/var(--tw-border-opacity,1))}.border-amber-300\/70{border-color:rgba(252,211,77,.7)}.border-amber-400{--tw-border-opacity:1;border-color:rgb(251 191 36/var(--tw-border-opacity,1))}.border-amber-500{--tw-border-opacity:1;border-color:rgb(245 158 11/var(--tw-border-opacity,1))}.border-amber-600{--tw-border-opacity:1;border-color:rgb(217 119 6/var(--tw-border-opacity,1))}.border-blue-100{--tw-border-opacity:1;border-color:rgb(219 234 254/var(--tw-border-opacity,1))}.border-blue-200{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.border-blue-300{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.border-blue-400{--tw-border-opacity:1;border-color:rgb(96 165 250/var(--tw-border-opacity,1))}.border-blue-400\/30{border-color:rgba(96,165,250,.3)}.border-blue-500{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.border-blue-600{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity,1))}.border-emerald-100{--tw-border-opacity:1;border-color:rgb(209 250 229/var(--tw-border-opacity,1))}.border-emerald-200{--tw-border-opacity:1;border-color:rgb(167 243 208/var(--tw-border-opacity,1))}.border-emerald-300{--tw-border-opacity:1;border-color:rgb(110 231 183/var(--tw-border-opacity,1))}.border-emerald-500{--tw-border-opacity:1;border-color:rgb(16 185 129/var(--tw-border-opacity,1))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity,1))}.border-indigo-100{--tw-border-opacity:1;border-color:rgb(224 231 255/var(--tw-border-opacity,1))}.border-indigo-200{--tw-border-opacity:1;border-color:rgb(199 210 254/var(--tw-border-opacity,1))}.border-indigo-300{--tw-border-opacity:1;border-color:rgb(165 180 252/var(--tw-border-opacity,1))}.border-indigo-400{--tw-border-opacity:1;border-color:rgb(129 140 248/var(--tw-border-opacity,1))}.border-indigo-500{--tw-border-opacity:1;border-color:rgb(99 102 241/var(--tw-border-opacity,1))}.border-red-100{--tw-border-opacity:1;border-color:rgb(254 226 226/var(--tw-border-opacity,1))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity,1))}.border-red-300{--tw-border-opacity:1;border-color:rgb(252 165 165/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-slate-100{--tw-border-opacity:1;border-color:rgb(241 245 249/var(--tw-border-opacity,1))}.border-slate-200{--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1))}.border-slate-300{--tw-border-opacity:1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.border-slate-500{--tw-border-opacity:1;border-color:rgb(100 116 139/var(--tw-border-opacity,1))}.border-transparent{border-color:transparent}.border-white{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity,1))}.border-white\/15{border-color:hsla(0,0%,100%,.15)}.border-white\/20{border-color:hsla(0,0%,100%,.2)}.border-white\/25{border-color:hsla(0,0%,100%,.25)}.border-white\/30{border-color:hsla(0,0%,100%,.3)}.bg-amber-100{--tw-bg-opacity:1;background-color:rgb(254 243 199/var(--tw-bg-opacity,1))}.bg-amber-400{--tw-bg-opacity:1;background-color:rgb(251 191 36/var(--tw-bg-opacity,1))}.bg-amber-400\/20{background-color:rgba(251,191,36,.2)}.bg-amber-50{--tw-bg-opacity:1;background-color:rgb(255 251 235/var(--tw-bg-opacity,1))}.bg-amber-50\/70{background-color:rgba(255,251,235,.7)}.bg-amber-50\/80{background-color:rgba(255,251,235,.8)}.bg-amber-500{--tw-bg-opacity:1;background-color:rgb(245 158 11/var(--tw-bg-opacity,1))}.bg-amber-500\/30{background-color:rgba(245,158,11,.3)}.bg-amber-600{--tw-bg-opacity:1;background-color:rgb(217 119 6/var(--tw-bg-opacity,1))}.bg-blue-100{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(191 219 254/var(--tw-bg-opacity,1))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.bg-blue-50\/50{background-color:rgba(239,246,255,.5)}.bg-blue-50\/70{background-color:rgba(239,246,255,.7)}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity,1))}.bg-blue-500\/20{background-color:rgba(59,130,246,.2)}.bg-blue-500\/30{background-color:rgba(59,130,246,.3)}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.bg-blue-700{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.bg-emerald-100{--tw-bg-opacity:1;background-color:rgb(209 250 229/var(--tw-bg-opacity,1))}.bg-emerald-200{--tw-bg-opacity:1;background-color:rgb(167 243 208/var(--tw-bg-opacity,1))}.bg-emerald-300{--tw-bg-opacity:1;background-color:rgb(110 231 183/var(--tw-bg-opacity,1))}.bg-emerald-400{--tw-bg-opacity:1;background-color:rgb(52 211 153/var(--tw-bg-opacity,1))}.bg-emerald-50{--tw-bg-opacity:1;background-color:rgb(236 253 245/var(--tw-bg-opacity,1))}.bg-emerald-50\/70{background-color:rgba(236,253,245,.7)}.bg-emerald-500{--tw-bg-opacity:1;background-color:rgb(16 185 129/var(--tw-bg-opacity,1))}.bg-emerald-500\/20{background-color:rgba(16,185,129,.2)}.bg-emerald-500\/25{background-color:rgba(16,185,129,.25)}.bg-emerald-500\/30{background-color:rgba(16,185,129,.3)}.bg-emerald-600{--tw-bg-opacity:1;background-color:rgb(5 150 105/var(--tw-bg-opacity,1))}.bg-emerald-700{--tw-bg-opacity:1;background-color:rgb(4 120 87/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-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity,1))}.bg-green-400{--tw-bg-opacity:1;background-color:rgb(74 222 128/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-indigo-100{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity,1))}.bg-indigo-200{--tw-bg-opacity:1;background-color:rgb(199 210 254/var(--tw-bg-opacity,1))}.bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity,1))}.bg-indigo-50\/60{background-color:rgba(238,242,255,.6)}.bg-indigo-500\/30{background-color:rgba(99,102,241,.3)}.bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229/var(--tw-bg-opacity,1))}.bg-orange-100{--tw-bg-opacity:1;background-color:rgb(255 237 213/var(--tw-bg-opacity,1))}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.bg-red-50\/70{background-color:hsla(0,86%,97%,.7)}.bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-red-500\/30{background-color:rgba(239,68,68,.3)}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-red-700{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.bg-slate-100{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.bg-slate-200{--tw-bg-opacity:1;background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.bg-slate-300{--tw-bg-opacity:1;background-color:rgb(203 213 225/var(--tw-bg-opacity,1))}.bg-slate-400{--tw-bg-opacity:1;background-color:rgb(148 163 184/var(--tw-bg-opacity,1))}.bg-slate-50{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.bg-slate-50\/60{background-color:rgba(248,250,252,.6)}.bg-slate-50\/70{background-color:rgba(248,250,252,.7)}.bg-slate-50\/80{background-color:rgba(248,250,252,.8)}.bg-slate-50\/90{background-color:rgba(248,250,252,.9)}.bg-slate-800{--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.bg-slate-900{--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1))}.bg-slate-900\/40{background-color:rgba(15,23,42,.4)}.bg-slate-900\/60{background-color:rgba(15,23,42,.6)}.bg-slate-950{--tw-bg-opacity:1;background-color:rgb(2 6 23/var(--tw-bg-opacity,1))}.bg-slate-950\/70{background-color:rgba(2,6,23,.7)}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/10{background-color:hsla(0,0%,100%,.1)}.bg-white\/15{background-color:hsla(0,0%,100%,.15)}.bg-white\/20{background-color:hsla(0,0%,100%,.2)}.bg-white\/5{background-color:hsla(0,0%,100%,.05)}.bg-white\/70{background-color:hsla(0,0%,100%,.7)}.bg-white\/80{background-color:hsla(0,0%,100%,.8)}.bg-white\/90{background-color:hsla(0,0%,100%,.9)}.bg-white\/95{background-color:hsla(0,0%,100%,.95)}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.bg-gradient-to-tr{background-image:linear-gradient(to top right,var(--tw-gradient-stops))}.from-amber-100{--tw-gradient-from:#fef3c7 var(--tw-gradient-from-position);--tw-gradient-to:hsla(48,96%,89%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-300{--tw-gradient-from:#fcd34d var(--tw-gradient-from-position);--tw-gradient-to:rgba(252,211,77,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-50{--tw-gradient-from:#fffbeb var(--tw-gradient-from-position);--tw-gradient-to:rgba(255,251,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-500{--tw-gradient-from:#f59e0b var(--tw-gradient-from-position);--tw-gradient-to:rgba(245,158,11,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-600{--tw-gradient-from:#d97706 var(--tw-gradient-from-position);--tw-gradient-to:rgba(217,119,6,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-amber-700{--tw-gradient-from:#b45309 var(--tw-gradient-from-position);--tw-gradient-to:rgba(180,83,9,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-black\/35{--tw-gradient-from:rgba(0,0,0,.35) var(--tw-gradient-from-position);--tw-gradient-to:transparent var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from:#eff6ff var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,246,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from:#3b82f6 var(--tw-gradient-from-position);--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-700{--tw-gradient-from:#1d4ed8 var(--tw-gradient-from-position);--tw-gradient-to:rgba(29,78,216,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-emerald-50{--tw-gradient-from:#ecfdf5 var(--tw-gradient-from-position);--tw-gradient-to:rgba(236,253,245,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-emerald-500{--tw-gradient-from:#10b981 var(--tw-gradient-from-position);--tw-gradient-to:rgba(16,185,129,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-emerald-700{--tw-gradient-from:#047857 var(--tw-gradient-from-position);--tw-gradient-to:rgba(4,120,87,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-green-400{--tw-gradient-from:#4ade80 var(--tw-gradient-from-position);--tw-gradient-to:rgba(74,222,128,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-50{--tw-gradient-from:#eef2ff var(--tw-gradient-from-position);--tw-gradient-to:rgba(238,242,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-500{--tw-gradient-from:#6366f1 var(--tw-gradient-from-position);--tw-gradient-to:rgba(99,102,241,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-700{--tw-gradient-from:#4338ca var(--tw-gradient-from-position);--tw-gradient-to:rgba(67,56,202,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-900{--tw-gradient-from:#312e81 var(--tw-gradient-from-position);--tw-gradient-to:rgba(49,46,129,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-500{--tw-gradient-from:#ef4444 var(--tw-gradient-from-position);--tw-gradient-to:rgba(239,68,68,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-red-700{--tw-gradient-from:#b91c1c var(--tw-gradient-from-position);--tw-gradient-to:rgba(185,28,28,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-100{--tw-gradient-from:#f1f5f9 var(--tw-gradient-from-position);--tw-gradient-to:rgba(241,245,249,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-50{--tw-gradient-from:#f8fafc var(--tw-gradient-from-position);--tw-gradient-to:rgba(248,250,252,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-500{--tw-gradient-from:#64748b var(--tw-gradient-from-position);--tw-gradient-to:rgba(100,116,139,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-800{--tw-gradient-from:#1e293b var(--tw-gradient-from-position);--tw-gradient-to:rgba(30,41,59,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-900{--tw-gradient-from:#0f172a var(--tw-gradient-from-position);--tw-gradient-to:rgba(15,23,42,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-slate-950{--tw-gradient-from:#020617 var(--tw-gradient-from-position);--tw-gradient-to:rgba(2,6,23,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-white{--tw-gradient-from:#fff var(--tw-gradient-from-position);--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.via-amber-500{--tw-gradient-to:rgba(245,158,11,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#f59e0b var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-amber-600{--tw-gradient-to:rgba(217,119,6,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#d97706 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-blue-50{--tw-gradient-to:rgba(239,246,255,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#eff6ff var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-blue-500{--tw-gradient-to:rgba(59,130,246,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#3b82f6 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-blue-600{--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#2563eb var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-blue-700{--tw-gradient-to:rgba(29,78,216,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1d4ed8 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-blue-900{--tw-gradient-to:rgba(30,58,138,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1e3a8a var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-emerald-600{--tw-gradient-to:rgba(5,150,105,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#059669 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-indigo-500{--tw-gradient-to:rgba(99,102,241,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#6366f1 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-indigo-600{--tw-gradient-to:rgba(79,70,229,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#4f46e5 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-red-600{--tw-gradient-to:rgba(220,38,38,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#dc2626 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-slate-50{--tw-gradient-to:rgba(248,250,252,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#f8fafc var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-slate-700{--tw-gradient-to:rgba(51,65,85,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#334155 var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-slate-800{--tw-gradient-to:rgba(30,41,59,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#1e293b var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-slate-900{--tw-gradient-to:rgba(15,23,42,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#0f172a var(--tw-gradient-via-position),var(--tw-gradient-to)}.via-white{--tw-gradient-to:hsla(0,0%,100%,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),#fff var(--tw-gradient-via-position),var(--tw-gradient-to)}.to-amber-100{--tw-gradient-to:#fef3c7 var(--tw-gradient-to-position)}.to-amber-300{--tw-gradient-to:#fcd34d var(--tw-gradient-to-position)}.to-amber-600{--tw-gradient-to:#d97706 var(--tw-gradient-to-position)}.to-blue-50{--tw-gradient-to:#eff6ff var(--tw-gradient-to-position)}.to-blue-500{--tw-gradient-to:#3b82f6 var(--tw-gradient-to-position)}.to-blue-600{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.to-blue-700{--tw-gradient-to:#1d4ed8 var(--tw-gradient-to-position)}.to-blue-800{--tw-gradient-to:#1e40af var(--tw-gradient-to-position)}.to-emerald-50{--tw-gradient-to:#ecfdf5 var(--tw-gradient-to-position)}.to-emerald-600{--tw-gradient-to:#059669 var(--tw-gradient-to-position)}.to-indigo-100{--tw-gradient-to:#e0e7ff var(--tw-gradient-to-position)}.to-indigo-50{--tw-gradient-to:#eef2ff var(--tw-gradient-to-position)}.to-indigo-500{--tw-gradient-to:#6366f1 var(--tw-gradient-to-position)}.to-indigo-600{--tw-gradient-to:#4f46e5 var(--tw-gradient-to-position)}.to-indigo-700{--tw-gradient-to:#4338ca var(--tw-gradient-to-position)}.to-indigo-800{--tw-gradient-to:#3730a3 var(--tw-gradient-to-position)}.to-indigo-900{--tw-gradient-to:#312e81 var(--tw-gradient-to-position)}.to-purple-500{--tw-gradient-to:#a855f7 var(--tw-gradient-to-position)}.to-red-500{--tw-gradient-to:#ef4444 var(--tw-gradient-to-position)}.to-red-600{--tw-gradient-to:#dc2626 var(--tw-gradient-to-position)}.to-slate-100{--tw-gradient-to:#f1f5f9 var(--tw-gradient-to-position)}.to-slate-200{--tw-gradient-to:#e2e8f0 var(--tw-gradient-to-position)}.to-slate-50{--tw-gradient-to:#f8fafc var(--tw-gradient-to-position)}.to-slate-700{--tw-gradient-to:#334155 var(--tw-gradient-to-position)}.to-slate-900{--tw-gradient-to:#0f172a var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to:transparent var(--tw-gradient-to-position)}.to-white{--tw-gradient-to:#fff var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-10{padding-bottom:2.5rem;padding-top:2.5rem}.py-12{padding-bottom:3rem;padding-top:3rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-2\.5{padding-bottom:.625rem;padding-top:.625rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-3\.5{padding-bottom:.875rem;padding-top:.875rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-5{padding-bottom:1.25rem;padding-top:1.25rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.pb-0\.5{padding-bottom:.125rem}.pb-1{padding-bottom:.25rem}.pb-10{padding-bottom:2.5rem}.pb-12{padding-bottom:3rem}.pb-2{padding-bottom:.5rem}.pb-20{padding-bottom:5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}.pl-10{padding-left:2.5rem}.pl-3{padding-left:.75rem}.pl-5{padding-left:1.25rem}.pl-8{padding-left:2rem}.pr-1{padding-right:.25rem}.pr-10{padding-right:2.5rem}.pr-14{padding-right:3.5rem}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pt-1{padding-top:.25rem}.pt-1\.5{padding-top:.375rem}.pt-10{padding-top:2.5rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.pt-9{padding-top:2.25rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-top{vertical-align:top}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-5{line-height:1.25rem}.leading-\[1\.1rem\]{line-height:1.1rem}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-\[0\.1em\]{letter-spacing:.1em}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.text-amber-100{--tw-text-opacity:1;color:rgb(254 243 199/var(--tw-text-opacity,1))}.text-amber-500{--tw-text-opacity:1;color:rgb(245 158 11/var(--tw-text-opacity,1))}.text-amber-600{--tw-text-opacity:1;color:rgb(217 119 6/var(--tw-text-opacity,1))}.text-amber-700{--tw-text-opacity:1;color:rgb(180 83 9/var(--tw-text-opacity,1))}.text-amber-800{--tw-text-opacity:1;color:rgb(146 64 14/var(--tw-text-opacity,1))}.text-amber-900{--tw-text-opacity:1;color:rgb(120 53 15/var(--tw-text-opacity,1))}.text-blue-100{--tw-text-opacity:1;color:rgb(219 234 254/var(--tw-text-opacity,1))}.text-blue-200{--tw-text-opacity:1;color:rgb(191 219 254/var(--tw-text-opacity,1))}.text-blue-200\/80{color:rgba(191,219,254,.8)}.text-blue-400{--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity,1))}.text-blue-50{--tw-text-opacity:1;color:rgb(239 246 255/var(--tw-text-opacity,1))}.text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity,1))}.text-cyan-300{--tw-text-opacity:1;color:rgb(103 232 249/var(--tw-text-opacity,1))}.text-emerald-100{--tw-text-opacity:1;color:rgb(209 250 229/var(--tw-text-opacity,1))}.text-emerald-300{--tw-text-opacity:1;color:rgb(110 231 183/var(--tw-text-opacity,1))}.text-emerald-400{--tw-text-opacity:1;color:rgb(52 211 153/var(--tw-text-opacity,1))}.text-emerald-500{--tw-text-opacity:1;color:rgb(16 185 129/var(--tw-text-opacity,1))}.text-emerald-600{--tw-text-opacity:1;color:rgb(5 150 105/var(--tw-text-opacity,1))}.text-emerald-700{--tw-text-opacity:1;color:rgb(4 120 87/var(--tw-text-opacity,1))}.text-emerald-800{--tw-text-opacity:1;color:rgb(6 95 70/var(--tw-text-opacity,1))}.text-emerald-900{--tw-text-opacity:1;color:rgb(6 78 59/var(--tw-text-opacity,1))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity,1))}.text-indigo-100{--tw-text-opacity:1;color:rgb(224 231 255/var(--tw-text-opacity,1))}.text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity,1))}.text-indigo-700{--tw-text-opacity:1;color:rgb(67 56 202/var(--tw-text-opacity,1))}.text-indigo-800{--tw-text-opacity:1;color:rgb(55 48 163/var(--tw-text-opacity,1))}.text-indigo-900{--tw-text-opacity:1;color:rgb(49 46 129/var(--tw-text-opacity,1))}.text-orange-500{--tw-text-opacity:1;color:rgb(249 115 22/var(--tw-text-opacity,1))}.text-orange-600{--tw-text-opacity:1;color:rgb(234 88 12/var(--tw-text-opacity,1))}.text-red-100{--tw-text-opacity:1;color:rgb(254 226 226/var(--tw-text-opacity,1))}.text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity,1))}.text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/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-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity,1))}.text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.text-red-900{--tw-text-opacity:1;color:rgb(127 29 29/var(--tw-text-opacity,1))}.text-slate-100{--tw-text-opacity:1;color:rgb(241 245 249/var(--tw-text-opacity,1))}.text-slate-200{--tw-text-opacity:1;color:rgb(226 232 240/var(--tw-text-opacity,1))}.text-slate-300{--tw-text-opacity:1;color:rgb(203 213 225/var(--tw-text-opacity,1))}.text-slate-400{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.text-slate-500{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.text-slate-600{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1))}.text-slate-700{--tw-text-opacity:1;color:rgb(51 65 85/var(--tw-text-opacity,1))}.text-slate-800{--tw-text-opacity:1;color:rgb(30 41 59/var(--tw-text-opacity,1))}.text-slate-900{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.text-transparent{color:transparent}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/90{color:hsla(0,0%,100%,.9)}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.placeholder-slate-400::-moz-placeholder{--tw-placeholder-opacity:1;color:rgb(148 163 184/var(--tw-placeholder-opacity,1))}.placeholder-slate-400::placeholder{--tw-placeholder-opacity:1;color:rgb(148 163 184/var(--tw-placeholder-opacity,1))}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-100{opacity:1}.opacity-25{opacity:.25}.opacity-30{opacity:.3}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-65{opacity:.65}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-80{opacity:.8}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-2xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px rgba(0,0,0,.25);--tw-shadow-colored:0 25px 50px -12px var(--tw-shadow-color)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 rgba(0,0,0,.05);--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color)}.shadow-inner,.shadow-lg{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{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 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-1,.ring-2{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-2{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.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)}.ring-amber-100{--tw-ring-opacity:1;--tw-ring-color:rgb(254 243 199/var(--tw-ring-opacity,1))}.ring-amber-200{--tw-ring-opacity:1;--tw-ring-color:rgb(253 230 138/var(--tw-ring-opacity,1))}.ring-blue-200{--tw-ring-opacity:1;--tw-ring-color:rgb(191 219 254/var(--tw-ring-opacity,1))}.ring-emerald-200{--tw-ring-opacity:1;--tw-ring-color:rgb(167 243 208/var(--tw-ring-opacity,1))}.ring-indigo-200{--tw-ring-opacity:1;--tw-ring-color:rgb(199 210 254/var(--tw-ring-opacity,1))}.ring-red-200{--tw-ring-opacity:1;--tw-ring-color:rgb(254 202 202/var(--tw-ring-opacity,1))}.ring-slate-100{--tw-ring-opacity:1;--tw-ring-color:rgb(241 245 249/var(--tw-ring-opacity,1))}.ring-slate-200{--tw-ring-opacity:1;--tw-ring-color:rgb(226 232 240/var(--tw-ring-opacity,1))}.blur{--tw-blur:blur(8px)}.blur,.blur-3xl{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.blur-3xl{--tw-blur:blur(64px)}.blur-xl{--tw-blur:blur(24px)}.blur-xl,.grayscale{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale:grayscale(100%)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur:blur(8px)}.backdrop-blur,.backdrop-blur-md{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-md{--tw-backdrop-blur:blur(12px)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-shadow{transition-duration:.15s;transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.placeholder\:text-slate-400::-moz-placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.placeholder\:text-slate-400::placeholder{--tw-text-opacity:1;color:rgb(148 163 184/var(--tw-text-opacity,1))}.placeholder\:text-slate-500::-moz-placeholder{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.placeholder\:text-slate-500::placeholder{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.last\:border-0:last-child{border-width:0}.last\:border-b-0:last-child{border-bottom-width:0}.hover\:-translate-y-0\.5:hover{--tw-translate-y:-0.125rem}.hover\:-translate-y-0\.5:hover,.hover\:-translate-y-2:hover{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:-translate-y-2:hover{--tw-translate-y:-0.5rem}.hover\:-translate-y-3:hover{--tw-translate-y:-0.75rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-amber-300:hover{--tw-border-opacity:1;border-color:rgb(252 211 77/var(--tw-border-opacity,1))}.hover\:border-blue-200:hover{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity,1))}.hover\:border-blue-300:hover{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.hover\:border-emerald-300:hover{--tw-border-opacity:1;border-color:rgb(110 231 183/var(--tw-border-opacity,1))}.hover\:border-indigo-300:hover{--tw-border-opacity:1;border-color:rgb(165 180 252/var(--tw-border-opacity,1))}.hover\:border-slate-200:hover{--tw-border-opacity:1;border-color:rgb(226 232 240/var(--tw-border-opacity,1))}.hover\:border-slate-300:hover{--tw-border-opacity:1;border-color:rgb(203 213 225/var(--tw-border-opacity,1))}.hover\:border-slate-400:hover{--tw-border-opacity:1;border-color:rgb(148 163 184/var(--tw-border-opacity,1))}.hover\:bg-amber-100:hover{--tw-bg-opacity:1;background-color:rgb(254 243 199/var(--tw-bg-opacity,1))}.hover\:bg-amber-200:hover{--tw-bg-opacity:1;background-color:rgb(253 230 138/var(--tw-bg-opacity,1))}.hover\:bg-amber-500\/40:hover{background-color:rgba(245,158,11,.4)}.hover\:bg-amber-600:hover{--tw-bg-opacity:1;background-color:rgb(217 119 6/var(--tw-bg-opacity,1))}.hover\:bg-amber-700:hover{--tw-bg-opacity:1;background-color:rgb(180 83 9/var(--tw-bg-opacity,1))}.hover\:bg-blue-100:hover{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity,1))}.hover\:bg-blue-200:hover{--tw-bg-opacity:1;background-color:rgb(191 219 254/var(--tw-bg-opacity,1))}.hover\:bg-blue-50:hover{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity,1))}.hover\:bg-blue-50\/30:hover{background-color:rgba(239,246,255,.3)}.hover\:bg-blue-500\/40:hover{background-color:rgba(59,130,246,.4)}.hover\:bg-blue-600:hover{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity,1))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity,1))}.hover\:bg-blue-800:hover{--tw-bg-opacity:1;background-color:rgb(30 64 175/var(--tw-bg-opacity,1))}.hover\:bg-emerald-100:hover{--tw-bg-opacity:1;background-color:rgb(209 250 229/var(--tw-bg-opacity,1))}.hover\:bg-emerald-200:hover{--tw-bg-opacity:1;background-color:rgb(167 243 208/var(--tw-bg-opacity,1))}.hover\:bg-emerald-50:hover{--tw-bg-opacity:1;background-color:rgb(236 253 245/var(--tw-bg-opacity,1))}.hover\:bg-emerald-500\/40:hover{background-color:rgba(16,185,129,.4)}.hover\:bg-emerald-700:hover{--tw-bg-opacity:1;background-color:rgb(4 120 87/var(--tw-bg-opacity,1))}.hover\:bg-emerald-800:hover{--tw-bg-opacity:1;background-color:rgb(6 95 70/var(--tw-bg-opacity,1))}.hover\:bg-indigo-100:hover{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity,1))}.hover\:bg-indigo-200:hover{--tw-bg-opacity:1;background-color:rgb(199 210 254/var(--tw-bg-opacity,1))}.hover\:bg-indigo-50:hover{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity,1))}.hover\:bg-indigo-500\/40:hover{background-color:rgba(99,102,241,.4)}.hover\:bg-indigo-700:hover{--tw-bg-opacity:1;background-color:rgb(67 56 202/var(--tw-bg-opacity,1))}.hover\:bg-red-100:hover{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity,1))}.hover\:bg-red-200:hover{--tw-bg-opacity:1;background-color:rgb(254 202 202/var(--tw-bg-opacity,1))}.hover\:bg-red-50:hover{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity,1))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.hover\:bg-red-800:hover{--tw-bg-opacity:1;background-color:rgb(153 27 27/var(--tw-bg-opacity,1))}.hover\:bg-slate-100:hover{--tw-bg-opacity:1;background-color:rgb(241 245 249/var(--tw-bg-opacity,1))}.hover\:bg-slate-200:hover{--tw-bg-opacity:1;background-color:rgb(226 232 240/var(--tw-bg-opacity,1))}.hover\:bg-slate-300:hover{--tw-bg-opacity:1;background-color:rgb(203 213 225/var(--tw-bg-opacity,1))}.hover\:bg-slate-50:hover{--tw-bg-opacity:1;background-color:rgb(248 250 252/var(--tw-bg-opacity,1))}.hover\:bg-slate-800:hover{--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.hover\:bg-slate-900:hover{--tw-bg-opacity:1;background-color:rgb(15 23 42/var(--tw-bg-opacity,1))}.hover\:bg-white:hover{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.hover\:bg-white\/20:hover{background-color:hsla(0,0%,100%,.2)}.hover\:bg-white\/25:hover{background-color:hsla(0,0%,100%,.25)}.hover\:from-blue-600:hover{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:from-blue-700:hover{--tw-gradient-from:#1d4ed8 var(--tw-gradient-from-position);--tw-gradient-to:rgba(29,78,216,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.hover\:to-indigo-700:hover{--tw-gradient-to:#4338ca var(--tw-gradient-to-position)}.hover\:text-amber-500:hover{--tw-text-opacity:1;color:rgb(245 158 11/var(--tw-text-opacity,1))}.hover\:text-amber-800:hover{--tw-text-opacity:1;color:rgb(146 64 14/var(--tw-text-opacity,1))}.hover\:text-blue-100:hover{--tw-text-opacity:1;color:rgb(219 234 254/var(--tw-text-opacity,1))}.hover\:text-blue-600:hover{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.hover\:text-blue-700:hover{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.hover\:text-blue-900:hover{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity,1))}.hover\:text-emerald-800:hover{--tw-text-opacity:1;color:rgb(6 95 70/var(--tw-text-opacity,1))}.hover\:text-indigo-800:hover{--tw-text-opacity:1;color:rgb(55 48 163/var(--tw-text-opacity,1))}.hover\:text-red-500:hover{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.hover\:text-red-600:hover{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.hover\:text-red-800:hover{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.hover\:text-red-900:hover{--tw-text-opacity:1;color:rgb(127 29 29/var(--tw-text-opacity,1))}.hover\:text-slate-500:hover{--tw-text-opacity:1;color:rgb(100 116 139/var(--tw-text-opacity,1))}.hover\:text-slate-600:hover{--tw-text-opacity:1;color:rgb(71 85 105/var(--tw-text-opacity,1))}.hover\:text-slate-900:hover{--tw-text-opacity:1;color:rgb(15 23 42/var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-90:hover{opacity:.9}.hover\:shadow:hover{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.hover\:shadow-lg:hover,.hover\:shadow:hover{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.hover\:shadow-md:hover,.hover\:shadow-sm:hover{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-sm:hover{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(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)}.focus\:border-amber-400:focus{--tw-border-opacity:1;border-color:rgb(251 191 36/var(--tw-border-opacity,1))}.focus\:border-blue-300:focus{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity,1))}.focus\:border-blue-400:focus{--tw-border-opacity:1;border-color:rgb(96 165 250/var(--tw-border-opacity,1))}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity,1))}.focus\:border-emerald-400:focus{--tw-border-opacity:1;border-color:rgb(52 211 153/var(--tw-border-opacity,1))}.focus\:border-indigo-400:focus{--tw-border-opacity:1;border-color:rgb(129 140 248/var(--tw-border-opacity,1))}.focus\:border-indigo-500:focus{--tw-border-opacity:1;border-color:rgb(99 102 241/var(--tw-border-opacity,1))}.focus\:border-slate-900:focus{--tw-border-opacity:1;border-color:rgb(15 23 42/var(--tw-border-opacity,1))}.focus\:bg-white:focus{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-amber-100:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(254 243 199/var(--tw-ring-opacity,1))}.focus\:ring-amber-300:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(252 211 77/var(--tw-ring-opacity,1))}.focus\:ring-blue-100:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(219 234 254/var(--tw-ring-opacity,1))}.focus\:ring-blue-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(191 219 254/var(--tw-ring-opacity,1))}.focus\:ring-blue-400:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(96 165 250/var(--tw-ring-opacity,1))}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity,1))}.focus\:ring-blue-600:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(37 99 235/var(--tw-ring-opacity,1))}.focus\:ring-emerald-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(167 243 208/var(--tw-ring-opacity,1))}.focus\:ring-indigo-100:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(224 231 255/var(--tw-ring-opacity,1))}.focus\:ring-indigo-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(199 210 254/var(--tw-ring-opacity,1))}.focus\:ring-indigo-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(99 102 241/var(--tw-ring-opacity,1))}.focus\:ring-slate-200:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(226 232 240/var(--tw-ring-opacity,1))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.focus-visible\:ring-4:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(4px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-visible\:ring-blue-200:focus-visible{--tw-ring-opacity:1;--tw-ring-color:rgb(191 219 254/var(--tw-ring-opacity,1))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-70:disabled{opacity:.7}.group:hover .group-hover\:translate-x-1{--tw-translate-x:0.25rem}.group:hover .group-hover\:scale-105,.group:hover .group-hover\:translate-x-1{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:scale-105{--tw-scale-x:1.05;--tw-scale-y:1.05}.group:hover .group-hover\:scale-\[1\.03\]{--tw-scale-x:1.03;--tw-scale-y:1.03;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:from-amber-600{--tw-gradient-from:#d97706 var(--tw-gradient-from-position);--tw-gradient-to:rgba(217,119,6,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-blue-600{--tw-gradient-from:#2563eb var(--tw-gradient-from-position);--tw-gradient-to:rgba(37,99,235,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-emerald-600{--tw-gradient-from:#059669 var(--tw-gradient-from-position);--tw-gradient-to:rgba(5,150,105,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-indigo-600{--tw-gradient-from:#4f46e5 var(--tw-gradient-from-position);--tw-gradient-to:rgba(79,70,229,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:from-red-600{--tw-gradient-from:#dc2626 var(--tw-gradient-from-position);--tw-gradient-to:rgba(220,38,38,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.group:hover .group-hover\:to-amber-700{--tw-gradient-to:#b45309 var(--tw-gradient-to-position)}.group:hover .group-hover\:to-blue-700{--tw-gradient-to:#1d4ed8 var(--tw-gradient-to-position)}.group:hover .group-hover\:to-emerald-700{--tw-gradient-to:#047857 var(--tw-gradient-to-position)}.group:hover .group-hover\:to-indigo-700{--tw-gradient-to:#4338ca var(--tw-gradient-to-position)}.group:hover .group-hover\:to-red-700{--tw-gradient-to:#b91c1c var(--tw-gradient-to-position)}.group:hover .group-hover\:text-amber-600{--tw-text-opacity:1;color:rgb(217 119 6/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-amber-700{--tw-text-opacity:1;color:rgb(180 83 9/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-emerald-600{--tw-text-opacity:1;color:rgb(5 150 105/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-emerald-700{--tw-text-opacity:1;color:rgb(4 120 87/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity,1))}.group:hover .group-hover\:text-indigo-700{--tw-text-opacity:1;color:rgb(67 56 202/var(--tw-text-opacity,1))}.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width:640px){.sm\:top-16{top:4rem}.sm\:col-span-2{grid-column:span 2/span 2}.sm\:col-span-3{grid-column:span 3/span 3}.sm\:-mt-16{margin-top:-4rem}.sm\:mb-3{margin-bottom:.75rem}.sm\:mb-4{margin-bottom:1rem}.sm\:mb-5{margin-bottom:1.25rem}.sm\:mb-6{margin-bottom:1.5rem}.sm\:ml-2{margin-left:.5rem}.sm\:mr-2{margin-right:.5rem}.sm\:mr-3{margin-right:.75rem}.sm\:mt-1{margin-top:.25rem}.sm\:mt-2{margin-top:.5rem}.sm\:mt-6{margin-top:1.5rem}.sm\:mt-8{margin-top:2rem}.sm\:inline-block{display:inline-block}.sm\:inline{display:inline}.sm\:flex{display:flex}.sm\:inline-flex{display:inline-flex}.sm\:hidden{display:none}.sm\:h-10{height:2.5rem}.sm\:h-12{height:3rem}.sm\:h-14{height:3.5rem}.sm\:h-16{height:4rem}.sm\:h-20{height:5rem}.sm\:h-28{height:7rem}.sm\:h-3{height:.75rem}.sm\:h-4{height:1rem}.sm\:h-5{height:1.25rem}.sm\:h-56{height:14rem}.sm\:h-6{height:1.5rem}.sm\:h-8{height:2rem}.sm\:h-9{height:2.25rem}.sm\:h-\[600px\]{height:600px}.sm\:w-10{width:2.5rem}.sm\:w-12{width:3rem}.sm\:w-14{width:3.5rem}.sm\:w-16{width:4rem}.sm\:w-20{width:5rem}.sm\:w-28{width:7rem}.sm\:w-3{width:.75rem}.sm\:w-4{width:1rem}.sm\:w-5{width:1.25rem}.sm\:w-56{width:14rem}.sm\:w-6{width:1.5rem}.sm\:w-8{width:2rem}.sm\:w-80{width:20rem}.sm\:w-9{width:2.25rem}.sm\:w-auto{width:auto}.sm\:max-w-\[180px\]{max-width:180px}.sm\:max-w-\[260px\]{max-width:260px}.sm\:max-w-\[78\%\]{max-width:78%}.sm\:max-w-none{max-width:none}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-start{align-items:flex-start}.sm\:items-end{align-items:flex-end}.sm\:items-center{align-items:center}.sm\:justify-start{justify-content:flex-start}.sm\:justify-end{justify-content:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:gap-2{gap:.5rem}.sm\:gap-3{gap:.75rem}.sm\:gap-4{gap:1rem}.sm\:gap-5{gap:1.25rem}.sm\:gap-6{gap:1.5rem}.sm\:gap-8{gap:2rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.sm\:space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.sm\:space-y-5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.25rem*var(--tw-space-y-reverse));margin-top:calc(1.25rem*(1 - var(--tw-space-y-reverse)))}.sm\:space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.sm\:bg-transparent{background-color:transparent}.sm\:p-10{padding:2.5rem}.sm\:p-3{padding:.75rem}.sm\:p-4{padding:1rem}.sm\:p-5{padding:1.25rem}.sm\:p-6{padding:1.5rem}.sm\:p-8{padding:2rem}.sm\:px-0{padding-left:0;padding-right:0}.sm\:px-3{padding-left:.75rem;padding-right:.75rem}.sm\:px-4{padding-left:1rem;padding-right:1rem}.sm\:px-5{padding-left:1.25rem;padding-right:1.25rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-0{padding-bottom:0;padding-top:0}.sm\:py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.sm\:py-10{padding-bottom:2.5rem;padding-top:2.5rem}.sm\:py-2{padding-bottom:.5rem;padding-top:.5rem}.sm\:py-3{padding-bottom:.75rem;padding-top:.75rem}.sm\:py-4{padding-bottom:1rem;padding-top:1rem}.sm\:py-5{padding-bottom:1.25rem;padding-top:1.25rem}.sm\:py-6{padding-bottom:1.5rem;padding-top:1.5rem}.sm\:py-8{padding-bottom:2rem;padding-top:2rem}.sm\:pb-6{padding-bottom:1.5rem}.sm\:pl-10{padding-left:2.5rem}.sm\:pt-5{padding-top:1.25rem}.sm\:text-left{text-align:left}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}.sm\:text-xs{font-size:.75rem;line-height:1rem}.sm\:hover\:bg-transparent:hover{background-color:transparent}}@media (min-width:768px){.md\:order-1{order:1}.md\:order-2{order:2}.md\:order-3{order:3}.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-12{grid-column:span 12/span 12}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:col-span-4{grid-column:span 4/span 4}.md\:ml-2{margin-left:.5rem}.md\:ml-auto{margin-left:auto}.md\:mt-0{margin-top:0}.md\:mt-8{margin-top:2rem}.md\:block{display:block}.md\:flex{display:flex}.md\:hidden{display:none}.md\:h-\[800px\]{height:800px}.md\:h-\[calc\(100vh-200px\)\]{height:calc(100vh - 200px)}.md\:min-h-\[800px\]{min-height:800px}.md\:w-auto{width:auto}.md\:max-w-none{max-width:none}.md\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-end{align-items:flex-end}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:gap-6{gap:1.5rem}.md\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.md\:space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.75rem*var(--tw-space-x-reverse))}.md\:p-5{padding:1.25rem}.md\:p-6{padding:1.5rem}.md\:p-8{padding:2rem}.md\:px-6{padding-left:1.5rem;padding-right:1.5rem}.md\:py-8{padding-bottom:2rem;padding-top:2rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width:1024px){.lg\:sticky{position:sticky}.lg\:top-24{top:6rem}.lg\:top-4{top:1rem}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:col-span-3{grid-column:span 3/span 3}.lg\:col-span-4{grid-column:span 4/span 4}.lg\:col-span-8{grid-column:span 8/span 8}.lg\:block{display:block}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-\[350px\2c 1fr\]{grid-template-columns:350px 1fr}.lg\:grid-cols-\[minmax\(0\2c 1fr\)_320px\]{grid-template-columns:minmax(0,1fr) 320px}.lg\:flex-row{flex-direction:row}.lg\:items-start{align-items:flex-start}.lg\:items-end{align-items:flex-end}.lg\:items-center{align-items:center}.lg\:justify-end{justify-content:flex-end}.lg\:justify-between{justify-content:space-between}.lg\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.lg\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.lg\:border-b-0{border-bottom-width:0}.lg\:border-l{border-left-width:1px}.lg\:border-r{border-right-width:1px}.lg\:border-t-0{border-top-width:0}.lg\:p-10{padding:2.5rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:py-10{padding-bottom:2.5rem;padding-top:2.5rem}.lg\:text-2xl{font-size:1.5rem;line-height:2rem}.lg\:text-3xl{font-size:1.875rem;line-height:2.25rem}}@media (min-width:1280px){.xl\:sticky{position:sticky}.xl\:top-24{top:6rem}.xl\:col-span-2{grid-column:span 2/span 2}.xl\:col-span-3{grid-column:span 3/span 3}.xl\:col-span-4{grid-column:span 4/span 4}.xl\:col-span-8{grid-column:span 8/span 8}.xl\:col-span-9{grid-column:span 9/span 9}.xl\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.xl\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.xl\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.xl\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.xl\:flex-row{flex-direction:row}.xl\:items-end{align-items:flex-end}.xl\:justify-between{justify-content:space-between}}
/* Custom styles for munotes.in */

/* -----------------------------------------------------------------
   Global Typography System
   A proportional type scale to keep UI readable and consistent
------------------------------------------------------------------ */

:root {
  --app-font-body: "Mulish", "Avenir Next", "Segoe UI", "Helvetica Neue", sans-serif;
  --app-font-display: "Mulish", "Avenir Next", "Segoe UI", "Helvetica Neue", sans-serif;
  --app-surface: #ffffff;
  --app-surface-alt: #f7f9fc;
  --app-border: #e6e9ef;
  --app-text-primary: #0f172a;
  --app-text-muted: #475569;
  --app-brand: #2456f5;
  --app-brand-deep: #1e40af;
  --app-shadow-soft: 0 8px 28px rgba(15, 23, 42, 0.06);
  --app-shadow-focus: 0 12px 36px rgba(37, 99, 235, 0.16);

  --app-text-xs: clamp(0.75rem, 0.72rem + 0.12vw, 0.82rem);
  --app-text-sm: clamp(0.84rem, 0.81rem + 0.16vw, 0.93rem);
  --app-text-base: clamp(0.97rem, 0.93rem + 0.2vw, 1.07rem);
  --app-text-lg: clamp(1.08rem, 1.03rem + 0.24vw, 1.2rem);
  --app-text-xl: clamp(1.2rem, 1.13rem + 0.34vw, 1.38rem);
  --app-text-2xl: clamp(1.36rem, 1.26rem + 0.52vw, 1.64rem);
  --app-text-3xl: clamp(1.58rem, 1.44rem + 0.78vw, 1.98rem);
  --app-text-4xl: clamp(1.84rem, 1.64rem + 1.08vw, 2.44rem);
  --app-text-5xl: clamp(2.12rem, 1.9rem + 1.36vw, 2.9rem);
}

html {
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

body {
  font-family: var(--app-font-body);
  font-weight: 400;
  font-size: var(--app-text-base);
  line-height: 1.58;
  letter-spacing: 0.001em;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--app-font-display);
  letter-spacing: -0.012em;
  line-height: 1.24;
  font-weight: 700;
}

h1 { font-size: var(--app-text-3xl); }
h2 { font-size: var(--app-text-2xl); }
h3 { font-size: var(--app-text-xl); }
h4 { font-size: var(--app-text-lg); }
h5 { font-size: var(--app-text-base); }
h6 { font-size: var(--app-text-sm); }

/* Normalize Tailwind text utilities with a proportional scale */
.text-xs { font-size: var(--app-text-xs); line-height: 1.4; }
.text-sm { font-size: var(--app-text-sm); line-height: 1.48; }
.text-base { font-size: var(--app-text-base); line-height: 1.58; }
.text-lg { font-size: var(--app-text-lg); line-height: 1.5; }
.text-xl { font-size: var(--app-text-xl); line-height: 1.4; }
.text-2xl { font-size: var(--app-text-2xl); line-height: 1.3; }
.text-3xl { font-size: var(--app-text-3xl); line-height: 1.2; }
.text-4xl { font-size: var(--app-text-4xl); line-height: 1.15; }
.text-5xl { font-size: var(--app-text-5xl); line-height: 1.1; }

button,
input,
select,
textarea {
  font: inherit;
}

/* PDF Viewer styles */
#pdf-container {
  border: 1px solid #ddd;
  background-color: #f5f5f5;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  margin-bottom: 20px;
  overflow: auto;
}

#pdf-render {
  background-color: white;
  margin: 0 auto;
  display: block;
}

.pdf-controls {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 15px 0;
  padding: 10px;
  background-color: #f0f9ff;
  border-radius: 8px;
}

.pdf-controls button {
  background-color: #3b82f6;
  color: white;
  border: none;
  border-radius: 4px;
  padding: 8px 15px;
  margin: 0 5px;
  cursor: pointer;
  transition: background-color 0.2s;
}

.pdf-controls button:hover {
  background-color: #2563eb;
}

.pdf-controls button:disabled {
  background-color: #9ca3af;
  cursor: not-allowed;
}

.pdf-controls span {
  margin: 0 10px;
  font-weight: 500;
}

/* New PDF Viewer styles for vertical scrolling */
#pdf-viewer {
  background-color: #f5f5f5;
  overflow: auto;
  position: relative;
  height: 100%;
  max-height: 85vh; /* Limit height on desktop */
}

#pdf-viewer-container {
  display: flex;
  flex-direction: column;
  height: 100%;
  background-color: #f5f5f5;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

#pdf-viewer canvas {
  max-width: 100%; /* Ensure canvas doesn't overflow on mobile */
  height: auto;
  display: block;
  margin: 0 auto; /* Center pages */
  background-color: white;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  border-radius: 4px;
}

/* Improved toolbar styles */
#pdf-viewer-container .toolbar {
  background: linear-gradient(to bottom, #ffffff, #f5f7fa);
  border-bottom: 1px solid #e2e8f0;
  padding: 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  z-index: 10;
}

/* Button hover effects */
#pdf-viewer-container button:active {
  transform: translateY(1px);
}

/* Keep action icons optically centered/symmetric across browsers */
#pdf-viewer-container .toolbar button svg {
  display: block;
  width: 18px;
  height: 18px;
}

#mobile-fullscreen-exit {
  display: none;
}

#mobile-fullscreen-zoom-controls {
  display: none;
}

/* Thumbnail styling */
#pdf-thumbnails {
  border-right: 1px solid #e2e8f0;
  background-color: #f8fafc;
  transition: all 0.3s ease;
  scrollbar-width: thin;
  scrollbar-color: #cbd5e1 #f1f5f9;
}

#pdf-thumbnails::-webkit-scrollbar {
  width: 6px;
}

#pdf-thumbnails::-webkit-scrollbar-track {
  background: #f1f5f9;
}

#pdf-thumbnails::-webkit-scrollbar-thumb {
  background-color: #cbd5e1;
  border-radius: 3px;
}

#pdf-thumbnails .p-2 {
  transition: all 0.2s ease;
}

#pdf-thumbnails .p-2:hover {
  background-color: #e0f2fe;
  transform: translateY(-2px);
}

#pdf-thumbnails .bg-blue-200 {
  background-color: #bfdbfe !important;
  position: relative;
}

#pdf-thumbnails .bg-blue-200::after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 70%;
  background-color: #3b82f6;
  border-radius: 0 2px 2px 0;
}

/* Enhanced Mobile-friendly PDF Viewer Styles */
@media (max-width: 768px) {
  /* Better toolbar for mobile PDF viewer with the new layout */
  #pdf-viewer-container .toolbar {
    padding: 10px;
    gap: 10px;
  }

  /* Make control sections stand out better */
  #pdf-viewer-container .toolbar > div {
    background-color: rgba(237, 242, 247, 0.7);
    border-radius: 8px;
    padding: 8px;
    border: 1px solid rgba(226, 232, 240, 0.8);
  }

  /* Quality and Zoom indicators */
  #pdf-viewer-container .text-xs.font-medium.px-2.py-1.bg-blue-100 {
    min-width: 80px;
    text-align: center;
    font-weight: 500;
  }

  /* Make buttons more tappable */
  #pdf-viewer-container .toolbar button {
    min-width: 40px;
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
  }

  /* Improve button feedback */
  #pdf-viewer-container .toolbar button:active {
    background-color: #cbd5e0;
    transform: scale(0.95);
  }

  /* Allow unlimited zoom on mobile devices */
  #pdf-viewer {
    touch-action: pan-x pan-y;
  }

  /* Style PDF pages for better mobile viewing with high quality */
  #pdf-viewer canvas {
    margin: 10px auto;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  }

  /* Optimize navigation controls for mobile */
  #pdf-viewer-container .flex.items-center.space-x-2 {
    gap: 6px;
  }

  #pdf-viewer-container button {
    padding: 6px;
  }

  #pdf-viewer-container input[type="number"] {
    width: 40px;
    padding: 4px;
    font-size: 14px;
  }

  /* Make page margins smaller on mobile */
  #pdf-viewer .mb-4 {
    margin-bottom: 0.75rem;
  }

  /* Full height for PDF viewer on mobile */
  #pdf-viewer {
    max-height: none;
  }

  /* Improve page controls visibility */
  #pdf-viewer-container .bg-blue-600 {
    background-color: #2563eb;
    padding: 6px 12px;
  }

  /* Make thumbnails wider when active on mobile */
  #pdf-thumbnails.w-48 {
    width: 120px;
  }

  /* Smaller thumbnails on mobile */
  #pdf-thumbnails canvas {
    max-width: 100%;
  }

  /* Fix fullscreen on mobile */
  #pdf-viewer-container:fullscreen,
  #pdf-viewer-container:-webkit-full-screen,
  #pdf-viewer-container:-moz-full-screen {
    width: 100vw;
    width: 100dvw;
    height: 100vh;
    height: 100dvh;
    background-color: white;
    border-radius: 0;
  }

  /* Compact controls in mobile fullscreen so PDF gets maximum visible area */
  #pdf-viewer-container:fullscreen .toolbar,
  #pdf-viewer-container:-webkit-full-screen .toolbar,
  #pdf-viewer-container:-moz-full-screen .toolbar,
  #pdf-viewer-container.pdf-pseudo-fullscreen .toolbar {
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center;
    gap: 6px;
    overflow-x: auto;
    padding: 8px;
  }

  #pdf-viewer-container:fullscreen .toolbar > div,
  #pdf-viewer-container:-webkit-full-screen .toolbar > div,
  #pdf-viewer-container:-moz-full-screen .toolbar > div,
  #pdf-viewer-container.pdf-pseudo-fullscreen .toolbar > div {
    width: auto !important;
    margin-bottom: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background-color: transparent !important;
    flex-shrink: 0;
  }

  #pdf-viewer-container:fullscreen [data-toolbar-group="quality"],
  #pdf-viewer-container:-webkit-full-screen [data-toolbar-group="quality"],
  #pdf-viewer-container:-moz-full-screen [data-toolbar-group="quality"],
  #pdf-viewer-container.pdf-pseudo-fullscreen [data-toolbar-group="quality"],
  #pdf-viewer-container:fullscreen [data-toolbar-group="zoom"],
  #pdf-viewer-container:-webkit-full-screen [data-toolbar-group="zoom"],
  #pdf-viewer-container:-moz-full-screen [data-toolbar-group="zoom"],
  #pdf-viewer-container.pdf-pseudo-fullscreen [data-toolbar-group="zoom"] {
    display: none !important;
  }

  #pdf-viewer-container:fullscreen [data-toolbar-group="view"] button:not(#fullscreen-button),
  #pdf-viewer-container:-webkit-full-screen [data-toolbar-group="view"] button:not(#fullscreen-button),
  #pdf-viewer-container:-moz-full-screen [data-toolbar-group="view"] button:not(#fullscreen-button),
  #pdf-viewer-container.pdf-pseudo-fullscreen [data-toolbar-group="view"] button:not(#fullscreen-button) {
    display: none !important;
  }

  #pdf-viewer-container:fullscreen [data-toolbar-group="nav"],
  #pdf-viewer-container:-webkit-full-screen [data-toolbar-group="nav"],
  #pdf-viewer-container:-moz-full-screen [data-toolbar-group="nav"],
  #pdf-viewer-container.pdf-pseudo-fullscreen [data-toolbar-group="nav"] {
    gap: 4px;
  }

  #pdf-viewer-container:fullscreen .toolbar button,
  #pdf-viewer-container:-webkit-full-screen .toolbar button,
  #pdf-viewer-container:-moz-full-screen .toolbar button,
  #pdf-viewer-container.pdf-pseudo-fullscreen .toolbar button {
    min-width: 34px;
    min-height: 34px;
    padding: 6px;
  }

  /* True immersive mode on mobile fullscreen: hide toolbar, keep only floating exit */
  #pdf-viewer-container.pdf-mobile-immersive .toolbar {
    display: none !important;
  }

  #pdf-viewer-container.pdf-mobile-immersive > .flex.flex-1.overflow-hidden {
    min-height: 100%;
  }

  #pdf-viewer-container.pdf-mobile-immersive .flex-1.overflow-auto {
    padding-top: 0.75rem;
  }

  #pdf-viewer-container.pdf-mobile-immersive #mobile-fullscreen-exit {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: max(10px, env(safe-area-inset-top));
    right: max(10px, env(safe-area-inset-right));
    width: 42px;
    height: 42px;
    border-radius: 9999px;
    border: 1px solid rgba(255, 255, 255, 0.4);
    background: rgba(15, 23, 42, 0.78);
    color: #ffffff;
    z-index: 80;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
  }

  #pdf-viewer-container.pdf-mobile-immersive #mobile-fullscreen-exit svg {
    width: 18px;
    height: 18px;
  }

  #pdf-viewer-container.pdf-mobile-immersive #mobile-fullscreen-zoom-controls {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    position: absolute;
    left: 50%;
    bottom: max(12px, calc(env(safe-area-inset-bottom) + 6px));
    transform: translateX(-50%);
    padding: 6px;
    border-radius: 9999px;
    border: 1px solid rgba(255, 255, 255, 0.35);
    background: rgba(15, 23, 42, 0.82);
    color: #ffffff;
    z-index: 80;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.32);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }

  #pdf-viewer-container.pdf-mobile-immersive #mobile-fullscreen-zoom-controls .mobile-zoom-button {
    min-width: 40px;
    min-height: 40px;
    padding: 0 10px;
    border: 0;
    border-radius: 9999px;
    background: #ffffff;
    color: #0f172a;
    font-size: 0.95rem;
    font-weight: 800;
    line-height: 1;
  }

  #pdf-viewer-container.pdf-mobile-immersive #mobile-fullscreen-zoom-controls .mobile-zoom-button:active {
    transform: scale(0.95);
    background: #e2e8f0;
  }

  #pdf-viewer-container.pdf-mobile-immersive #mobile-fullscreen-zoom-controls .mobile-zoom-level {
    min-width: 56px;
    text-align: center;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.01em;
  }

  /* Add touch-friendly tap areas */
  #pdf-viewer-container button,
  #pdf-thumbnails .p-2 {
    min-height: 36px;
    min-width: 36px;
  }

  /* Recent uploads card styling */
  .md\:hidden.space-y-4 .border.rounded-lg {
    transition: transform 0.2s, box-shadow 0.2s;
  }

  .md\:hidden.space-y-4 .border.rounded-lg:active {
    transform: scale(0.98);
  }

  /* Make titles more readable on mobile */
  .md\:hidden.space-y-4 h3.font-medium {
    line-height: 1.4;
    word-break: break-word;
  }

  /* Improve spacing in mobile cards */
  .md\:hidden.space-y-4 .p-4 {
    padding: 1rem;
  }

  /* Ensure view button is easy to tap */
  .md\:hidden.space-y-4 .bg-blue-600 {
    padding: 0.5rem 1rem;
    min-height: 44px;
  }

  /* Improve uploader info layout */
  .md\:hidden.space-y-4 .flex.items-start {
    align-items: flex-start;
  }

  /* Add a subtle divider between info sections */
  .md\:hidden.space-y-4 .flex.flex-col.space-y-2 > div:not(:last-child) {
    padding-bottom: 0.5rem;
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  }

  /* Make list items more tappable */
  .divide-y.divide-gray-200 li a {
    padding: 1rem 0.75rem;
    min-height: 4.5rem;
  }

  /* Add a tap effect */
  .divide-y.divide-gray-200 li:active {
    background-color: rgba(59, 130, 246, 0.1);
  }

  /* Give the View button more prominence */
  .divide-y.divide-gray-200 .bg-blue-100 {
    padding: 0.375rem 0.75rem;
    font-weight: 500;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  }

  /* Improve spacing for long titles */
  .divide-y.divide-gray-200 h3.font-medium {
    line-height: 1.4;
    max-width: 80%;
  }

  /* Make sure icon is properly aligned */
  .divide-y.divide-gray-200 .w-9.h-9 {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  /* Ensure the title doesn't overflow and push the View button off screen */
  .divide-y.divide-gray-200 .flex-1.min-w-0 {
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Improve breadcrumb navigation */
  .breadcrumb-item {
    white-space: nowrap;
  }

  /* Better spacing for question paper titles */
  .divide-y.divide-gray-200 .text-blue-800 {
    line-height: 1.4;
  }

  /* Ensure directory items are sized well */
  #content-grid .card-item {
    display: flex;
    align-items: center;
    min-height: 4rem;
    transition: background-color 0.2s;
  }

  /* Make directory items more tappable */
  #content-grid .card-item .flex {
    width: 100%;
  }

  #content-grid .card-item:active {
    background-color: rgba(59, 130, 246, 0.1);
  }

  /* Proper text wrapping for long directory names */
  .card-title {
    overflow-wrap: break-word;
    word-wrap: break-word;
    hyphens: auto;
    line-height: 1.4;
  }

  /* Make title more readable on small screens */
  .text-xl.font-bold.text-blue-700 {
    line-height: 1.4;
    word-break: break-word;
  }

  /* Improved PDF viewer container on mobile */
  #pdf-viewer {
    border-radius: 8px;
    overflow: hidden;
  }

  /* Make page navigation more touch-friendly */
  #pdf-viewer-container input[type="number"] {
    min-height: 36px;
    font-size: 14px;
    width: 45px;
    text-align: center;
  }

  /* Make the login popup more mobile-friendly */
  #loginPopup .bg-white {
    max-width: 92%;
    padding: 16px;
    margin: 0 16px;
  }

  /* Ensure tags are properly spaced and sized for touch */
  .inline-flex.items-center.px-3.py-1.rounded-md {
    margin-bottom: 4px;
    min-height: 32px;
  }

  /* Better Google Drive preview on mobile */
  #drive-viewer .inline-flex.items-center {
    width: 100%;
    justify-content: center;
    padding: 12px 16px;
  }
}

/* Fullscreen mode optimizations */
#pdf-viewer-container:fullscreen,
#pdf-viewer-container:-webkit-full-screen,
#pdf-viewer-container:-moz-full-screen,
#pdf-viewer-container:-ms-fullscreen {
  position: fixed;
  inset: 0;
  width: 100vw;
  width: 100dvw;
  height: 100vh;
  height: 100dvh;
  max-width: none;
  max-height: none;
  background-color: white;
  margin: 0;
  padding: 0;
  border-radius: 0;
}

#pdf-viewer-container:fullscreen .toolbar,
#pdf-viewer-container:-webkit-full-screen .toolbar,
#pdf-viewer-container:-moz-full-screen .toolbar,
#pdf-viewer-container:-ms-fullscreen .toolbar {
  padding-top: max(10px, env(safe-area-inset-top));
  padding-left: max(10px, env(safe-area-inset-left));
  padding-right: max(10px, env(safe-area-inset-right));
}

#pdf-viewer-container:fullscreen > .flex.flex-1.overflow-hidden,
#pdf-viewer-container:-webkit-full-screen > .flex.flex-1.overflow-hidden,
#pdf-viewer-container:-moz-full-screen > .flex.flex-1.overflow-hidden,
#pdf-viewer-container:-ms-fullscreen > .flex.flex-1.overflow-hidden {
  min-height: 0;
}

#pdf-viewer-container:fullscreen .flex-1.overflow-auto,
#pdf-viewer-container:-webkit-full-screen .flex-1.overflow-auto,
#pdf-viewer-container:-moz-full-screen .flex-1.overflow-auto,
#pdf-viewer-container:-ms-fullscreen .flex-1.overflow-auto {
  min-height: 0;
  overscroll-behavior: contain;
  padding-bottom: calc(1rem + env(safe-area-inset-bottom));
}

/* Loading animation improvements */
#pdf-viewer .flex-col.items-center.justify-center.p-10 {
  padding: 2rem;
  background-color: rgba(255, 255, 255, 0.9);
  border-radius: 1rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

/* General custom styles */
.content-header {
  background-color: #f0f9ff;
  border-left: 4px solid #3b82f6;
  padding: 20px;
  margin-bottom: 20px;
  border-radius: 8px;
}

.breadcrumb-item {
  display: inline-flex;
  align-items: center;
}

.document-card {
  transition: transform 0.2s, box-shadow 0.2s;
}

.document-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 15px rgba(0, 0, 0, 0.1);
}

/* Support for unlimited zooming */
@supports (touch-action: pinch-zoom) {
  #pdf-viewer {
    touch-action: pinch-zoom;
  }
}

/* Line-clamp utilities for text truncation */
.line-clamp-1 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.line-clamp-2 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

.line-clamp-3 {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

/* Shared shell overflow guardrail for visual regression stability */
body.ui-v2 .mn-page-root,
body.ui-v2 .mn-page-shell {
  max-width: 100%;
  overflow-x: clip;
}

/* Committee control center should feel like a full platform surface, not a narrow card */
body.ui-v2 .mn-page-root-fluid {
  max-width: none;
}

body.ui-v2 .committee-control-shell {
  max-width: min(108rem, 100%);
  font-size: clamp(1rem, 0.95rem + 0.14vw, 1.08rem);
}

body.ui-v2 .committee-control-shell .committee-alert-menu-panel {
  width: min(22rem, calc(100vw - 1.5rem));
}

body.ui-v2 .committee-control-shell .committee-start-progress-fill {
  width: 0;
}

/* Clamp decorative blur ornaments that use negative offsets */
body.ui-v2 .pointer-events-none.absolute.blur-3xl[class*="-bottom-10"][class*="-right-8"],
body.ui-v2 .pointer-events-none.absolute.blur-3xl[class*="-bottom-10"][class*="-right-10"] {
  right: 0 !important;
}

body.ui-v2 .pointer-events-none.absolute.blur-3xl[class*="-top-8"][class*="-left-8"] {
  left: 0 !important;
}

/* Defensive reset when ui-btn is mistakenly applied to non-button containers */
body.ui-v2 article.ui-btn,
body.ui-v2 section.ui-btn,
body.ui-v2 aside.ui-btn,
body.ui-v2 div.ui-btn {
  display: block;
  min-height: 0;
}

@supports not (overflow: clip) {
  body.ui-v2 .mn-page-root,
  body.ui-v2 .mn-page-shell {
    overflow-x: hidden;
  }
}

/* -----------------------------------------------------------------
   UI V2 Design System (Centralized)
   Automatically upgrades common page patterns without per-page edits
------------------------------------------------------------------ */
body.ui-v2 {
  --ui-v2-surface: #ffffff;
  --ui-v2-surface-soft: #f8fafc;
  --ui-v2-border: #cbd5e1;
  --ui-v2-text: #0f172a;
  --ui-v2-text-muted: #475569;
  --ui-v2-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
  --ui-v2-shadow-hover: 0 16px 32px rgba(15, 23, 42, 0.12);
}

/* Standard card treatment for existing Tailwind class combinations */
body.ui-v2 .main-content .bg-white.rounded-lg.shadow-sm,
body.ui-v2 .main-content .bg-white.rounded-xl.shadow-sm,
body.ui-v2 .main-content .bg-white.rounded-2xl.shadow-sm,
body.ui-v2 .main-content .bg-white.rounded-lg.shadow-md,
body.ui-v2 .main-content .bg-white.rounded-xl.shadow-md,
body.ui-v2 .main-content .bg-white.rounded-2xl.shadow-md {
  border: 1px solid var(--ui-v2-border);
  box-shadow: var(--ui-v2-shadow);
  border-radius: 1rem;
}

/* Generic bordered white cards (resource cards, list items, event cards) */
body.ui-v2 .main-content a.bg-white.border,
body.ui-v2 .main-content div.bg-white.border.rounded-lg,
body.ui-v2 .main-content div.bg-white.border.rounded-xl {
  border-color: var(--ui-v2-border) !important;
  border-radius: 0.75rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

body.ui-v2 .main-content a.bg-white.border:hover,
body.ui-v2 .main-content div.bg-white.border.rounded-lg:hover,
body.ui-v2 .main-content div.bg-white.border.rounded-xl:hover {
  transform: translateY(-2px);
  box-shadow: var(--ui-v2-shadow-hover);
}

/* Promote section headings that still use legacy blue heading utilities */
body.ui-v2 .main-content h2.text-blue-800,
body.ui-v2 .main-content h3.text-blue-800 {
  color: var(--ui-v2-text) !important;
}

/* Default text harmonization for older utility usage */
body.ui-v2 .main-content .text-gray-900 { color: var(--ui-v2-text) !important; }
body.ui-v2 .main-content .text-gray-700,
body.ui-v2 .main-content .text-gray-600,
body.ui-v2 .main-content .text-gray-500 { color: var(--ui-v2-text-muted) !important; }

/* Forms: unified look without touching PDF controls */
body.ui-v2 .main-content form input[type="text"],
body.ui-v2 .main-content form input[type="email"],
body.ui-v2 .main-content form input[type="number"],
body.ui-v2 .main-content form input[type="password"],
body.ui-v2 .main-content form select,
body.ui-v2 .main-content form textarea {
  border-radius: 0.75rem;
  border-color: var(--ui-v2-border);
  background: #fff;
}

body.ui-v2 .main-content form input:focus,
body.ui-v2 .main-content form select:focus,
body.ui-v2 .main-content form textarea:focus {
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

/* Buttons and button-like links */
body.ui-v2 .main-content button.bg-blue-600,
body.ui-v2 .main-content a.bg-blue-600,
body.ui-v2 .main-content button[class*="from-blue-"][class*="to-indigo-"],
body.ui-v2 .main-content a[class*="from-blue-"][class*="to-indigo-"] {
  border-radius: 0.75rem;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.25);
}

body.ui-v2 .main-content button.bg-blue-600:hover,
body.ui-v2 .main-content a.bg-blue-600:hover,
body.ui-v2 .main-content button[class*="from-blue-"][class*="to-indigo-"]:hover,
body.ui-v2 .main-content a[class*="from-blue-"][class*="to-indigo-"]:hover {
  transform: translateY(-1px);
}

/* Legacy utility block used on many pages */
body.ui-v2 .content-header {
  background: linear-gradient(135deg, #eff6ff, #eef2ff);
  border: 1px solid #dbeafe;
  border-left: 4px solid #3b82f6;
  border-radius: 1rem;
  box-shadow: var(--ui-v2-shadow);
}

/* Reusable classes for new pages */
body.ui-v2 .ui-card:not([class*="bg-"]) {
  background: #fff;
  border: 1px solid var(--ui-v2-border);
  border-radius: 1rem;
  box-shadow: var(--ui-v2-shadow);
}

body.ui-v2 .ui-card-soft {
  background: var(--ui-v2-surface-soft);
  border: 1px solid var(--ui-v2-border);
  border-radius: 1rem;
}

body.ui-v2 .ui-btn-primary {
  background: linear-gradient(135deg, #2563eb, #1d4ed8);
  color: #fff;
  border-radius: 0.75rem;
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.25);
}

body.ui-v2 .ui-btn-primary:hover {
  transform: translateY(-1px);
}

body.ui-v2 .ui-btn-secondary {
  background: #fff;
  border: 1px solid #bfdbfe;
  color: #1d4ed8;
  border-radius: 0.75rem;
}

body.ui-v2 .ui-input {
  border-radius: 0.75rem;
  border: 1px solid var(--ui-v2-border);
  background: #fff;
}

/* -----------------------------------------------------------------
   Shared Topbar Action System
------------------------------------------------------------------ */
body.ui-v2 .topbar-menu summary {
  list-style: none;
}

body.ui-v2 .topbar-menu summary::-webkit-details-marker {
  display: none;
}

body.ui-v2 .mn-topbar-actions {
  min-width: 0;
  max-width: min(72vw, 100%);
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.1rem;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}

/* Prevent dropdown clipping when profile/create topbar menu is open */
body.ui-v2 .mn-topbar-actions.mn-topbar-menu-open {
  overflow: visible;
  max-width: none;
}

body.ui-v2 .mn-topbar-actions::-webkit-scrollbar {
  height: 5px;
}

body.ui-v2 .mn-topbar-actions::-webkit-scrollbar-thumb {
  background: #cbd5e1;
  border-radius: 9999px;
}

body.ui-v2 .mn-topbar-btn,
body.ui-v2 .mn-topbar-menu > summary,
body.ui-v2 .mn-topbar-icon-btn,
body.ui-v2 .mn-topbar-avatar-btn {
  flex: 0 0 auto;
}

body.ui-v2 .mn-topbar-btn {
  min-height: 2.5rem;
  line-height: 1.25;
  white-space: nowrap;
}

body.ui-v2 .mn-topbar-icon-btn {
  width: 2.5rem;
  height: 2.5rem;
}

body.ui-v2 .mn-topbar-btn-label {
  display: inline-block;
  white-space: nowrap;
  max-width: 12.5rem;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 1280px) {
  body.ui-v2 .mn-topbar-actions {
    max-width: min(62vw, 100%);
  }

  body.ui-v2 .mn-topbar-btn-label {
    max-width: 9.5rem;
  }
}

/* -----------------------------------------------------------------
   Design Tokens + Component Primitives (Standardization)
------------------------------------------------------------------ */
:root {
  --mn-color-brand-50: #eff6ff;
  --mn-color-brand-100: #dbeafe;
  --mn-color-brand-500: #2563eb;
  --mn-color-brand-600: #1d4ed8;
  --mn-color-brand-700: #1e40af;

  --mn-color-success-50: #ecfdf5;
  --mn-color-success-200: #a7f3d0;
  --mn-color-success-700: #047857;

  --mn-color-danger-50: #fef2f2;
  --mn-color-danger-200: #fecaca;
  --mn-color-danger-700: #b91c1c;

  --mn-color-warning-50: #fffbeb;
  --mn-color-warning-200: #fde68a;
  --mn-color-warning-700: #b45309;

  --mn-neutral-0: #ffffff;
  --mn-neutral-50: #f8fafc;
  --mn-neutral-100: #f1f5f9;
  --mn-neutral-200: #e2e8f0;
  --mn-neutral-300: #cbd5e1;
  --mn-neutral-500: #64748b;
  --mn-neutral-700: #334155;
  --mn-neutral-900: #0f172a;

  --mn-radius-sm: 0.5rem;
  --mn-radius-md: 0.75rem;
  --mn-radius-lg: 1rem;
  --mn-shadow-soft: 0 8px 24px rgba(15, 23, 42, 0.07);
  --mn-shadow-card: 0 14px 30px rgba(15, 23, 42, 0.08);
}

body.ui-v2 .ui-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 2.5rem;
  padding: 0.6rem 1rem;
  border-radius: var(--mn-radius-md);
  border: 1px solid transparent;
  font-weight: 700;
  line-height: 1.2;
  transition: transform 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease, border-color 0.16s ease;
}

body.ui-v2 .ui-btn:hover {
  transform: translateY(-1px);
}

body.ui-v2 .ui-btn-primary {
  background: linear-gradient(135deg, var(--mn-color-brand-500), var(--mn-color-brand-600));
  border-color: var(--mn-color-brand-600);
  color: #fff;
  box-shadow: 0 10px 18px rgba(37, 99, 235, 0.23);
}

body.ui-v2 .ui-btn-secondary {
  background: #fff;
  color: var(--mn-color-brand-700);
  border-color: #bfdbfe;
}

body.ui-v2 .ui-btn-danger {
  background: #ef4444;
  border-color: #dc2626;
  color: #fff;
}

body.ui-v2 .ui-btn-ghost {
  background: transparent;
  border-color: var(--mn-neutral-200);
  color: var(--mn-neutral-700);
}

body.ui-v2 .ui-btn-chip {
  min-height: 2rem;
  padding: 0.3rem 0.8rem;
  border-radius: 9999px;
  font-size: var(--app-text-xs);
  background: var(--mn-neutral-100);
  border-color: var(--mn-neutral-200);
  color: var(--mn-neutral-700);
}

body.ui-v2 .ui-card-soft,
body.ui-v2 .ui-card-metric,
body.ui-v2 .ui-card-panel,
body.ui-v2 .ui-card:not([class*="bg-"]) {
  border-radius: var(--mn-radius-lg);
  border: 1px solid var(--mn-neutral-200);
}

body.ui-v2 .ui-card:not([class*="bg-"]) {
  background: #fff;
  box-shadow: var(--mn-shadow-soft);
}

body.ui-v2 .ui-card-soft {
  background: var(--mn-neutral-50);
}

body.ui-v2 .ui-card-metric {
  background: #fff;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.06);
}

body.ui-v2 .ui-card-panel {
  background: linear-gradient(135deg, #fff, #f8fafc);
  box-shadow: var(--mn-shadow-card);
}

body.ui-v2 .ui-input,
body.ui-v2 .ui-select,
body.ui-v2 .ui-textarea,
body.ui-v2 .ui-file {
  border-radius: var(--mn-radius-md);
  border: 1px solid var(--mn-neutral-300);
  background: #fff;
  color: var(--mn-neutral-900);
}

body.ui-v2 .ui-input:focus,
body.ui-v2 .ui-select:focus,
body.ui-v2 .ui-textarea:focus,
body.ui-v2 .ui-file:focus {
  outline: none;
  border-color: var(--mn-color-brand-500);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.14);
}

body.ui-v2 .ui-badge {
  display: inline-flex;
  align-items: center;
  border-radius: 9999px;
  border: 1px solid transparent;
  font-weight: 600;
  font-size: var(--app-text-xs);
  padding: 0.2rem 0.6rem;
}

body.ui-v2 .ui-badge-muted {
  background: var(--mn-neutral-100);
  border-color: var(--mn-neutral-200);
  color: var(--mn-neutral-700);
}

body.ui-v2 .ui-badge-success {
  background: var(--mn-color-success-50);
  border-color: var(--mn-color-success-200);
  color: var(--mn-color-success-700);
}

body.ui-v2 .ui-badge-warning {
  background: var(--mn-color-warning-50);
  border-color: var(--mn-color-warning-200);
  color: var(--mn-color-warning-700);
}

body.ui-v2 .ui-badge-danger {
  background: var(--mn-color-danger-50);
  border-color: var(--mn-color-danger-200);
  color: var(--mn-color-danger-700);
}

body.ui-v2 .ui-heading-page {
  font-size: var(--app-text-3xl);
  line-height: 1.22;
  font-weight: 800;
}

body.ui-v2 .ui-heading-section {
  font-size: var(--app-text-2xl);
  line-height: 1.28;
  font-weight: 700;
}

body.ui-v2 .ui-heading-subsection {
  font-size: var(--app-text-xl);
  line-height: 1.35;
  font-weight: 700;
}

body.ui-v2 .ui-alert {
  border-radius: var(--mn-radius-md);
  border: 1px solid transparent;
  padding: 0.8rem 1rem;
  font-size: var(--app-text-sm);
  font-weight: 600;
}

body.ui-v2 .ui-alert-success {
  background: var(--mn-color-success-50);
  border-color: var(--mn-color-success-200);
  color: var(--mn-color-success-700);
}

body.ui-v2 .ui-alert-error {
  background: var(--mn-color-danger-50);
  border-color: var(--mn-color-danger-200);
  color: var(--mn-color-danger-700);
}

body.ui-v2 .ui-alert-info {
  background: var(--mn-color-brand-50);
  border-color: var(--mn-color-brand-100);
  color: var(--mn-color-brand-700);
}

/* -----------------------------------------------------------------
   Shared Admin Workspace Wireframe
   Reused by admin pages to keep one consistent layout system
------------------------------------------------------------------ */
body.ui-v2 .admin-wireframe-shell {
  max-width: min(108rem, 100%);
}

body.ui-v2 .admin-panel {
  border: 1px solid #e2e8f0;
  box-shadow: 0 10px 28px -22px rgba(15, 23, 42, 0.55);
}

body.ui-v2 .admin-section-head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.25rem;
  margin-bottom: 1rem;
}

body.ui-v2 .admin-section-head h2 {
  margin: 0;
}

body.ui-v2 .admin-form-surface {
  border: 1px solid #e2e8f0;
  border-radius: 0.9rem;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
  padding: 1rem;
}

body.ui-v2 .admin-table-wrap {
  border: 1px solid #e2e8f0;
  border-radius: 0.9rem;
  background: #ffffff;
}

body.ui-v2 .admin-workspace-toggle .js-admin-view-btn {
  min-height: 2.65rem;
}

@media (min-width: 640px) {
  body.ui-v2 .admin-section-head {
    flex-direction: row;
    align-items: center;
  }

  body.ui-v2 .admin-form-surface {
    padding: 1.25rem;
  }
}

/* Sidebar nav consistency */
body.ui-v2 #sidebar .nav-item {
  min-height: 2.7rem;
  align-items: center;
}

body.ui-v2 #sidebar .nav-label {
  line-height: 1.25;
}

body.ui-v2 #sidebar .mn-nav-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.45rem;
  padding: 0.1rem 0.4rem;
  border-radius: 9999px;
  font-size: 9px;
  font-weight: 800;
  line-height: 1;
}

/* Tone down bright blue active states across sidebar/topbar */
body.ui-v2 #sidebar .nav-item.bg-blue-50 {
  background: #edf2f8 !important;
}

body.ui-v2 #sidebar .nav-item.text-blue-600 {
  color: #1f467f !important;
}

body.ui-v2 #sidebar .nav-item.border-blue-600 {
  border-color: #1f467f !important;
}

body.ui-v2 .mn-topbar-btn.bg-blue-50,
body.ui-v2 .mn-topbar-icon-btn.bg-blue-50 {
  background: #edf2f8 !important;
}

body.ui-v2 .mn-topbar-btn.text-blue-700,
body.ui-v2 .mn-topbar-icon-btn.text-blue-700 {
  color: #1f467f !important;
}

body.ui-v2 .mn-topbar-btn.border-blue-200,
body.ui-v2 .mn-topbar-icon-btn.border-blue-200 {
  border-color: #c9d6e5 !important;
}

body.ui-v2 .mn-topbar-btn.bg-blue-600 {
  background: #1f467f !important;
  border-color: #1f467f !important;
}

body.ui-v2 .mn-topbar-btn.hover\:bg-blue-700:hover {
  background: #183664 !important;
  border-color: #183664 !important;
}

/* Utility helpers for inline-style removals */
body.ui-v2 .mn-visually-hidden {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

body.ui-v2 .mn-max-content {
  width: max-content;
}

body.ui-v2 .mn-progress-track {
  overflow: hidden;
}

body.ui-v2 .mn-progress-fill {
  height: 100%;
  border-radius: inherit;
  transition: width 0.45s ease;
}

/* Flat button policy and contrast-safe translucent hero chips */
body.ui-v2 button,
body.ui-v2 input[type="button"],
body.ui-v2 input[type="submit"],
body.ui-v2 input[type="reset"],
body.ui-v2 .ui-btn,
body.ui-v2 .ui-btn-primary,
body.ui-v2 .ui-btn-secondary,
body.ui-v2 .ui-btn-danger,
body.ui-v2 .ui-btn-ghost,
body.ui-v2 .ui-btn-chip,
body.ui-v2 .mn-topbar-btn,
body.ui-v2 .mn-topbar-menu > summary,
body.ui-v2 .mn-topbar-icon-btn,
body.ui-v2 .mn-topbar-avatar-btn,
body.ui-v2 .main-content a.bg-blue-600,
body.ui-v2 .main-content a[class*="from-blue-"][class*="to-indigo-"] {
  box-shadow: none !important;
}

body.ui-v2 .ui-card[class*="bg-white/"] {
  box-shadow: none;
}

/* Keep decorative blur ornaments behind card surfaces site-wide */
body.ui-v2 .ui-card,
body.ui-v2 .profile-card {
  position: relative;
  z-index: 1;
}

body.ui-v2 .pointer-events-none.absolute.blur-3xl {
  z-index: 0;
}

body.ui-v2 .profile-card {
  border: 1px solid var(--mn-neutral-200);
  border-radius: var(--mn-radius-lg);
  background: #fff;
  box-shadow: var(--mn-shadow-soft);
}

body.ui-v2 .mn-scroll-row-slow {
  animation: scroll-left 32s linear infinite;
}

/* Committee theme classes (centralized) */
body.ui-v2 .mn-committee-gradient-cultural { background: linear-gradient(135deg, #f59e0b, #d97706); }
body.ui-v2 .mn-committee-gradient-technical { background: linear-gradient(135deg, #3b82f6, #1d4ed8); }
body.ui-v2 .mn-committee-gradient-sports { background: linear-gradient(135deg, #22c55e, #16a34a); }
body.ui-v2 .mn-committee-gradient-academic { background: linear-gradient(135deg, #8b5cf6, #7c3aed); }
body.ui-v2 .mn-committee-gradient-student-council { background: linear-gradient(135deg, #ec4899, #db2777); }
body.ui-v2 .mn-committee-gradient-placement { background: linear-gradient(135deg, #6366f1, #4f46e5); }
body.ui-v2 .mn-committee-gradient-other { background: linear-gradient(135deg, #6b7280, #4b5563); }

body.ui-v2 .mn-committee-badge-cultural { background: #fef3c7; color: #92400e; }
body.ui-v2 .mn-committee-badge-technical { background: #dbeafe; color: #1e40af; }
body.ui-v2 .mn-committee-badge-sports { background: #dcfce7; color: #166534; }
body.ui-v2 .mn-committee-badge-academic { background: #f3e8ff; color: #7c3aed; }
body.ui-v2 .mn-committee-badge-student-council { background: #fce7f3; color: #be185d; }
body.ui-v2 .mn-committee-badge-placement { background: #e0e7ff; color: #3730a3; }
body.ui-v2 .mn-committee-badge-other { background: #f3f4f6; color: #374151; }

/* Issue theme classes (centralized) */
body.ui-v2 .mn-issue-soft-default { background: rgba(37, 99, 235, 0.14); color: #1d4ed8; }
body.ui-v2 .mn-issue-dot-default { background: #2563eb; }
body.ui-v2 .mn-issue-hero-chip-default { background: rgba(37, 99, 235, 0.28); border: 1px solid rgba(147, 197, 253, 0.48); color: #fff; }

body.ui-v2 .mn-issue-soft-bug { background: rgba(244, 63, 94, 0.16); color: #be123c; }
body.ui-v2 .mn-issue-dot-bug { background: #e11d48; }
body.ui-v2 .mn-issue-hero-chip-bug { background: rgba(244, 63, 94, 0.35); border: 1px solid rgba(253, 164, 175, 0.5); color: #fff; }

body.ui-v2 .mn-issue-soft-content { background: rgba(16, 185, 129, 0.16); color: #047857; }
body.ui-v2 .mn-issue-dot-content { background: #10b981; }
body.ui-v2 .mn-issue-hero-chip-content { background: rgba(16, 185, 129, 0.35); border: 1px solid rgba(110, 231, 183, 0.52); color: #fff; }

body.ui-v2 .mn-issue-soft-feature { background: rgba(99, 102, 241, 0.16); color: #4338ca; }
body.ui-v2 .mn-issue-dot-feature { background: #4f46e5; }
body.ui-v2 .mn-issue-hero-chip-feature { background: rgba(99, 102, 241, 0.36); border: 1px solid rgba(165, 180, 252, 0.52); color: #fff; }

body.ui-v2 .mn-issue-soft-feedback { background: rgba(245, 158, 11, 0.18); color: #b45309; }
body.ui-v2 .mn-issue-dot-feedback { background: #d97706; }
body.ui-v2 .mn-issue-hero-chip-feedback { background: rgba(245, 158, 11, 0.36); border: 1px solid rgba(253, 230, 138, 0.56); color: #fff; }

body.ui-v2 .mn-issue-soft-account { background: rgba(6, 182, 212, 0.16); color: #0e7490; }
body.ui-v2 .mn-issue-dot-account { background: #0891b2; }
body.ui-v2 .mn-issue-hero-chip-account { background: rgba(6, 182, 212, 0.35); border: 1px solid rgba(103, 232, 249, 0.5); color: #fff; }

body.ui-v2 .mn-issue-soft-billing { background: rgba(217, 70, 239, 0.16); color: #a21caf; }
body.ui-v2 .mn-issue-dot-billing { background: #c026d3; }
body.ui-v2 .mn-issue-hero-chip-billing { background: rgba(217, 70, 239, 0.34); border: 1px solid rgba(240, 171, 252, 0.52); color: #fff; }
/* BEGIN: mn width classes */
body.ui-v2 .mn-w-pct-0 { width: 0%; }
body.ui-v2 .mn-w-pct-1 { width: 1%; }
body.ui-v2 .mn-w-pct-2 { width: 2%; }
body.ui-v2 .mn-w-pct-3 { width: 3%; }
body.ui-v2 .mn-w-pct-4 { width: 4%; }
body.ui-v2 .mn-w-pct-5 { width: 5%; }
body.ui-v2 .mn-w-pct-6 { width: 6%; }
body.ui-v2 .mn-w-pct-7 { width: 7%; }
body.ui-v2 .mn-w-pct-8 { width: 8%; }
body.ui-v2 .mn-w-pct-9 { width: 9%; }
body.ui-v2 .mn-w-pct-10 { width: 10%; }
body.ui-v2 .mn-w-pct-11 { width: 11%; }
body.ui-v2 .mn-w-pct-12 { width: 12%; }
body.ui-v2 .mn-w-pct-13 { width: 13%; }
body.ui-v2 .mn-w-pct-14 { width: 14%; }
body.ui-v2 .mn-w-pct-15 { width: 15%; }
body.ui-v2 .mn-w-pct-16 { width: 16%; }
body.ui-v2 .mn-w-pct-17 { width: 17%; }
body.ui-v2 .mn-w-pct-18 { width: 18%; }
body.ui-v2 .mn-w-pct-19 { width: 19%; }
body.ui-v2 .mn-w-pct-20 { width: 20%; }
body.ui-v2 .mn-w-pct-21 { width: 21%; }
body.ui-v2 .mn-w-pct-22 { width: 22%; }
body.ui-v2 .mn-w-pct-23 { width: 23%; }
body.ui-v2 .mn-w-pct-24 { width: 24%; }
body.ui-v2 .mn-w-pct-25 { width: 25%; }
body.ui-v2 .mn-w-pct-26 { width: 26%; }
body.ui-v2 .mn-w-pct-27 { width: 27%; }
body.ui-v2 .mn-w-pct-28 { width: 28%; }
body.ui-v2 .mn-w-pct-29 { width: 29%; }
body.ui-v2 .mn-w-pct-30 { width: 30%; }
body.ui-v2 .mn-w-pct-31 { width: 31%; }
body.ui-v2 .mn-w-pct-32 { width: 32%; }
body.ui-v2 .mn-w-pct-33 { width: 33%; }
body.ui-v2 .mn-w-pct-34 { width: 34%; }
body.ui-v2 .mn-w-pct-35 { width: 35%; }
body.ui-v2 .mn-w-pct-36 { width: 36%; }
body.ui-v2 .mn-w-pct-37 { width: 37%; }
body.ui-v2 .mn-w-pct-38 { width: 38%; }
body.ui-v2 .mn-w-pct-39 { width: 39%; }
body.ui-v2 .mn-w-pct-40 { width: 40%; }
body.ui-v2 .mn-w-pct-41 { width: 41%; }
body.ui-v2 .mn-w-pct-42 { width: 42%; }
body.ui-v2 .mn-w-pct-43 { width: 43%; }
body.ui-v2 .mn-w-pct-44 { width: 44%; }
body.ui-v2 .mn-w-pct-45 { width: 45%; }
body.ui-v2 .mn-w-pct-46 { width: 46%; }
body.ui-v2 .mn-w-pct-47 { width: 47%; }
body.ui-v2 .mn-w-pct-48 { width: 48%; }
body.ui-v2 .mn-w-pct-49 { width: 49%; }
body.ui-v2 .mn-w-pct-50 { width: 50%; }
body.ui-v2 .mn-w-pct-51 { width: 51%; }
body.ui-v2 .mn-w-pct-52 { width: 52%; }
body.ui-v2 .mn-w-pct-53 { width: 53%; }
body.ui-v2 .mn-w-pct-54 { width: 54%; }
body.ui-v2 .mn-w-pct-55 { width: 55%; }
body.ui-v2 .mn-w-pct-56 { width: 56%; }
body.ui-v2 .mn-w-pct-57 { width: 57%; }
body.ui-v2 .mn-w-pct-58 { width: 58%; }
body.ui-v2 .mn-w-pct-59 { width: 59%; }
body.ui-v2 .mn-w-pct-60 { width: 60%; }
body.ui-v2 .mn-w-pct-61 { width: 61%; }
body.ui-v2 .mn-w-pct-62 { width: 62%; }
body.ui-v2 .mn-w-pct-63 { width: 63%; }
body.ui-v2 .mn-w-pct-64 { width: 64%; }
body.ui-v2 .mn-w-pct-65 { width: 65%; }
body.ui-v2 .mn-w-pct-66 { width: 66%; }
body.ui-v2 .mn-w-pct-67 { width: 67%; }
body.ui-v2 .mn-w-pct-68 { width: 68%; }
body.ui-v2 .mn-w-pct-69 { width: 69%; }
body.ui-v2 .mn-w-pct-70 { width: 70%; }
body.ui-v2 .mn-w-pct-71 { width: 71%; }
body.ui-v2 .mn-w-pct-72 { width: 72%; }
body.ui-v2 .mn-w-pct-73 { width: 73%; }
body.ui-v2 .mn-w-pct-74 { width: 74%; }
body.ui-v2 .mn-w-pct-75 { width: 75%; }
body.ui-v2 .mn-w-pct-76 { width: 76%; }
body.ui-v2 .mn-w-pct-77 { width: 77%; }
body.ui-v2 .mn-w-pct-78 { width: 78%; }
body.ui-v2 .mn-w-pct-79 { width: 79%; }
body.ui-v2 .mn-w-pct-80 { width: 80%; }
body.ui-v2 .mn-w-pct-81 { width: 81%; }
body.ui-v2 .mn-w-pct-82 { width: 82%; }
body.ui-v2 .mn-w-pct-83 { width: 83%; }
body.ui-v2 .mn-w-pct-84 { width: 84%; }
body.ui-v2 .mn-w-pct-85 { width: 85%; }
body.ui-v2 .mn-w-pct-86 { width: 86%; }
body.ui-v2 .mn-w-pct-87 { width: 87%; }
body.ui-v2 .mn-w-pct-88 { width: 88%; }
body.ui-v2 .mn-w-pct-89 { width: 89%; }
body.ui-v2 .mn-w-pct-90 { width: 90%; }
body.ui-v2 .mn-w-pct-91 { width: 91%; }
body.ui-v2 .mn-w-pct-92 { width: 92%; }
body.ui-v2 .mn-w-pct-93 { width: 93%; }
body.ui-v2 .mn-w-pct-94 { width: 94%; }
body.ui-v2 .mn-w-pct-95 { width: 95%; }
body.ui-v2 .mn-w-pct-96 { width: 96%; }
body.ui-v2 .mn-w-pct-97 { width: 97%; }
body.ui-v2 .mn-w-pct-98 { width: 98%; }
body.ui-v2 .mn-w-pct-99 { width: 99%; }
body.ui-v2 .mn-w-pct-100 { width: 100%; }
/* END: mn width classes */

/* BEGIN: mn governance utility classes */
body.ui-v2 .mn-flex-1-min0 { flex: 1; min-width: 0; }
body.ui-v2 .mn-flex-1-min200 { flex: 1; min-width: 200px; }
body.ui-v2 .mn-flex-1-min240 { flex: 1; min-width: 240px; }
body.ui-v2 .mn-flex-between-center { display: flex; justify-content: space-between; align-items: center; }
body.ui-v2 .mn-flex-between-center-gap-06 { display: flex; align-items: center; justify-content: space-between; gap: 0.6rem; }
body.ui-v2 .mn-flex-between-center-gap-075 { display: flex; align-items: center; justify-content: space-between; gap: 0.75rem; }
body.ui-v2 .mn-flex-wrap-gap-06-start { display: flex; flex-wrap: wrap; gap: 0.6rem; align-items: flex-start; }
body.ui-v2 .mn-flex-center-gap-065-min220 { display: flex; align-items: center; gap: 0.65rem; min-width: 220px; }
body.ui-v2 .mn-flex-center-wrap-gap-04 { display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
body.ui-v2 .mn-form-col-gap-04-min240 { display: flex; flex-direction: column; gap: 0.4rem; min-width: 240px; }
body.ui-v2 .mn-form-col-gap-04-min220 { display: flex; flex-direction: column; gap: 0.4rem; min-width: 220px; }

body.ui-v2 .mn-bg-amber { background: var(--amber); }
body.ui-v2 .mn-bg-blue-500 { background: var(--blue-500); }
body.ui-v2 .mn-bg-green { background: var(--green); }

body.ui-v2 .mn-admin-console-brand { font-size: 0.9rem; font-weight: 700; color: var(--blue-800); letter-spacing: -0.01em; }
body.ui-v2 .mn-admin-console-sub { font-size: 0.71rem; color: var(--ink-3); margin-top: 3px; }
body.ui-v2 .mn-admin-console-meta { font-size: 0.75rem; color: var(--ink-3); display: flex; flex-direction: column; gap: 0.4rem; }
body.ui-v2 .mn-stat-value-tight,
body.ui-v2 .mn-text-1-5-tight { font-size: 1.5rem; line-height: 1.1; }
body.ui-v2 .mn-text-1-2-tight { font-size: 1.2rem; line-height: 1.15; }
body.ui-v2 .mn-text-072-ink3 { font-size: 0.72rem; color: var(--ink-3); }
body.ui-v2 .mn-text-danger { color: var(--red); }

body.ui-v2 .mn-grid-cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
body.ui-v2 .mn-grid-col-full { grid-column: 1 / -1; }

body.ui-v2 .mn-inline-block { display: inline-block; }
body.ui-v2 .mn-hidden { display: none; }
body.ui-v2 .mn-cursor-default { cursor: default; }
body.ui-v2 .mn-no-underline { text-decoration: none; }

body.ui-v2 .mn-form-group-min170 { min-width: 170px; margin-bottom: 0; }
body.ui-v2 .mn-form-group-min190 { min-width: 190px; margin-bottom: 0; }
body.ui-v2 .mn-form-group-mb0 { margin-bottom: 0; }
body.ui-v2 .mn-justify-start { justify-content: flex-start; }

body.ui-v2 .mn-pad-08-10 { padding: 0.8rem 1rem; }
body.ui-v2 .mn-pad-100-125-085 { padding: 1rem 1.25rem 0.85rem; }
body.ui-v2 .mn-pad-095-125 { padding: 0.95rem 1.25rem; }
body.ui-v2 .mn-pl-1rem { padding-left: 1rem; }
body.ui-v2 .mn-leading-15 { line-height: 1.5; }

body.ui-v2 .mn-pt-1rem { padding-top: 1rem; }
body.ui-v2 .mn-pt-162 { padding-top: 1.62rem; }
body.ui-v2 .mn-mt-025-break { margin-top: 0.25rem; word-break: break-word; }
body.ui-v2 .mn-mt-06 { margin-top: 0.6rem; }
body.ui-v2 .mn-ml-045 { margin-left: 0.45rem; }
body.ui-v2 .mn-mx-02 { margin: 0 0.2rem; }
body.ui-v2 .mn-mb-03rem { margin-bottom: 0.3rem; }

body.ui-v2 .mn-link-break-inline { word-break: break-word; display: inline-block; margin-top: 0.25rem; }

body.ui-v2 .mn-w-42 { width: 42px; }
body.ui-v2 .mn-h-pct-35 { height: 35%; }
body.ui-v2 .mn-h-pct-40 { height: 40%; }
body.ui-v2 .mn-h-pct-55 { height: 55%; }
body.ui-v2 .mn-h-pct-70 { height: 70%; }
body.ui-v2 .mn-h-pct-90 { height: 90%; }
body.ui-v2 .mn-h-pct-100 { height: 100%; }

body.ui-v2 .mn-avatar-blue-grad {
  background: linear-gradient(135deg, var(--blue-100), var(--blue-200));
  color: var(--blue-700);
  border-color: var(--blue-200);
}
/* END: mn governance utility classes */

/* Extracted page-level styles from route PHP files.
   Generated during UI standardization migration. */

/* --- BEGIN: admin/admin-org-structure.php --- */

    .tag-chip.is-active {
        background-color: rgb(15 23 42);
        border-color: rgb(15 23 42);
        color: rgb(255 255 255);
    }
/* --- END: admin/admin-org-structure.php --- */

/* --- BEGIN: admin/admin-resource-connections.php --- */

    .admin-connection-shell .admin-glass,
    #editModal .admin-glass {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    }
    .admin-connection-shell .admin-input,
    .admin-connection-shell .admin-select,
    .admin-connection-shell .admin-textarea {
        width: 100%;
        border: 1px solid #cbd5e1;
        background: #f8fafc;
        border-radius: 0.75rem;
        padding: 0.62rem 0.8rem;
        color: #0f172a;
        font-size: 0.9rem;
    }
    .admin-connection-shell .admin-input:focus,
    .admin-connection-shell .admin-select:focus,
    .admin-connection-shell .admin-textarea:focus {
        outline: none;
        border-color: #3b82f6;
        box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.18);
        background: #ffffff;
    }
    .admin-connection-shell .type-tab {
        display: inline-flex;
        align-items: center;
        border-radius: 0.75rem;
        border: 1px solid #cbd5e1;
        background: #ffffff;
        padding: 0.5rem 0.9rem;
        font-size: 0.86rem;
        font-weight: 600;
        color: #475569;
        transition: all 150ms ease;
        white-space: nowrap;
    }
    .admin-connection-shell .type-tab:hover {
        background: #f1f5f9;
        border-color: #94a3b8;
        color: #0f172a;
    }
    .admin-connection-shell .type-tab.active {
        background: #2563eb;
        color: #ffffff;
        border-color: #2563eb;
        box-shadow: 0 8px 18px rgba(37, 99, 235, 0.24);
    }
/* --- END: admin/admin-resource-connections.php --- */

/* --- BEGIN: admin/random-chat-logs.php --- */

    .chat-log-shell .log-glass {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    }
    .chat-log-shell .info-card {
        border: 1px solid #e2e8f0;
        border-radius: 0.95rem;
        background: #ffffff;
        padding: 1rem;
    }
    .chat-log-shell .message-stream {
        max-height: 780px;
        overflow-y: auto;
        background:
            radial-gradient(circle at 15% 10%, rgba(59, 130, 246, 0.08), transparent 35%),
            radial-gradient(circle at 85% 0%, rgba(99, 102, 241, 0.07), transparent 35%),
            #f8fafc;
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        padding: 1rem;
    }
    .chat-log-shell .msg-row {
        display: flex;
        margin-bottom: 0.9rem;
    }
    .chat-log-shell .msg-row.left {
        justify-content: flex-start;
    }
    .chat-log-shell .msg-row.right {
        justify-content: flex-end;
    }
    .chat-log-shell .msg-bubble {
        max-width: min(82%, 44rem);
        border-radius: 0.9rem;
        border: 1px solid #e2e8f0;
        background: #ffffff;
        padding: 0.75rem 0.85rem;
    }
    .chat-log-shell .msg-bubble.user1 {
        background: #eff6ff;
        border-color: #bfdbfe;
    }
    .chat-log-shell .msg-bubble.user2 {
        background: #ecfdf5;
        border-color: #bbf7d0;
    }
    .chat-log-shell .msg-bubble.ai {
        background: #eef2ff;
        border-color: #c7d2fe;
    }
/* --- END: admin/random-chat-logs.php --- */

/* --- BEGIN: admin/random-chat-stats.php --- */

    .chat-stats-shell .chat-glass {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    }
    .chat-stats-shell .metric-card {
        border: 1px solid #e2e8f0;
        border-radius: 0.95rem;
        background: #ffffff;
        padding: 1rem;
    }
    .chat-stats-shell .metric-label {
        font-size: 0.74rem;
        line-height: 1rem;
        font-weight: 700;
        letter-spacing: 0.04em;
        text-transform: uppercase;
        color: #64748b;
    }
/* --- END: admin/random-chat-stats.php --- */

/* --- BEGIN: pages/committee-dashboard.php --- */

	    .committee-dashboard-shell .metric-card {
	        border: 1px solid #dbeafe;
	        border-radius: 1rem;
	        background: #ffffff;
	        transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
	    }
	    .committee-dashboard-shell .metric-card:hover {
	        transform: translateY(-2px);
	        border-color: #bfdbfe;
	        box-shadow: 0 14px 30px rgba(15, 23, 42, 0.08);
	    }
	    .committee-dashboard-shell .action-card {
	        border: 1px solid #e2e8f0;
	        border-radius: 1rem;
	        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
	        transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
	    }
	    .committee-dashboard-shell .action-card:hover {
	        transform: translateY(-2px);
	        border-color: #bfdbfe;
	        box-shadow: 0 14px 30px rgba(15, 23, 42, 0.08);
	    }
	
/* --- END: pages/committee-dashboard.php --- */

/* --- BEGIN: pages/committee-workspace.php --- */

    .committee-workspace-shell .workspace-app-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        gap: 0.9rem;
        align-items: start;
    }
    .committee-workspace-shell.committee-workspace-embedded {
        padding: 0;
        max-width: none;
    }
    .committee-workspace-shell .workspace-module-sidebar {
        position: static;
        top: auto;
        border: 1px solid #dbe4ee;
        background: #ffffff;
        box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
        max-height: none;
        overflow: visible;
    }
    .committee-workspace-shell .workspace-module-tab-list {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.5rem;
    }
    .committee-workspace-shell .workspace-module-tab {
        width: 100%;
        border: 1px solid #d1d9e4;
        border-radius: 0.75rem;
        background: #ffffff;
        color: #334155;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.6rem;
        font-size: 0.78rem;
        font-weight: 700;
        padding: 0.52rem 0.64rem;
        transition: border-color 140ms ease, background-color 140ms ease, color 140ms ease;
    }
    .committee-workspace-shell .workspace-module-tab:hover {
        border-color: #94a3b8;
        background: #f8fafc;
    }
    .committee-workspace-shell .workspace-module-tab[data-active="true"] {
        border-color: #2563eb;
        background: #eff6ff;
        color: #1d4ed8;
    }
    .committee-workspace-shell .workspace-module-tab-count {
        min-width: 1.75rem;
        text-align: center;
        border-radius: 999px;
        border: 1px solid #cbd5e1;
        background: #f8fafc;
        color: #475569;
        font-size: 0.67rem;
        font-weight: 700;
        line-height: 1.1rem;
        padding: 0 0.32rem;
    }
    .committee-workspace-shell .workspace-module-tab[data-active="true"] .workspace-module-tab-count {
        border-color: #bfdbfe;
        background: #ffffff;
        color: #1d4ed8;
    }
    .committee-workspace-shell .workspace-module-mobile-select {
        display: none;
    }
    .committee-workspace-shell .workspace-module-panels {
        display: grid;
        gap: 1rem;
    }
    .committee-workspace-shell .workspace-module-panel.hidden {
        display: none;
    }
    .committee-workspace-shell .workspace-hero {
        border: 1px solid #dbe3ef;
        box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
    }

    .committee-workspace-shell .workspace-metric-card {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        border-color: #dce4ee;
    }

    .committee-workspace-shell .workspace-governance-grid article {
        transition: border-color 170ms ease, transform 170ms ease, box-shadow 170ms ease;
    }

    .committee-workspace-shell .workspace-governance-grid article:hover {
        transform: translateY(-1px);
        border-color: #cbd5e1;
        box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
    }

    .committee-workspace-shell .workspace-module-card {
        border: 1px solid #dbe4ee;
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
    }

    .committee-workspace-shell .workspace-module-kicker {
        margin-bottom: 0.4rem;
        font-size: 0.68rem;
        line-height: 1rem;
        font-weight: 700;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: #64748b;
    }

    .committee-workspace-shell .workspace-module-card form + form {
        margin-top: 1rem;
        padding-top: 1rem;
        border-top: 1px dashed #dbe3ef;
    }

    .committee-workspace-shell .workspace-record-row {
        transition: border-color 170ms ease, background-color 170ms ease;
    }

    .committee-workspace-shell .workspace-record-row:hover {
        border-color: #cbd5e1;
        background: #f1f5f9;
    }

    .workspace-toast-root {
        position: fixed;
        top: 4.8rem;
        right: 1rem;
        z-index: 80;
        display: flex;
        flex-direction: column;
        gap: 0.5rem;
        width: min(24rem, calc(100vw - 2rem));
    }

    .workspace-toast {
        border-radius: 0.85rem;
        border: 1px solid transparent;
        padding: 0.75rem 0.9rem;
        font-size: 0.82rem;
        font-weight: 600;
        box-shadow: 0 14px 30px rgba(15, 23, 42, 0.16);
        opacity: 0;
        transform: translateY(-6px);
        transition: opacity 180ms ease, transform 180ms ease;
    }

    .workspace-toast.is-visible {
        opacity: 1;
        transform: translateY(0);
    }

    .workspace-toast-success {
        background: #ecfdf5;
        border-color: #a7f3d0;
        color: #065f46;
    }

    .workspace-toast-error {
        background: #fef2f2;
        border-color: #fecaca;
        color: #991b1b;
    }

    @media (max-width: 768px) {
        .workspace-toast-root {
            top: 4.25rem;
            right: 0.75rem;
            width: calc(100vw - 1.5rem);
        }
    }
    @media (max-width: 1279px) {
        .committee-workspace-shell .workspace-app-layout {
            grid-template-columns: 1fr;
        }
        .committee-workspace-shell .workspace-module-sidebar {
            position: static;
            max-height: none;
        }
        .committee-workspace-shell .workspace-module-tab-list {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 0.5rem;
        }
    }
    @media (max-width: 640px) {
        .committee-workspace-shell .workspace-module-tab-list {
            display: none;
        }
        .committee-workspace-shell .workspace-module-mobile-select {
            display: block;
        }
    }

/* --- END: pages/committee-workspace.php --- */

/* --- BEGIN: pages/manage-committee.php --- */

    .committee-control-shell .committee-control-topbar {
        border: 0;
        box-shadow: none;
    }
    .committee-control-shell .committee-topbar-side {
        width: 100%;
        max-width: 34rem;
        justify-self: end;
    }
    .committee-control-shell .committee-app-layout {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        gap: 1rem;
        align-items: start;
    }
    .committee-control-shell .committee-workspace-strip {
        position: static;
        top: auto;
        border: 0;
        background: #ffffff;
        box-shadow: none;
        max-height: none;
        overflow: visible;
    }
    .committee-control-shell .committee-control-panel {
        border: 0;
        box-shadow: none;
    }
    .committee-control-shell .committee-start-here {
        background: linear-gradient(180deg, #f5f9ff 0%, #eff5ff 100%);
    }
    .committee-control-shell .committee-start-progress-track {
        position: relative;
        width: 100%;
        height: 0.5rem;
        border-radius: 999px;
        background: #dbeafe;
        overflow: hidden;
    }
    .committee-control-shell .committee-start-progress-fill {
        display: block;
        height: 100%;
        border-radius: inherit;
        background: linear-gradient(90deg, #2563eb 0%, #3b82f6 100%);
    }
    .committee-control-shell .committee-start-task {
        transition: border-color 140ms ease, box-shadow 140ms ease;
    }
    .committee-control-shell .committee-start-task:hover {
        border-color: #bfdbfe;
        box-shadow: 0 6px 16px rgba(37, 99, 235, 0.08);
    }
    .committee-control-shell .committee-start-task-done {
        box-shadow: none;
    }
    .committee-control-shell .committee-start-task-dot {
        display: inline-flex;
        width: 0.5rem;
        height: 0.5rem;
        border-radius: 999px;
        flex-shrink: 0;
    }
    .committee-control-shell .committee-navigator-details {
        border: 1px solid #dbe4ee;
        border-radius: 0.95rem;
        background: #ffffff;
    }
    .committee-control-shell .committee-navigator-summary {
        list-style: none;
        cursor: pointer;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 1rem;
        padding: 0.85rem 1rem;
    }
    .committee-control-shell .committee-navigator-summary::-webkit-details-marker {
        display: none;
    }
    .committee-control-shell .committee-navigator-summary-cta {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 5.6rem;
        border-radius: 999px;
        border: 1px solid #cbd5e1;
        background: #f8fafc;
        color: #475569;
        font-size: 0.72rem;
        font-weight: 700;
        line-height: 1;
        padding: 0.4rem 0.75rem;
    }
    .committee-control-shell .committee-navigator-summary-cta::before {
        content: 'Expand';
    }
    .committee-control-shell .committee-navigator-details[open] .committee-navigator-summary-cta {
        border-color: #bfdbfe;
        background: #eff6ff;
        color: #1d4ed8;
    }
    .committee-control-shell .committee-navigator-details[open] .committee-navigator-summary-cta::before {
        content: 'Collapse';
    }
    .committee-control-shell .committee-navigator-body {
        border-top: 1px solid #e2e8f0;
        padding: 0.95rem 1rem 1rem;
    }
    .committee-control-shell .committee-workspace-shortcuts {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.5rem;
    }
    .committee-control-shell .committee-app-tab-list {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.5rem;
    }
    .committee-control-shell .committee-app-tab {
        width: 100%;
        border: 1px solid #d1d9e4;
        border-radius: 0.75rem;
        background: #ffffff;
        color: #334155;
        display: flex;
        align-items: center;
        justify-content: center;
        text-align: center;
        font-size: 0.78rem;
        font-weight: 700;
        padding: 0.6rem 0.7rem;
        transition: border-color 140ms ease, background-color 140ms ease, color 140ms ease;
    }
    .committee-control-shell .committee-app-tab:hover {
        border-color: #94a3b8;
        background: #f8fafc;
    }
    .committee-control-shell .committee-app-tab[data-active="true"] {
        border-color: #2563eb;
        background: #eff6ff;
        color: #1d4ed8;
    }
    .committee-control-shell .committee-control-panel.hidden {
        display: none;
    }
    .committee-control-shell .committee-top-priority-empty {
        display: none;
    }
    .committee-control-shell .committee-app-main > .committee-control-panel:last-child {
        margin-bottom: 0;
    }
    @media (max-width: 1023px) {
        .committee-control-shell .committee-topbar-side {
            max-width: none;
        }
        .committee-control-shell .committee-navigator-summary {
            padding: 0.75rem 0.85rem;
        }
        .committee-control-shell .committee-navigator-body {
            padding: 0.8rem 0.85rem 0.9rem;
        }
        .committee-control-shell .committee-app-tab-list {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 0.5rem;
        }
        .committee-control-shell .committee-workspace-shortcuts {
            justify-content: flex-start;
        }
    }
    @media (max-width: 640px) {
        .committee-control-shell .committee-app-tab-list {
            grid-template-columns: 1fr;
        }
        .committee-control-shell .committee-workspace-shortcuts {
            width: 100%;
        }
    }

/* --- END: pages/manage-committee.php --- */

/* --- BEGIN: pages/committee-settings.php --- */

    .committee-settings-shell .settings-form-section {
        border-bottom: 1px dashed #e2e8f0;
        padding-bottom: 1rem;
        margin-bottom: 1rem;
    }
    .committee-settings-shell .settings-form-section:last-of-type {
        border-bottom: none;
        padding-bottom: 0;
        margin-bottom: 0;
    }
    .committee-settings-shell .settings-input {
        border-radius: 0.75rem;
        border: 1px solid #cbd5e1;
        background: #ffffff;
    }
    .committee-settings-shell .settings-input:focus {
        border-color: #3b82f6;
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
        outline: none;
    }
/* --- END: pages/committee-settings.php --- */

/* --- BEGIN: pages/committee.php --- */

    .committee-page-shell {
        max-width: min(108rem, 100%);
        overflow-x: clip;
    }
    .committee-page-shell .feature-card {
        border: 1px solid #dbe4ef;
        border-radius: 1rem;
        background: #ffffff;
        box-shadow: 0 10px 26px rgba(15, 23, 42, 0.06);
    }
    .committee-page-shell .committee-public-cover {
        background-color: #1d4ed8;
        background-image: linear-gradient(135deg, #1e3a8a 0%, #1d4ed8 45%, #2563eb 100%);
    }
    .committee-page-shell .committee-public-content {
        position: relative;
    }
    .committee-page-shell .committee-public-logo {
        box-shadow: 0 10px 24px rgba(15, 23, 42, 0.2);
    }
    .committee-page-shell .committee-public-quick {
        background: linear-gradient(180deg, #f8fbff 0%, #f1f5f9 100%);
    }
    .committee-page-shell .committee-public-links a {
        transition: transform 170ms ease, box-shadow 170ms ease;
    }
    .committee-page-shell .committee-public-links a:hover {
        transform: translateY(-1px);
        box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
    }
    .committee-page-shell .committee-public-stat-grid {
        display: grid;
        grid-template-columns: repeat(4, minmax(0, 1fr));
        gap: 0.75rem;
    }
    .committee-page-shell .committee-public-stat-card {
        border: 1px solid #dbe4ef;
        border-radius: 0.9rem;
        background: #ffffff;
        padding: 0.95rem 1rem;
        box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
    }
    .committee-page-shell .committee-public-stat-label {
        color: #64748b;
        font-size: 0.72rem;
        letter-spacing: 0.08em;
        font-weight: 700;
        text-transform: uppercase;
    }
    .committee-page-shell .committee-public-stat-value {
        margin-top: 0.35rem;
        color: #0f172a;
        font-size: 1.7rem;
        line-height: 1;
        letter-spacing: -0.02em;
        font-weight: 800;
        font-family: "Playfair Display", Georgia, serif;
    }
    .committee-page-shell .committee-public-main-grid {
        align-items: start;
    }
    .committee-page-shell .event-tile {
        border: 1px solid #e2e8f0;
        border-radius: 0.9rem;
        overflow: hidden;
        transition: transform 170ms ease, box-shadow 170ms ease, border-color 170ms ease;
    }
    .committee-page-shell .event-tile:hover {
        transform: translateY(-2px);
        border-color: #bfdbfe;
        box-shadow: 0 14px 30px rgba(37, 99, 235, 0.11);
    }
    .committee-page-shell .committee-public-event-date {
        min-width: 3rem;
    }
    .committee-page-shell .post-tile {
        border: 1px solid #e2e8f0;
        border-radius: 0.9rem;
        background: #f8fafc;
    }
    .committee-page-shell .committee-public-post {
        border-color: #dbe4ef;
    }
    .committee-page-shell .committee-public-member-row {
        transition: border-color 170ms ease, box-shadow 170ms ease, transform 170ms ease;
    }
    .committee-page-shell .committee-public-member-row:hover {
        border-color: #bfdbfe;
        box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
        transform: translateY(-1px);
    }
    @media (max-width: 1279px) {
        .committee-page-shell .committee-public-stat-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }
    }
    @media (max-width: 1023px) {
        .committee-page-shell .committee-public-content {
            margin-top: -3.2rem;
        }
    }
    @media (max-width: 767px) {
        .committee-page-shell .committee-public-content {
            margin-top: -2.6rem;
        }
        .committee-page-shell .committee-public-stat-card {
            padding: 0.85rem 0.9rem;
        }
        .committee-page-shell .committee-public-stat-value {
            font-size: 1.45rem;
        }
    }
    @media (max-width: 479px) {
        .committee-page-shell .committee-public-stat-grid {
            grid-template-columns: 1fr;
        }
    }
/* --- END: pages/committee.php --- */

/* --- BEGIN: pages/course-page.php --- */

                @keyframes scroll-left {
                    0% {
                        transform: translateX(0);
                    }
                    100% {
                        transform: translateX(-100%);
                    }
                }
                
                .scroll-container {
                    display: flex;
                    animation: scroll-left 30s linear infinite;
                    width: calc(200% + 20px);
                }
                
                .scroll-container:hover {
                    animation-play-state: paused;
                }
                
                .student-card {
                    flex: 0 0 auto;
                    margin-right: 15px;
                }
                
                /* Mobile responsive sizes */
                @media (max-width: 640px) {
                    .student-card {
                        width: 80px;
                        margin-right: 12px;
                    }
                    
                    .scroll-container {
                        animation: scroll-left 25s linear infinite;
                    }
                }
                
                @media (min-width: 641px) and (max-width: 1023px) {
                    .student-card {
                        width: 110px;
                        margin-right: 18px;
                    }
                }
                
                /* Desktop sizes */
                @media (min-width: 1024px) {
                    .student-card {
                        width: 140px;
                        margin-right: 24px;
                    }
                    
                    .scroll-container {
                        animation: scroll-left 35s linear infinite;
                    }
                }
            
/* --- END: pages/course-page.php --- */

/* --- BEGIN: pages/create-event.php --- */

    .event-create-shell .event-form > div.mb-8 {
        border-bottom: 1px dashed #e2e8f0;
        padding-bottom: 1.35rem;
    }
    .event-create-shell .event-form > div.mb-8:last-of-type {
        border-bottom: none;
        padding-bottom: 0;
    }
    .event-create-shell .event-form h2 {
        font-size: 1.05rem;
        font-weight: 800;
        color: #0f172a;
        border-bottom-color: #e2e8f0;
    }
    .event-create-shell .event-form h3 {
        color: #1e293b;
    }
    .event-create-shell .event-form label {
        color: #334155;
        font-weight: 600;
    }
    .event-create-shell .event-form input[type="text"],
    .event-create-shell .event-form input[type="email"],
    .event-create-shell .event-form input[type="url"],
    .event-create-shell .event-form input[type="tel"],
    .event-create-shell .event-form input[type="number"],
    .event-create-shell .event-form input[type="datetime-local"],
    .event-create-shell .event-form select,
    .event-create-shell .event-form textarea {
        border-radius: 0.75rem;
        border-color: #cbd5e1;
        background: #ffffff;
        transition: border-color 160ms ease, box-shadow 160ms ease;
    }
    .event-create-shell .event-form input:focus,
    .event-create-shell .event-form select:focus,
    .event-create-shell .event-form textarea:focus {
        border-color: #3b82f6;
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
    }
    .event-create-shell .event-form input[type="file"] {
        border-radius: 0.75rem;
        border: 1px dashed #bfdbfe;
        background: #f8fafc;
        padding: 0.55rem 0.7rem;
    }
/* --- END: pages/create-event.php --- */

/* --- BEGIN: pages/dashboard.php --- */

    .dashboard-shell .dashboard-glass {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    }
    .dashboard-shell #tabs {
        display: flex;
        flex-wrap: nowrap;
        gap: 0.5rem;
        padding: 0.75rem;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        scroll-behavior: smooth;
        overscroll-behavior-x: contain;
        touch-action: pan-x pan-y;
    }
    .dashboard-shell #tabs::-webkit-scrollbar {
        height: 8px;
    }
    .dashboard-shell #tabs::-webkit-scrollbar-thumb {
        background: #cbd5e1;
        border-radius: 9999px;
    }
    .dashboard-shell #tabs::-webkit-scrollbar-track {
        background: transparent;
    }
    .dashboard-shell .tab-item {
        display: inline-flex;
        flex: 0 0 auto;
        align-items: center;
        white-space: nowrap;
        border-radius: 0.75rem;
        border: 1px solid transparent;
        padding: 0.6rem 0.9rem;
        color: #475569;
        font-size: 0.84rem;
        font-weight: 600;
        line-height: 1.2;
        transition: all 160ms ease;
    }
    .dashboard-shell .tab-item:hover {
        background: #f1f5f9;
        color: #0f172a;
    }
    .dashboard-shell .tab-item.is-active {
        background: #2563eb;
        border-color: #2563eb;
        color: #ffffff;
        box-shadow: 0 8px 20px rgba(37, 99, 235, 0.25);
    }
    .dashboard-shell .tab-item .tab-badge {
        margin-left: 0.4rem;
        border-radius: 9999px;
        padding: 0.05rem 0.45rem;
        font-size: 0.68rem;
        font-weight: 700;
        line-height: 1.25;
        background: #e2e8f0;
        color: #334155;
    }
    .dashboard-shell .tab-item.is-active .tab-badge {
        background: rgba(255, 255, 255, 0.2);
        color: #ffffff;
    }
    .dashboard-shell .tab-content .overflow-x-auto {
        overflow-x: auto;
        overflow-y: visible;
        -webkit-overflow-scrolling: touch;
        touch-action: pan-x pan-y;
        overscroll-behavior-x: contain;
        scrollbar-width: thin;
        border: 1px solid #e2e8f0;
        border-radius: 0.9rem;
        background: #ffffff;
    }
    .dashboard-shell .tab-content .overflow-auto {
        overflow: auto;
        -webkit-overflow-scrolling: touch;
        touch-action: pan-x pan-y;
        overscroll-behavior-x: contain;
        scrollbar-width: thin;
    }
    .dashboard-shell .tab-content .overflow-x-auto > table,
    .dashboard-shell .tab-content .overflow-auto > table {
        min-width: 46rem;
    }
    @media (min-width: 1024px) {
        .dashboard-shell .tab-content .overflow-x-auto > table,
        .dashboard-shell .tab-content .overflow-auto > table {
            min-width: 100%;
        }
    }
    .dashboard-shell .tab-content table thead {
        background: #f8fafc;
    }
    .dashboard-shell .tab-content table th {
        color: #64748b;
    }
    .dashboard-shell .tab-content .text-center.py-8 {
        border: 1px dashed #cbd5e1;
        border-radius: 0.9rem;
        background: #f8fafc;
    }
    .dashboard-shell .open-tab-trigger {
        border-radius: 0.65rem;
    }
/* --- END: pages/dashboard.php --- */

/* --- BEGIN: pages/edit-event.php --- */

    .event-edit-shell .ui-card {
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        background: #ffffff;
        box-shadow: 0 8px 22px rgba(15, 23, 42, 0.05);
    }
    .event-edit-shell .event-form > div.mb-8 {
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        background: #ffffff;
        padding: 1rem;
        margin-bottom: 1rem;
    }
    @media (min-width: 640px) {
        .event-edit-shell .event-form > div.mb-8 {
            padding: 1.25rem;
            margin-bottom: 1.25rem;
        }
    }
    .event-edit-shell .event-form h2 {
        font-size: 1.05rem;
        font-weight: 800;
        color: #0f172a;
        border-bottom-color: #e2e8f0;
    }
    .event-edit-shell .event-form h3 {
        color: #1e293b;
    }
    .event-edit-shell .event-form label {
        color: #334155;
        font-weight: 600;
    }
    .event-edit-shell .event-form input[type="text"],
    .event-edit-shell .event-form input[type="email"],
    .event-edit-shell .event-form input[type="url"],
    .event-edit-shell .event-form input[type="tel"],
    .event-edit-shell .event-form input[type="number"],
    .event-edit-shell .event-form input[type="datetime-local"],
    .event-edit-shell .event-form select,
    .event-edit-shell .event-form textarea {
        border-radius: 0.75rem;
        border-color: #cbd5e1;
        background: #ffffff;
        transition: border-color 160ms ease, box-shadow 160ms ease;
    }
    .event-edit-shell .event-form input:focus,
    .event-edit-shell .event-form select:focus,
    .event-edit-shell .event-form textarea:focus {
        border-color: #3b82f6;
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
    }
    .event-edit-shell .event-form input[type="file"] {
        border-radius: 0.75rem;
        border: 1px dashed #bfdbfe;
        background: #f8fafc;
        padding: 0.55rem 0.7rem;
    }
/* --- END: pages/edit-event.php --- */

/* --- BEGIN: pages/manage-members.php --- */

    .manage-members-shell .member-row {
        transition: background-color 160ms ease;
    }
    .manage-members-shell .member-row:hover {
        background: #f8fafc;
    }
    .manage-members-shell .input-control {
        border-radius: 0.75rem;
        border: 1px solid #cbd5e1;
        background: #ffffff;
    }
    .manage-members-shell .input-control:focus {
        border-color: #3b82f6;
        box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.14);
        outline: none;
    }
/* --- END: pages/manage-members.php --- */

/* --- BEGIN: pages/messages.php --- */

    .messages-shell {
        --messages-border: #e2e8f0;
        --messages-primary: #2563eb;
    }
    .messages-shell .messages-app-shell {
        min-height: calc(100vh - 7.5rem);
    }
    .messages-shell .messages-glass {
        background: #ffffff;
        border: 1px solid var(--messages-border);
        border-radius: 1.1rem;
        box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
    }
    .messages-shell .conversations-header {
        position: sticky;
        top: 0;
        z-index: 6;
        background: rgba(255, 255, 255, 0.95);
        backdrop-filter: blur(6px);
    }
    .messages-shell .conversation-scroll {
        max-height: calc(100vh - 15rem);
        overflow-y: auto;
        overscroll-behavior: contain;
    }
    .messages-shell .chat-panel {
        min-height: calc(100vh - 13rem);
    }
    .messages-shell .chat-topbar {
        backdrop-filter: blur(8px);
    }
    .messages-shell .message-scroll {
        max-height: calc(100vh - 18rem);
        overflow-y: auto;
        overscroll-behavior: contain;
        scroll-behavior: smooth;
        background:
            radial-gradient(circle at 12% 18%, rgba(59, 130, 246, 0.08), transparent 36%),
            radial-gradient(circle at 88% 0%, rgba(14, 165, 233, 0.07), transparent 32%),
            #f8fafc;
    }
    .messages-shell .composer-wrap {
        padding-bottom: calc(0.75rem + env(safe-area-inset-bottom));
    }
    .messages-shell #message-input {
        min-height: 44px;
        max-height: 150px;
        resize: none;
    }
    .messages-shell .conversation-item {
        border-left: 3px solid transparent;
        transition: background-color 140ms ease, border-color 140ms ease;
    }
    .messages-shell .conversation-item:hover {
        background: #f8fafc;
        border-left-color: #cbd5e1;
    }
    .messages-shell .conversation-item.active {
        background: #eff6ff;
        border-left-color: var(--messages-primary);
    }
    .messages-shell .message-row {
        display: flex;
    }
    .messages-shell .message-row.hidden {
        display: none;
    }
    .messages-shell .message-row.group-start {
        margin-top: 0.55rem;
    }
    .messages-shell #messages-stack .message-row:first-child {
        margin-top: 0;
    }
    .messages-shell .message-row.self {
        justify-content: flex-end;
    }
    .messages-shell .message-row.other {
        justify-content: flex-start;
    }
    .messages-shell .message-content {
        max-width: min(82%, 35rem);
    }
    .messages-shell .message-meta {
        display: flex;
        align-items: center;
        margin-bottom: 0.2rem;
    }
    .messages-shell .message-row.other:not(.group-start) .message-meta {
        display: none;
    }
    .messages-shell .message-time {
        line-height: 1;
    }
    .messages-shell .message-row:not(.group-end) .message-time {
        display: none;
    }
    .messages-shell .message-bubble {
        border-radius: 1rem;
        padding: 0.64rem 0.82rem;
        font-size: 0.9rem;
        line-height: 1.42;
        word-wrap: break-word;
    }
    .messages-shell .message-bubble.self {
        background: linear-gradient(135deg, #2563eb, #1d4ed8);
        color: #ffffff;
        box-shadow: 0 8px 18px rgba(37, 99, 235, 0.22);
    }
    .messages-shell .message-bubble.other {
        background: #ffffff;
        color: #1e293b;
        border: 1px solid #dbe1ea;
        box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
    }
    .messages-shell .message-row.self:not(.group-start) .message-bubble {
        border-top-right-radius: 0.38rem;
    }
    .messages-shell .message-row.self:not(.group-end) .message-bubble {
        border-bottom-right-radius: 0.38rem;
    }
    .messages-shell .message-row.other:not(.group-start) .message-bubble {
        border-top-left-radius: 0.38rem;
    }
    .messages-shell .message-row.other:not(.group-end) .message-bubble {
        border-bottom-left-radius: 0.38rem;
    }
    .messages-shell .typing-dot {
        display: inline-block;
        width: 7px;
        height: 7px;
        border-radius: 50%;
        margin-right: 5px;
        background-color: #64748b;
        animation: typing-animation 1.2s infinite ease-in-out both;
    }
    .messages-shell .typing-dot:nth-child(1) { animation-delay: 0s; }
    .messages-shell .typing-dot:nth-child(2) { animation-delay: 0.2s; }
    .messages-shell .typing-dot:nth-child(3) { animation-delay: 0.4s; }

    @media (max-width: 1023px) {
        .messages-shell {
            padding-left: 0;
            padding-right: 0;
            padding-top: 0;
            padding-bottom: 0;
        }
        .messages-shell .messages-app-shell {
            min-height: calc(100vh - 64px);
        }
        .messages-shell .messages-glass {
            border-radius: 0;
            border-left: 0;
            border-right: 0;
            box-shadow: none;
        }
        .messages-shell .conversation-scroll {
            max-height: calc(100vh - 226px);
        }
        .messages-shell .chat-panel {
            min-height: calc(100vh - 64px);
        }
        .messages-shell .message-scroll {
            max-height: calc(100vh - 205px);
        }
        .messages-shell.mobile-chat-open .conversations-panel {
            display: none;
        }
        .messages-shell.mobile-chat-open .chat-panel {
            display: flex;
        }
        .messages-shell:not(.mobile-chat-open) .chat-panel {
            display: none;
        }
    }

    @keyframes typing-animation {
        0%, 80%, 100% {
            transform: scale(0.6);
            opacity: 0.55;
        }
        40% {
            transform: scale(1);
            opacity: 1;
        }
    }
/* --- END: pages/messages.php --- */

/* --- BEGIN: pages/progress.php --- */

    .progress-shell .metric-tile {
        border: 1px solid #dbeafe;
        border-radius: 0.9rem;
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    }
    .progress-shell .activity-dot {
        width: 0.72rem;
        height: 0.72rem;
        border-radius: 0.2rem;
    }
/* --- END: pages/progress.php --- */

/* --- BEGIN: pages/random-chat.php --- */

    .rc-native-app {
        --rc-viewport-height: 100dvh;
        min-height: calc(var(--rc-viewport-height) - 64px);
        max-width: 1180px;
        margin: 0 auto;
        padding: 0.9rem;
    }

    .rc-native-shell {
        border: 1px solid #dbe5f4;
        border-radius: 1.1rem;
        background: #ffffff;
        box-shadow: 0 16px 42px rgba(15, 23, 42, 0.07);
        overflow: hidden;
    }

    .rc-native-header {
        display: grid;
        grid-template-columns: 1.25fr minmax(280px, 420px);
        gap: 1rem;
        border-bottom: 1px solid #e2e8f0;
        background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
        padding: 1rem 1rem 0.95rem;
    }

    .rc-native-copy {
        min-width: 0;
    }

    .rc-native-pill {
        display: inline-flex;
        align-items: center;
        border-radius: 999px;
        border: 1px solid #c5d7f5;
        background: #edf4ff;
        color: #1e3a8a;
        padding: 0.25rem 0.65rem;
        font-size: 0.72rem;
        line-height: 1;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 0.04em;
        margin-bottom: 0.55rem;
    }

    .rc-native-title {
        margin: 0;
        font-size: clamp(1.35rem, 1.22rem + 0.36vw, 1.75rem);
        line-height: 1.2;
        color: #0f172a;
    }

    .rc-native-subtitle {
        margin: 0.55rem 0 0;
        color: #475569;
        font-size: 0.97rem;
        max-width: 62ch;
    }

    .rc-native-pulse {
        border: 1px solid #dbe5f4;
        border-radius: 0.95rem;
        background: #f8fbff;
        padding: 0.75rem;
    }

    .rc-pulse-grid {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.55rem;
    }

    .rc-pulse-card {
        border: 1px solid #d6e4f8;
        border-radius: 0.75rem;
        background: #ffffff;
        padding: 0.55rem 0.65rem;
        display: flex;
        flex-direction: column;
        gap: 0.15rem;
    }

    .rc-pulse-card span {
        font-size: 0.74rem;
        color: #64748b;
        line-height: 1.1;
    }

    .rc-pulse-card strong {
        font-size: 1.1rem;
        line-height: 1.1;
        color: #0f172a;
    }

    .rc-pulse-meta {
        margin: 0.55rem 0 0;
        font-size: 0.72rem;
        color: #64748b;
    }

    .rc-chat-shell {
        border-top: none;
        border-radius: 0 0 1.05rem 1.05rem;
        background: #ffffff;
        overflow: hidden;
        min-height: min(780px, calc(var(--rc-viewport-height) - 220px));
    }

    .rc-state {
        min-height: min(720px, calc(var(--rc-viewport-height) - 240px));
        background: #ffffff;
    }

    .rc-live-notice {
        margin: 0.78rem 0.78rem 0;
        padding: 0.58rem 0.72rem;
        border: 1px solid #dbe5f4;
        border-radius: 0.72rem;
        font-size: 0.8rem;
        line-height: 1.4;
        font-weight: 600;
    }

    .rc-live-notice-blue {
        color: #1e3a8a;
        background: #eff6ff;
        border-color: #c7dcff;
    }

    .rc-live-notice-green {
        color: #14532d;
        background: #f0fdf4;
        border-color: #bbf7d0;
    }

    .rc-live-notice-amber {
        color: #854d0e;
        background: #fffbeb;
        border-color: #fde68a;
    }

    .rc-live-notice-red {
        color: #991b1b;
        background: #fef2f2;
        border-color: #fecaca;
    }

    .rc-state-landing {
        padding: 1rem;
    }

    .rc-landing-grid {
        display: grid;
        grid-template-columns: minmax(0, 1fr) minmax(300px, 430px);
        gap: 1rem;
        min-height: 100%;
    }

    .rc-landing-visual {
        border: 1px solid #dbe5f4;
        border-radius: 0.95rem;
        background: linear-gradient(160deg, #f8fbff 0%, #ffffff 100%);
        padding: 1rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 0.85rem;
    }

    .rc-landing-poster {
        width: min(100%, 360px);
        border-radius: 1rem;
        box-shadow: 0 16px 40px rgba(15, 23, 42, 0.16);
        border: 1px solid #dbe5f4;
    }

    .rc-landing-points {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.5rem;
    }

    .rc-chip {
        border: 1px solid #d5e4fa;
        border-radius: 999px;
        background: #ffffff;
        color: #1e3a8a;
        font-size: 0.75rem;
        padding: 0.34rem 0.7rem;
        font-weight: 700;
    }

    .rc-landing-action {
        border: 1px solid #dbe5f4;
        border-radius: 0.95rem;
        background: #ffffff;
        padding: 1rem;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 0.8rem;
    }

    .rc-landing-action h2 {
        margin: 0;
        font-size: 1.35rem;
        color: #0f172a;
    }

    .rc-landing-action p {
        margin: 0;
        color: #475569;
        line-height: 1.58;
    }

    .rc-primary-action {
        border: none;
        border-radius: 0.85rem;
        background: linear-gradient(135deg, #2456f5 0%, #1d4ed8 100%);
        color: #ffffff;
        font-weight: 700;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.45rem;
        min-height: 46px;
        padding: 0.75rem 1rem;
        box-shadow: 0 10px 20px rgba(37, 99, 235, 0.24);
        transition: transform 140ms ease, box-shadow 140ms ease;
    }

    .rc-primary-action:hover {
        transform: translateY(-1px);
        box-shadow: 0 14px 24px rgba(37, 99, 235, 0.25);
    }

    [data-rc-start="1"].rc-start-disabled,
    [data-rc-start="1"]:disabled {
        opacity: 0.66;
        cursor: not-allowed;
        pointer-events: none;
    }

    .rc-primary-action.rc-start-disabled,
    .rc-primary-action:disabled {
        transform: none;
        box-shadow: 0 8px 16px rgba(37, 99, 235, 0.15);
    }

    .rc-micro-notes {
        display: flex;
        flex-direction: column;
        gap: 0.45rem;
        font-size: 0.84rem;
        color: #475569;
    }

    .rc-micro-notes span {
        border: 1px solid #e2e8f0;
        border-radius: 0.7rem;
        background: #f8fafc;
        padding: 0.45rem 0.65rem;
    }

    .rc-search-shell {
        min-height: inherit;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        text-align: center;
        padding: 1.5rem;
        gap: 0.55rem;
    }

    .rc-search-shell h3 {
        margin: 0;
        font-size: 1.35rem;
        color: #0f172a;
    }

    .rc-search-shell p {
        margin: 0;
        color: #64748b;
    }

    .rc-search-indicator {
        width: 72px;
        height: 72px;
        border-radius: 999px;
        background: #eef4ff;
        border: 1px solid #d5e4fa;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0.4rem;
        margin-bottom: 0.45rem;
    }

    .rc-search-indicator span {
        width: 8px;
        height: 8px;
        border-radius: 999px;
        background: #2456f5;
        opacity: 0.35;
        animation: rc-search-pulse 1.2s infinite ease-in-out;
    }

    .rc-search-indicator span:nth-child(2) {
        animation-delay: 0.16s;
    }

    .rc-search-indicator span:nth-child(3) {
        animation-delay: 0.32s;
    }

    @keyframes rc-search-pulse {
        0%, 80%, 100% {
            transform: translateY(0) scale(0.8);
            opacity: 0.3;
        }
        40% {
            transform: translateY(-2px) scale(1);
            opacity: 1;
        }
    }

    .rc-search-timer {
        font-size: clamp(2rem, 1.8rem + 1vw, 2.75rem);
        font-weight: 800;
        color: #1d4ed8;
        line-height: 1;
    }

    .rc-search-timer.rc-timer-danger {
        color: #b45309;
    }

    .rc-search-tip {
        border: 1px solid #dbe5f4;
        border-radius: 0.8rem;
        background: #f8fbff;
        padding: 0.6rem 0.75rem;
        max-width: 520px;
    }

    .rc-link-action {
        border: none;
        background: transparent;
        color: #64748b;
        font-weight: 700;
        text-decoration: underline;
        text-underline-offset: 3px;
        cursor: pointer;
    }

    .rc-hidden {
        display: none !important;
    }

    .rc-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;
    }

    .rc-icon-20 {
        width: 20px;
        height: 20px;
    }

    .rc-mono {
        font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    }

    .rc-chatting-shell {
        display: flex;
        flex-direction: column;
        height: min(760px, calc(var(--rc-viewport-height) - 240px));
    }

    .rc-chat-topbar {
        border-bottom: 1px solid #e2e8f0;
        background: #ffffff;
        padding: 0.78rem 0.95rem;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0.75rem;
        flex-wrap: wrap;
    }

    .rc-partner-meta {
        display: inline-flex;
        align-items: center;
        gap: 0.65rem;
        min-width: 0;
    }

    .rc-partner-copy {
        min-width: 0;
    }

    .rc-partner-row {
        display: inline-flex;
        align-items: center;
        gap: 0.38rem;
    }

    .rc-avatar-shell {
        position: relative;
        width: 40px;
        height: 40px;
        border-radius: 999px;
        background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
        border: 1px solid #dbeafe;
        display: grid;
        place-items: center;
    }

    .rc-avatar-shell i {
        position: absolute;
        bottom: 0;
        right: 0;
        width: 10px;
        height: 10px;
        border-radius: 999px;
        background: #22c55e;
        border: 2px solid #ffffff;
    }

    .rc-partner-name {
        font-size: 1rem;
        line-height: 1.2;
        font-weight: 700;
        color: #0f172a;
    }

    .rc-partner-subline {
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
        font-size: 0.76rem;
        color: #64748b;
    }

    .rc-status-online {
        color: #1d4ed8;
        font-weight: 600;
    }

    .rc-pill-dark {
        font-size: 0.63rem;
        line-height: 1;
        font-weight: 800;
        text-transform: uppercase;
        color: #ffffff;
        border-radius: 999px;
        background: #111827;
        padding: 0.2rem 0.45rem;
    }

    .rc-top-actions {
        display: inline-flex;
        align-items: center;
        gap: 0.45rem;
    }

    .rc-secondary-action {
        border: 1px solid #cbd5e1;
        border-radius: 0.7rem;
        background: #ffffff;
        color: #1e3a8a;
        font-size: 0.84rem;
        font-weight: 700;
        min-height: 36px;
        padding: 0.45rem 0.75rem;
        transition: background-color 120ms ease;
    }

    .rc-secondary-action:hover {
        background: #eff6ff;
    }

    .rc-icon-action {
        border: 1px solid #e2e8f0;
        background: #ffffff;
        color: #64748b;
        border-radius: 0.7rem;
        min-height: 36px;
        min-width: 36px;
        display: inline-grid;
        place-items: center;
    }

    .rc-icon-action:hover {
        color: #dc2626;
        background: #fef2f2;
    }

    .rc-chat-area {
        flex: 1;
        min-height: 0;
        overflow-y: auto;
        padding: 0.9rem;
        display: flex;
        flex-direction: column;
        gap: 0.65rem;
        background-color: #f8fafc;
        background-image: radial-gradient(#e2e8f0 1px, transparent 1px);
        background-size: 16px 16px;
    }

    .rc-message {
        max-width: 88%;
        margin-bottom: 0.35rem;
        animation: rc-message-slide 0.18s ease-out;
    }

    .rc-message-bubble {
        padding: 0.72rem 0.82rem;
        border-radius: 1rem;
        box-shadow: 0 6px 18px rgba(15, 23, 42, 0.09);
        word-break: break-word;
    }

    .rc-message-self {
        margin-left: auto;
        background: linear-gradient(140deg, #2563eb 0%, #1d4ed8 100%);
        color: #ffffff;
        border-top-right-radius: 0.42rem;
    }

    .rc-message-other {
        background: #ffffff;
        border: 1px solid #e2e8f0;
        color: #0f172a;
        border-top-left-radius: 0.42rem;
    }

    .rc-message-content {
        white-space: pre-wrap;
        font-size: 0.92rem;
        line-height: 1.52;
    }

    .rc-message-time {
        font-size: 0.62rem;
        margin-top: 0.2rem;
    }

    .rc-message-time-self {
        color: rgba(255, 255, 255, 0.84);
        text-align: right;
    }

    .rc-message-time-other {
        color: #94a3b8;
    }

    @keyframes rc-message-slide {
        from {
            opacity: 0;
            transform: translateY(8px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    .rc-typing {
        border-top: 1px solid #e2e8f0;
        padding: 0.38rem 0.95rem;
        background: #ffffff;
        display: inline-flex;
        align-items: center;
        gap: 0.35rem;
        font-size: 0.72rem;
        color: #64748b;
    }

    .rc-typing-dot {
        width: 6px;
        height: 6px;
        background: #94a3b8;
        border-radius: 999px;
        animation: rc-typing-pop 1.35s infinite ease-in-out;
    }

    .rc-typing-dot:nth-child(3) {
        animation-delay: 0.18s;
    }

    .rc-typing-dot:nth-child(4) {
        animation-delay: 0.36s;
    }

    @keyframes rc-typing-pop {
        0%, 80%, 100% {
            transform: translateY(0);
            opacity: 0.3;
        }
        40% {
            transform: translateY(-2px);
            opacity: 1;
        }
    }

    .rc-input-area {
        border-top: 1px solid #e2e8f0;
        background: #ffffff;
        padding: 0.7rem 0.95rem calc(0.7rem + env(safe-area-inset-bottom));
    }

    .rc-quick-prompts {
        display: flex;
        flex-wrap: wrap;
        gap: 0.45rem;
        margin-bottom: 0.58rem;
    }

    .rc-quick-chip {
        border: 1px solid #d1d9e8;
        border-radius: 999px;
        background: #f8fafc;
        color: #1e3a8a;
        font-size: 0.72rem;
        font-weight: 700;
        padding: 0.34rem 0.62rem;
        line-height: 1.2;
        cursor: pointer;
        transition: border-color 120ms ease, background-color 120ms ease, color 120ms ease;
    }

    .rc-quick-chip:hover {
        border-color: #93c5fd;
        background: #eff6ff;
        color: #1d4ed8;
    }

    .rc-input-area form {
        position: relative;
        display: flex;
        align-items: center;
    }

    .rc-input-area .ui-input,
    .rc-input-field {
        width: 100%;
        min-height: 46px;
        border: 1px solid #cbd5e1;
        border-radius: 0.8rem;
        background: #f8fafc;
        color: #0f172a;
        padding: 0.72rem 3rem 0.72rem 0.95rem;
        outline: none;
        transition: border-color 120ms ease, box-shadow 120ms ease, background-color 120ms ease;
    }

    .rc-input-area .ui-input:focus,
    .rc-input-field:focus {
        border-color: #2456f5;
        background: #ffffff;
        box-shadow: 0 0 0 3px rgba(36, 86, 245, 0.12);
    }

    .rc-send-btn {
        position: absolute;
        right: 0.42rem;
        top: 50%;
        transform: translateY(-50%);
        border: none;
        border-radius: 0.65rem;
        width: 36px;
        height: 36px;
        display: inline-grid;
        place-items: center;
        background: #2456f5;
        color: #ffffff;
        cursor: pointer;
    }

    .rc-send-btn:hover {
        background: #1d4ed8;
    }

    .rc-send-btn.rc-btn-disabled,
    .rc-send-btn:disabled {
        opacity: 0.55;
        cursor: not-allowed;
    }

    .rc-input-hint {
        margin: 0.44rem 0 0;
        font-size: 0.72rem;
        color: #64748b;
    }

    .rc-disconnected-shell {
        min-height: inherit;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0.7rem;
        padding: 1.2rem;
        text-align: center;
    }

    .rc-disconnected-icon {
        width: 58px;
        height: 58px;
        border-radius: 999px;
        border: 1px solid #dbe5f4;
        background: #f8fbff;
        display: grid;
        place-items: center;
        font-size: 1.5rem;
    }

    .rc-disconnected-shell h2 {
        margin: 0;
        font-size: 1.2rem;
        color: #0f172a;
    }

    .rc-disconnected-shell p {
        margin: 0;
        color: #64748b;
    }

    .rc-disconnected-actions {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.6rem;
        margin-top: 0.2rem;
    }

    .rc-system-wrap {
        text-align: center;
        padding: 0.2rem 0;
    }

    .rc-system-badge {
        display: inline-block;
        padding: 0.3rem 0.6rem;
        border-radius: 999px;
        border: 1px solid #e2e8f0;
        background: #f8fafc;
        color: #475569;
        font-size: 0.7rem;
        font-weight: 600;
    }

    .rc-caret::after {
        content: '';
        display: inline-block;
        width: 2px;
        height: 1em;
        margin-left: 2px;
        background: rgba(148, 163, 184, 0.95);
        animation: rc-blink 1s steps(1) infinite;
        vertical-align: -2px;
    }

    @keyframes rc-blink {
        0%, 50% { opacity: 1; }
        51%, 100% { opacity: 0; }
    }

    .rc-scroll::-webkit-scrollbar {
        width: 6px;
    }

    .rc-scroll::-webkit-scrollbar-track {
        background: transparent;
    }

    .rc-scroll::-webkit-scrollbar-thumb {
        background-color: #cbd5e1;
        border-radius: 20px;
    }

    @media (max-width: 1024px) {
        .rc-native-header {
            grid-template-columns: 1fr;
        }

        .rc-landing-grid {
            grid-template-columns: 1fr;
        }

        .rc-chat-shell {
            min-height: min(860px, calc(var(--rc-viewport-height) - 190px));
        }

        .rc-state {
            min-height: min(760px, calc(var(--rc-viewport-height) - 210px));
        }
    }

    @media (max-width: 640px) {
        .rc-native-app {
            min-height: var(--rc-viewport-height);
            max-width: none;
            padding: 0;
        }

        .rc-native-shell {
            border: none;
            border-radius: 0;
            box-shadow: none;
            min-height: var(--rc-viewport-height);
            display: flex;
            flex-direction: column;
        }

        .rc-native-header {
            padding: 0.78rem 0.78rem 0.72rem;
            gap: 0.72rem;
        }

        .rc-native-subtitle {
            font-size: 0.89rem;
            line-height: 1.45;
        }

        .rc-pulse-grid {
            grid-template-columns: repeat(3, minmax(0, 1fr));
        }

        .rc-pulse-card {
            padding: 0.48rem 0.52rem;
            border-radius: 0.66rem;
        }

        .rc-pulse-card strong {
            font-size: 0.97rem;
        }

        .rc-chat-shell {
            border-radius: 0;
            min-height: 0;
            flex: 1;
        }

        .rc-state,
        .rc-chatting-shell {
            min-height: 0;
            height: 100%;
        }

        .rc-state-landing {
            padding: 0.78rem;
        }

        .rc-live-notice {
            margin: 0.65rem 0.65rem 0;
            padding: 0.5rem 0.62rem;
            font-size: 0.75rem;
        }

        .rc-landing-visual {
            padding: 0.75rem;
        }

        .rc-landing-poster {
            width: min(100%, 310px);
        }

        .rc-landing-action {
            padding: 0.82rem;
            gap: 0.64rem;
        }

        .rc-chat-topbar {
            padding: 0.62rem 0.72rem;
        }

        .rc-top-actions .rc-secondary-action {
            min-height: 34px;
            font-size: 0.79rem;
            padding: 0.4rem 0.64rem;
        }

        .rc-chat-area {
            padding: 0.72rem;
            background-size: 14px 14px;
        }

        .rc-message {
            max-width: 92%;
        }

        .rc-quick-prompts {
            gap: 0.35rem;
            margin-bottom: 0.48rem;
            overflow-x: auto;
            padding-bottom: 0.2rem;
            scrollbar-width: thin;
        }

        .rc-quick-chip {
            font-size: 0.7rem;
            padding: 0.3rem 0.55rem;
            white-space: nowrap;
        }

        .rc-input-area {
            position: sticky;
            bottom: 0;
            padding: 0.58rem 0.72rem calc(0.58rem + env(safe-area-inset-bottom));
        }

        .rc-input-area .ui-input {
            min-height: 44px;
            padding-right: 2.85rem;
        }
    }
/* --- END: pages/random-chat.php --- */

/* --- BEGIN: pages/subscription.php --- */

    .subscription-shell .sub-glass {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    }
    .subscription-shell .plan-card {
        border: 1px solid #dbeafe;
        border-radius: 1rem;
        background: #ffffff;
        transition: all 160ms ease;
    }
    .subscription-shell .plan-card:hover {
        border-color: #93c5fd;
        box-shadow: 0 14px 24px rgba(29, 78, 216, 0.08);
    }
/* --- END: pages/subscription.php --- */

/* --- BEGIN: pages/upload.php --- */

    .upload-shell .upload-glass {
        background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
    }
    .upload-shell .upload-field,
    .upload-shell .upload-select,
    .upload-shell .upload-textarea {
        width: 100%;
        border: 1px solid #cbd5e1;
        background: #f8fafc;
        border-radius: 0.75rem;
        padding: 0.65rem 0.85rem;
        color: #0f172a;
        font-size: 0.94rem;
    }
    .upload-shell .upload-field:focus,
    .upload-shell .upload-select:focus,
    .upload-shell .upload-textarea:focus {
        outline: none;
        border-color: #3b82f6;
        box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2);
        background: #ffffff;
    }
    .upload-shell .method-option {
        border: 1px solid #cbd5e1;
        background: #ffffff;
        border-radius: 0.8rem;
        padding: 0.8rem 0.9rem;
        display: flex;
        align-items: flex-start;
        gap: 0.55rem;
        cursor: pointer;
        transition: all 140ms ease;
    }
    .upload-shell .method-option:hover {
        border-color: #93c5fd;
        background: #eff6ff;
    }
    .upload-shell .method-option.active {
        border-color: #2563eb;
        background: #eff6ff;
        box-shadow: inset 0 0 0 1px #2563eb;
    }
    .upload-shell .drop-zone {
        border: 2px dashed #94a3b8;
        border-radius: 0.9rem;
        background: #f8fafc;
        padding: 1.2rem;
        text-align: center;
        transition: all 140ms ease;
    }
    .upload-shell .drop-zone:hover {
        border-color: #3b82f6;
        background: #eff6ff;
    }
    .upload-shell .drop-zone.drag-over {
        border-color: #1d4ed8;
        background: #dbeafe;
    }
/* --- END: pages/upload.php --- */

/* --- BEGIN: pages/user-profile.php --- */

    .user-profile-shell .profile-card {
        border: 1px solid #e2e8f0;
        border-radius: 1rem;
        background: #ffffff;
        box-shadow: 0 8px 22px rgba(15, 23, 42, 0.05);
    }
    .user-profile-shell .chip {
        border: 1px solid #dbeafe;
        border-radius: 999px;
        background: #eff6ff;
        color: #1d4ed8;
        padding: 0.22rem 0.7rem;
        font-size: 0.72rem;
        font-weight: 600;
    }
    .user-profile-shell .info-label {
        font-size: 0.72rem;
        text-transform: uppercase;
        letter-spacing: 0.06em;
        color: #64748b;
        font-weight: 700;
    }
/* --- END: pages/user-profile.php --- */

/* --- BEGIN: pages/blog.php --- */

    .blog-article-prose h2,
    .blog-article-prose h3,
    .blog-article-prose h4 {
        scroll-margin-top: 7.5rem;
    }
    .blog-article-prose h2 {
        margin-top: 2rem;
        margin-bottom: 0.85rem;
        font-size: 1.45rem;
        line-height: 1.3;
        font-weight: 800;
        color: #0f172a;
    }
    .blog-article-prose h3 {
        margin-top: 1.55rem;
        margin-bottom: 0.7rem;
        font-size: 1.15rem;
        line-height: 1.35;
        font-weight: 700;
        color: #0f172a;
    }
    .blog-article-prose p,
    .blog-article-prose li {
        font-size: 1.03rem;
        line-height: 1.82;
        color: #334155;
    }
    .blog-article-prose ul,
    .blog-article-prose ol {
        margin-top: 0.95rem;
        margin-bottom: 1rem;
    }
    .blog-article-prose pre {
        border-radius: 0.85rem;
        border: 1px solid #cbd5e1;
        background: #0f172a;
        color: #e2e8f0;
        padding: 1rem;
        overflow-x: auto;
    }
    .blog-article-prose blockquote {
        border-left: 4px solid #2563eb;
        border-radius: 0 0.6rem 0.6rem 0;
        background: #eff6ff;
        color: #1e3a8a;
        padding: 0.8rem 1rem;
        margin: 1.2rem 0;
    }
    .blog-article-prose a {
        color: #1d4ed8;
        font-weight: 600;
        text-decoration: underline;
        text-decoration-thickness: 1px;
        text-underline-offset: 3px;
    }
    .blog-article-prose code {
        border-radius: 0.4rem;
        background: #e2e8f0;
        color: #0f172a;
        padding: 0.15rem 0.4rem;
        font-size: 0.92em;
    }
    .blog-article-prose pre code {
        background: transparent;
        color: inherit;
        padding: 0;
    }
    .blog-toc-link.is-active {
        background: #dbeafe;
        color: #1d4ed8;
        border-color: #93c5fd;
    }
    .blog-listing-item.hidden-by-filter {
        display: none;
    }
    .blog-card-excerpt {
        display: -webkit-box;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
        overflow: hidden;
    }
    .blog-tag-pill.is-active {
        border-color: #93c5fd;
        background: #dbeafe;
        color: #1d4ed8;
    }
    @media (max-width: 768px) {
        .blog-article-prose p,
        .blog-article-prose li {
            font-size: 1rem;
        }
    }
/* --- END: pages/blog.php --- */

/* --- BEGIN: pages/campus-stream.php --- */

.mu3-home-with-shell .mu3-left {
    display: none !important;
}

.mu3-home-with-shell {
    padding: 0.5rem 0 1rem;
}

.mu3-home-with-shell .mu3-shell {
    max-width: 1080px;
}

.mu3-home-with-shell .mu3-layout {
    grid-template-columns: minmax(0, 1fr);
    grid-template-areas:
        "center"
        "right";
    gap: 0.72rem;
}

.mu3-home-with-shell .mu3-right {
    position: static;
    top: auto;
    max-height: none;
    overflow: visible;
}

@media (min-width: 1500px) {
    .mu3-home-with-shell .mu3-shell {
        max-width: 1320px;
    }

    .mu3-home-with-shell .mu3-layout {
        grid-template-columns: minmax(0, 1fr) 308px;
        grid-template-areas: "center right";
        gap: 0.82rem;
    }

    .mu3-home-with-shell .mu3-right {
        position: sticky;
        top: 0.5rem;
        max-height: calc(100vh - 1rem);
        overflow: auto;
    }
}

.mu3-home {
    --mu3-bg: #ffffff;
    --mu3-surface: #ffffff;
    --mu3-muted: #f2f6fb;
    --mu3-line: #d9e3ef;
    --mu3-ink-900: #101f33;
    --mu3-ink-700: #324865;
    --mu3-ink-500: #667f9d;
    --mu3-brand: #2563eb;
    --mu3-accent: #0ea5a4;
    min-height: 100vh;
    padding: 0.86rem clamp(0.5rem, 1.4vw, 1rem) 1.5rem;
    background: var(--mu3-bg);
    color: var(--mu3-ink-900);
    font-family: 'Manrope', 'Mulish', 'Avenir Next', 'Segoe UI', sans-serif;
}

.mu3-shell {
    max-width: 1380px;
    margin: 0 auto;
}

.mu3-layout {
    display: grid;
    grid-template-columns: 248px minmax(0, 1fr) 328px;
    grid-template-areas: "left center right";
    gap: 1rem;
    align-items: start;
}

.mu3-left {
    grid-area: left;
    position: sticky;
    top: 0.72rem;
    max-height: calc(100vh - 1.45rem);
    overflow: auto;
    padding-right: 0.08rem;
    scrollbar-width: thin;
}

.mu3-right {
    grid-area: right;
    position: sticky;
    top: 0.72rem;
    max-height: calc(100vh - 1.45rem);
    overflow: auto;
    display: grid;
    gap: 0.62rem;
    scrollbar-width: thin;
}

.mu3-brand {
    display: inline-flex;
    align-items: center;
    gap: 0.56rem;
    text-decoration: none;
    margin-bottom: 0.6rem;
}

.mu3-brand-mark {
    width: 2rem;
    height: 2rem;
    border-radius: 0.64rem;
    background: #ffffff;
    border: 1px solid #d9e3ef;
    box-shadow: none;
    color: #2a55af;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.mu3-brand-mark img {
    width: 100%;
    height: 100%;
    border-radius: inherit;
    object-fit: cover;
    display: block;
}

.mu3-brand-title {
    margin: 0;
    font-size: 1.02rem;
    line-height: 1.08;
    font-weight: 800;
    color: #1a4ca6;
}

.mu3-brand-sub {
    margin: 0.06rem 0 0;
    font-size: 0.66rem;
    color: var(--mu3-ink-500);
}

.mu3-menu {
    display: grid;
    gap: 0.18rem;
}

.mu3-menu a {
    display: block;
    text-decoration: none;
    border: 1px solid transparent;
    border-radius: 0.7rem;
    padding: 0.47rem 0.56rem;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: capitalize;
    color: var(--mu3-ink-700);
    transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease;
}

.mu3-menu a:hover {
    border-color: #d4e0ef;
    background: #eef4fb;
    color: #1f4f9d;
}

.mu3-menu a.mu3-active {
    border-color: #c7d9f2;
    background: #e8f1ff;
    color: #174899;
}

.mu3-left-card {
    margin-top: 0.58rem;
    border: 1px solid var(--mu3-line);
    border-radius: 0.84rem;
    background: var(--mu3-surface);
    padding: 0.54rem;
}

.mu3-left-card h3 {
    margin: 0;
    font-size: 0.78rem;
    font-weight: 800;
}

.mu3-left-card p {
    margin: 0.18rem 0 0;
    font-size: 0.65rem;
    line-height: 1.38;
    color: var(--mu3-ink-500);
}

.mu3-topic-list,
.mu3-link-list {
    margin: 0.44rem 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.25rem;
}

.mu3-topic-list a,
.mu3-link-list a {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.38rem;
    text-decoration: none;
    border: 1px solid #d6e2f0;
    border-radius: 999px;
    padding: 0.22rem 0.42rem;
    background: #fbfdff;
    color: #2d4e7a;
    font-size: 0.64rem;
    font-weight: 700;
}

.mu3-topic-list strong {
    color: #1d4e96;
    font-size: 0.62rem;
}

.mu3-module-grid {
    margin-top: 0.42rem;
    display: grid;
    gap: 0.32rem;
}

.mu3-module {
    border: 1px solid #dae4f0;
    border-radius: 0.7rem;
    background: #fbfdff;
    padding: 0.41rem;
}

.mu3-module h4 {
    margin: 0;
    font-size: 0.69rem;
    font-weight: 800;
    text-transform: capitalize;
}

.mu3-module p {
    margin: 0.14rem 0 0;
    font-size: 0.62rem;
    line-height: 1.35;
    color: var(--mu3-ink-500);
}

.mu3-module-links {
    margin-top: 0.26rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.2rem;
}

.mu3-module-links a {
    text-decoration: none;
    border-radius: 999px;
    border: 1px solid #d7e3ef;
    padding: 0.16rem 0.32rem;
    color: #284d79;
    font-size: 0.61rem;
    font-weight: 700;
    background: #ffffff;
}

.mu3-left-foot {
    margin-top: 0.58rem;
    padding-top: 0.46rem;
    border-top: 1px solid var(--mu3-line);
    display: flex;
    flex-wrap: wrap;
    gap: 0.24rem;
}

.mu3-left-foot a {
    text-decoration: none;
    border-radius: 999px;
    border: 1px solid #d8e3ef;
    padding: 0.15rem 0.32rem;
    color: var(--mu3-ink-500);
    font-size: 0.61rem;
    background: #ffffff;
}

.mu3-center {
    grid-area: center;
    min-width: 0;
    border-left: 1px solid var(--mu3-line);
    border-right: 1px solid var(--mu3-line);
    padding: 0 0.84rem;
}

.mu3-stream-head {
    position: sticky;
    top: 0.72rem;
    z-index: 18;
    border: 1px solid var(--mu3-line);
    border-radius: 0.9rem 0.9rem 0 0;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(8px);
    padding: 0.74rem 0.86rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.6rem;
}

.mu3-stream-head h1 {
    margin: 0;
    font-size: 1.12rem;
    line-height: 1.2;
    font-weight: 800;
}

.mu3-stream-head p {
    margin: 0.2rem 0 0;
    font-size: 0.75rem;
    color: var(--mu3-ink-500);
}

.mu3-head-actions {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 0.3rem;
}

.mu3-pill,
.mu3-search,
.mu3-auth-btn {
    text-decoration: none;
    border: 1px solid #d6e2ef;
    border-radius: 999px;
    background: #ffffff;
    color: #2b4e79;
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.32rem 0.54rem;
}

.mu3-pill.mu3-pill-active {
    background: #eaf2ff;
    border-color: #c8daf2;
    color: #184a99;
}

.mu3-search {
    background: #f6f9fd;
}

.mu3-auth-btn.mu3-auth-main {
    background: #103f82;
    border-color: #103f82;
    color: #ffffff;
}

.mu3-timeline {
    border: 1px solid var(--mu3-line);
    border-top: none;
    border-radius: 0 0 0.95rem 0.95rem;
    background: var(--mu3-surface);
    overflow: hidden;
}

.mu3-timeline > .mu3-hero,
.mu3-timeline > .mu3-card {
    margin: 0;
    border: none;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
    padding: 1rem 0.9rem;
    border-bottom: 1px solid #e2eaf4;
}

.mu3-timeline > :last-child {
    border-bottom: none;
}

.mu3-card {
    border: 1px solid var(--mu3-line);
    border-radius: 0.86rem;
    background: var(--mu3-surface);
    padding: 0.86rem;
}

.mu3-hero {
    background: #ffffff;
}

.mu3-kicker {
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
    border: 1px solid #d7e3ef;
    border-radius: 999px;
    padding: 0.2rem 0.36rem;
    background: #f7fbff;
    color: #2b547f;
    font-size: 0.61rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
}

.mu3-kicker-dot {
    width: 0.36rem;
    height: 0.36rem;
    border-radius: 999px;
    background: var(--mu3-accent);
    box-shadow: 0 0 0 0 rgba(14, 165, 164, 0.28);
    animation: mu3Pulse 1.8s ease-in-out infinite;
}

.mu3-hero h2 {
    margin: 0.52rem 0 0;
    max-width: 28ch;
    font-size: clamp(1.16rem, 2.1vw, 1.56rem);
    line-height: 1.15;
    font-weight: 800;
}

.mu3-hero p {
    margin: 0.28rem 0 0;
    max-width: 66ch;
    font-size: 0.74rem;
    line-height: 1.44;
    color: var(--mu3-ink-500);
}

.mu3-hero-cta {
    margin-top: 0.5rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
}

.mu3-hero-cta a {
    text-decoration: none;
    border-radius: 999px;
    border: 1px solid #d4e1ef;
    background: #ffffff;
    color: #224b7a;
    font-size: 0.66rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.28rem 0.48rem;
}

.mu3-hero-cta a:first-child {
    background: #123f82;
    border-color: #123f82;
    color: #ffffff;
}

.mu3-stat-strip {
    margin-top: 0.52rem;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0.3rem;
}

.mu3-stat {
    border: 1px solid #d9e4f1;
    border-radius: 0.62rem;
    background: #f8fbff;
    padding: 0.34rem;
}

.mu3-stat strong {
    display: block;
    font-size: 0.9rem;
    color: #183c6a;
}

.mu3-stat span {
    display: block;
    margin-top: 0.07rem;
    font-size: 0.62rem;
    color: #607a97;
}

.mu3-composer-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
}

.mu3-composer-head h3 {
    margin: 0;
    font-size: 1.02rem;
    font-weight: 800;
}

.mu3-composer-head p {
    margin: 0.18rem 0 0;
    color: var(--mu3-ink-500);
    font-size: 0.75rem;
}

.mu3-compose-shell {
    display: flex;
    align-items: flex-start;
    gap: 0.72rem;
}

.mu3-compose-avatar {
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 999px;
    background: linear-gradient(145deg, #2e62c7, #4f84de);
    color: #ffffff;
    font-size: 0.92rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
    margin-top: 0.06rem;
}

.mu3-compose-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mu3-compose-main {
    min-width: 0;
    flex: 1;
}

.mu3-compose-form {
    margin-top: 0.56rem;
}

.mu3-compose-textarea {
    width: 100%;
    border: 1px solid #d7e3ef;
    border-radius: 0.86rem;
    background: #fafdff;
    color: #17324f;
    font-size: 0.88rem;
    line-height: 1.5;
    padding: 0.68rem 0.74rem;
    resize: vertical;
}

.mu3-compose-textarea::placeholder {
    color: #7b92ac;
}

.mu3-compose-row {
    margin-top: 0.44rem;
    display: flex;
    align-items: center;
    gap: 0.32rem;
}

.mu3-compose-select {
    min-width: 10.8rem;
    border: 1px solid #d6e1ee;
    border-radius: 0.66rem;
    background: #ffffff;
    color: #214266;
    font-size: 0.76rem;
    font-weight: 700;
    padding: 0.42rem 0.52rem;
}

.mu3-compose-submit {
    border: 1px solid #123f82;
    border-radius: 999px;
    background: #123f82;
    color: #ffffff;
    font-size: 0.76rem;
    font-weight: 800;
    line-height: 1;
    padding: 0.44rem 0.72rem;
    cursor: pointer;
}

.mu3-compose-note {
    margin: 0.4rem 0 0;
    color: var(--mu3-ink-500);
    font-size: 0.69rem;
}

.mu3-compose-fallback {
    margin-top: 0.42rem;
    border: 1px solid #d7e2ef;
    border-radius: 0.7rem;
    background: #f8fbff;
    color: #2f4f79;
    font-size: 0.71rem;
    line-height: 1.42;
    padding: 0.48rem;
}

.mu3-action-row {
    margin-top: 0.58rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.24rem;
}

.mu3-action-row a {
    text-decoration: none;
    border: 1px solid #d7e3ef;
    border-radius: 999px;
    background: #f8fbff;
    color: #2b4e78;
    font-size: 0.69rem;
    font-weight: 700;
    padding: 0.26rem 0.42rem;
}

.mu3-mobile-shortcuts {
    display: none;
}

.mu3-stories-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.45rem;
}

.mu3-stories-head h3 {
    margin: 0;
    font-size: 0.89rem;
    font-weight: 800;
}

.mu3-stories-head a {
    text-decoration: none;
    color: #1d4b98;
    font-size: 0.67rem;
    font-weight: 700;
}

.mu3-story-row {
    margin-top: 0.46rem;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(158px, 1fr);
    gap: 0.34rem;
    overflow-x: auto;
    padding-bottom: 0.1rem;
}

.mu3-story {
    text-decoration: none;
    border: 1px solid #dae5f1;
    border-radius: 0.7rem;
    background: #f9fcff;
    color: inherit;
    padding: 0.4rem;
}

.mu3-story strong {
    display: block;
    font-size: 0.71rem;
    font-weight: 800;
    text-transform: capitalize;
}

.mu3-story p {
    margin: 0.16rem 0 0;
    color: #67809d;
    font-size: 0.64rem;
    line-height: 1.36;
}

.mu3-story span {
    margin-top: 0.28rem;
    display: inline-flex;
    border: 1px solid #d2e1ef;
    border-radius: 999px;
    padding: 0.16rem 0.31rem;
    background: #ffffff;
    color: #2a4f7c;
    font-size: 0.6rem;
    font-weight: 700;
}

.mu3-feed-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.62rem;
}

.mu3-feed-head h3 {
    margin: 0;
    font-size: 1.08rem;
    font-weight: 800;
}

.mu3-feed-head p {
    margin: 0.22rem 0 0;
    font-size: 0.77rem;
    color: var(--mu3-ink-500);
}

.mu3-feed-head a {
    text-decoration: none;
    border: 1px solid #d5e1ee;
    border-radius: 999px;
    background: #f8fbff;
    color: #2a4f7c;
    font-size: 0.72rem;
    font-weight: 700;
    padding: 0.3rem 0.5rem;
}

.mu3-feed-stack {
    margin-top: 0.56rem;
    display: grid;
    gap: 0;
}

.mu3-feed-card {
    border: none;
    border-bottom: 1px solid #e2eaf4;
    border-radius: 0;
    background: transparent;
    padding: 1rem 0;
}

.mu3-feed-card:last-child {
    border-bottom: none;
}

.mu3-feed-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 0.52rem;
}

.mu3-feed-actor {
    display: flex;
    align-items: center;
    gap: 0.62rem;
    min-width: 0;
}

.mu3-feed-avatar-link {
    text-decoration: none;
    flex-shrink: 0;
}

.mu3-feed-avatar {
    width: 2.46rem;
    height: 2.46rem;
    border-radius: 999px;
    background: linear-gradient(148deg, #2e62c7, #4e82dd);
    color: #ffffff;
    font-size: 0.92rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
    position: relative;
}

.mu3-feed-avatar-fallback {
    position: relative;
    z-index: 1;
    line-height: 1;
}

.mu3-feed-avatar img {
    position: absolute;
    inset: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mu3-feed-name {
    margin: 0;
    font-size: 0.9rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    gap: 0.28rem;
}

.mu3-feed-name-link {
    text-decoration: none;
    color: var(--mu3-ink-900);
}

.mu3-feed-name-link:hover {
    color: #184a99;
}

.mu3-blue-check {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.98rem;
    height: 0.98rem;
    border-radius: 999px;
    background: radial-gradient(circle at 30% 24%, #86d1ff 0%, #53aeff 34%, #2a8cff 64%, #115fdb 100%);
    color: #ffffff;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.88), 0 0.28rem 0.62rem rgba(16, 94, 208, 0.42);
}

.mu3-blue-check::before {
    content: '';
    position: absolute;
    inset: 0.07rem;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.36);
    pointer-events: none;
}

.mu3-blue-check::after {
    content: '';
    position: absolute;
    width: 0.28rem;
    height: 0.18rem;
    top: 0.11rem;
    left: 0.17rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    transform: rotate(-24deg);
    pointer-events: none;
}

.mu3-blue-check svg {
    width: 0.57rem;
    height: 0.57rem;
    display: block;
    fill: currentColor;
    position: relative;
    z-index: 1;
}

.mu3-blue-check.is-premium {
    background: radial-gradient(circle at 30% 22%, #8ed9ff 0%, #55b2ff 28%, #208cff 60%, #0f53d0 100%);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.92), 0 0.34rem 0.72rem rgba(0, 88, 214, 0.52), 0 0 0.72rem rgba(74, 170, 255, 0.42);
}

.mu3-feed-sub {
    margin: 0.16rem 0 0;
    font-size: 0.76rem;
    color: var(--mu3-ink-500);
    line-height: 1.45;
}

.mu3-feed-title {
    margin: 0.52rem 0 0;
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.36;
}

.mu3-feed-body {
    margin: 0.32rem 0 0;
    color: var(--mu3-ink-700);
    font-size: 0.88rem;
    line-height: 1.58;
}

.mu3-feed-media {
    margin-top: 0.58rem;
    border: 1px solid #d9e4f0;
    border-radius: 0.9rem;
    overflow: hidden;
    background: #f8fbff;
}

.mu3-feed-media img {
    display: block;
    width: 100%;
    max-height: 420px;
    object-fit: cover;
}

.mu3-feed-chips {
    margin-top: 0.48rem;
    display: flex;
    flex-wrap: wrap;
    gap: 0.24rem;
}

.mu3-feed-chips span {
    border: 1px solid #d7e2ee;
    border-radius: 999px;
    background: #fbfdff;
    color: #2b4f7b;
    font-size: 0.68rem;
    font-weight: 700;
    padding: 0.2rem 0.36rem;
}

.mu3-feed-actions {
    margin-top: 0.58rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 0.48rem;
}

.mu3-feed-delete-form {
    margin-left: auto;
}

.mu3-feed-delete-btn {
    border: 1px solid #f2b8b5;
    border-radius: 999px;
    background: #fff5f5;
    color: #b42318;
    font-size: 0.74rem;
    font-weight: 700;
    line-height: 1;
    padding: 0.42rem 0.7rem;
    cursor: pointer;
}

.mu3-feed-delete-btn:hover {
    background: #ffe9e8;
    border-color: #ef9a95;
}

.mu3-feed-links {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.36rem;
}

.mu3-feed-link {
    text-decoration: none;
    border: 1px solid #d4e0ee;
    border-radius: 999px;
    background: #ffffff;
    color: #2f4f75;
    font-size: 0.76rem;
    font-weight: 700;
    padding: 0.33rem 0.56rem;
}

.mu3-feed-link-primary {
    border-color: #184a9c;
    background: #184a9c;
    color: #ffffff;
}

.mu3-feed-link-secondary {
    background: #f6f9fd;
    color: #2b4e79;
}

.mu3-feed-stats {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 0.38rem;
}

.mu3-feed-stats span {
    display: inline-flex;
    align-items: center;
    gap: 0.22rem;
    color: #5f7895;
    font-size: 0.77rem;
    font-weight: 700;
}

.mu3-feed-stats svg {
    width: 0.92rem;
    height: 0.92rem;
    fill: currentColor;
}

.mu3-right .mu3-card,
.mu3-badge-card {
    border: 1px solid var(--mu3-line);
    border-radius: 0.9rem;
    background: var(--mu3-surface);
    box-shadow: none;
    padding: 0.68rem;
}

.mu3-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.34rem;
}

.mu3-panel-head h3 {
    margin: 0;
    font-size: 0.86rem;
    font-weight: 800;
}

.mu3-panel-head a {
    text-decoration: none;
    color: #1d4b99;
    font-size: 0.64rem;
    font-weight: 700;
}

.mu3-panel-sub {
    margin: 0.14rem 0 0;
    color: var(--mu3-ink-500);
    font-size: 0.65rem;
    line-height: 1.35;
}

.mu3-pulse-grid {
    margin-top: 0.44rem;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.27rem;
}

.mu3-pulse-cell {
    border: 1px solid #dae4f0;
    border-radius: 0.64rem;
    background: #f9fcff;
    padding: 0.32rem;
}

.mu3-pulse-cell strong {
    display: block;
    font-size: 0.85rem;
}

.mu3-pulse-cell span {
    margin-top: 0.06rem;
    display: block;
    font-size: 0.62rem;
    color: #68829f;
}

.mu3-list {
    margin: 0.43rem 0 0;
    padding: 0;
    list-style: none;
    display: grid;
    gap: 0.26rem;
}

.mu3-list-item {
    border: 1px solid #dbe5f0;
    border-radius: 0.66rem;
    background: #fbfdff;
    padding: 0.35rem;
}

.mu3-person {
    display: flex;
    align-items: center;
    gap: 0.39rem;
}

.mu3-person-avatar {
    width: 1.72rem;
    height: 1.72rem;
    border-radius: 0.54rem;
    background: linear-gradient(153deg, #3558b7, #4e79d6);
    color: #ffffff;
    font-size: 0.7rem;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.mu3-person-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mu3-person-name {
    margin: 0;
    font-size: 0.71rem;
    font-weight: 800;
}

.mu3-person-name a {
    text-decoration: none;
    color: var(--mu3-ink-900);
}

.mu3-person-meta {
    margin: 0.1rem 0 0;
    color: var(--mu3-ink-500);
    font-size: 0.62rem;
}

.mu3-mini-title {
    margin: 0;
    font-size: 0.69rem;
    font-weight: 800;
    line-height: 1.28;
}

.mu3-mini-title a {
    text-decoration: none;
    color: var(--mu3-ink-900);
}

.mu3-mini-meta {
    margin: 0.12rem 0 0;
    color: var(--mu3-ink-500);
    font-size: 0.62rem;
}

.mu3-badge-card h3 {
    margin: 0;
    font-size: 0.86rem;
    font-weight: 800;
}

.mu3-badge-card p {
    margin: 0.17rem 0 0;
    color: #4b6787;
    font-size: 0.66rem;
    line-height: 1.37;
}

.mu3-badge-cta-row {
    margin-top: 0.38rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.34rem;
}

.mu3-badge-cta-row a {
    text-decoration: none;
    border: 1px solid #123f82;
    border-radius: 999px;
    background: #123f82;
    color: #ffffff;
    font-size: 0.64rem;
    font-weight: 800;
    line-height: 1;
    padding: 0.3rem 0.44rem;
}

.mu3-badge-state {
    color: #2f527f;
    font-size: 0.61rem;
    font-weight: 700;
}

@keyframes mu3Pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(14, 165, 164, 0.28);
    }
    100% {
        box-shadow: 0 0 0 0.52rem rgba(14, 165, 164, 0);
    }
}

@media (max-width: 1230px) {
    .mu3-layout {
        grid-template-columns: 220px minmax(0, 1fr) 300px;
    }
}

@media (max-width: 1040px) {
    .mu3-layout {
        grid-template-columns: minmax(0, 1fr) 300px;
        grid-template-areas:
            "left left"
            "center right";
    }

    .mu3-left,
    .mu3-right {
        position: static;
        max-height: none;
        overflow: visible;
    }

    .mu3-left {
        border: 1px solid var(--mu3-line);
        border-radius: 0.84rem;
        background: #ffffff;
        padding: 0.56rem;
        margin-bottom: 0.02rem;
    }

    .mu3-left .mu3-left-card {
        display: none;
    }

    .mu3-left .mu3-left-foot {
        display: none;
    }

    .mu3-menu {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 0.28rem;
    }

    .mu3-center {
        border-left: none;
        border-right: none;
        padding: 0;
    }
}

@media (max-width: 760px) {
    .mu3-home {
        padding: 0.44rem 0.3rem 1.2rem;
    }

    .mu3-layout {
        grid-template-columns: 1fr;
        grid-template-areas:
            "center"
            "left"
            "right";
        gap: 0.56rem;
    }

    .mu3-stream-head {
        top: 0.38rem;
        flex-direction: column;
        align-items: flex-start;
        border-radius: 0.82rem 0.82rem 0 0;
    }

    .mu3-head-actions {
        width: 100%;
        justify-content: flex-start;
    }

    .mu3-stat-strip,
    .mu3-pulse-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .mu3-compose-row {
        flex-direction: column;
        align-items: stretch;
    }

    .mu3-compose-select,
    .mu3-compose-submit {
        width: 100%;
    }

    .mu3-compose-shell {
        flex-direction: column;
    }

    .mu3-feed-actions {
        flex-direction: column;
        align-items: flex-start;
    }

    .mu3-feed-links {
        width: 100%;
    }

    .mu3-feed-link {
        flex: 1 1 auto;
        text-align: center;
    }

    .mu3-menu {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .mu3-mobile-shortcuts {
        margin-top: 0.38rem;
        display: flex;
        flex-wrap: wrap;
        gap: 0.22rem;
    }

    .mu3-mobile-shortcuts a {
        text-decoration: none;
        border: 1px solid #d8e3ef;
        border-radius: 999px;
        background: #f8fbff;
        color: #2a4e79;
        font-size: 0.61rem;
        font-weight: 700;
        padding: 0.18rem 0.3rem;
    }
}

/* Premium campus stream refresh */
.mu3-home {
    --mu3-bg: #ffffff;
    --mu3-surface: #ffffff;
    --mu3-muted: #f6f8fc;
    --mu3-line: #d8e1ec;
    --mu3-line-strong: #cad5e3;
    --mu3-ink-900: #0f1b2d;
    --mu3-ink-700: #31455f;
    --mu3-ink-500: #607286;
    --mu3-brand: #2b5eaa;
    --mu3-brand-strong: #2b5eaa;
    --mu3-accent: #198d86;
    --mu3-shadow-soft: 0 10px 24px rgba(15, 27, 45, 0.07);
    min-height: 100vh;
    padding: 0.62rem clamp(0.44rem, 1.2vw, 0.94rem) 1.25rem;
    background: var(--mu3-bg);
}

.mu3-shell {
    max-width: 1400px;
}

.mu3-layout {
    grid-template-columns: 244px minmax(0, 1fr) 308px;
    gap: 0.82rem;
}

.mu3-left,
.mu3-right {
    top: 0.5rem;
    max-height: calc(100vh - 1rem);
}

.mu3-brand {
    margin-bottom: 0.7rem;
}

.mu3-brand-mark {
    width: 2.06rem;
    height: 2.06rem;
    border-radius: 0.66rem;
    background: linear-gradient(145deg, #2b5eaa 0%, #234f90 54%, #198d86 100%);
    box-shadow: none;
}

.mu3-brand-title {
    font-size: 1.02rem;
    color: var(--mu3-brand-strong);
    max-width: 11rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mu3-brand-sub {
    font-size: 0.64rem;
    color: #66788c;
}

.mu3-menu {
    gap: 0.22rem;
}

.mu3-menu a {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 0.52rem;
    border-radius: 0.78rem;
    border-color: transparent;
    background: transparent;
    padding: 0.56rem 0.64rem;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.005em;
}

.mu3-menu a::after {
    display: none;
}

.mu3-menu a:hover {
    border-color: var(--mu3-line-strong);
    background: var(--mu3-surface);
    box-shadow: var(--mu3-shadow-soft);
}

.mu3-menu a.mu3-active {
    border-color: #bfd2ea;
    background: #f2f7ff;
    color: var(--mu3-brand);
}

.mu3-menu-icon {
    width: 1.26rem;
    height: 1.26rem;
    border-radius: 0.42rem;
    border: 1px solid #d5dee9;
    background: var(--mu3-muted);
    color: #425771;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: border-color 0.16s ease, color 0.16s ease, background-color 0.16s ease;
}

.mu3-menu-icon i {
    font-size: 0.62rem;
    line-height: 1;
}

.mu3-menu-label {
    min-width: 0;
    display: inline-block;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.mu3-menu a:hover .mu3-menu-icon {
    border-color: #c3d4e8;
    color: var(--mu3-brand);
}

.mu3-menu a.mu3-active .mu3-menu-icon {
    border-color: #b9cee7;
    background: #ffffff;
    color: var(--mu3-brand);
}

.mu3-left-card {
    margin-top: 0.66rem;
    border: 1px solid var(--mu3-line);
    border-radius: 0.98rem;
    background: #ffffff;
    box-shadow: var(--mu3-shadow-soft);
    padding: 0.72rem;
}

.mu3-left-card h3 {
    font-size: 0.84rem;
}

.mu3-left-card p {
    margin-top: 0.2rem;
    font-size: 0.7rem;
    line-height: 1.42;
}

.mu3-topic-list,
.mu3-link-list {
    margin-top: 0.5rem;
    gap: 0.28rem;
}

.mu3-topic-list a,
.mu3-link-list a {
    border-color: #d7e0eb;
    background: #ffffff;
    color: #344c66;
    font-size: 0.69rem;
    padding: 0.28rem 0.48rem;
}

.mu3-chat-promo {
    margin-top: 0.66rem;
    border: 1px solid var(--mu3-line);
    border-radius: 0.98rem;
    background: #ffffff;
    padding: 0.68rem;
    box-shadow: var(--mu3-shadow-soft);
}

.mu3-chat-promo-media {
    display: block;
    border: 1px solid #d6e0eb;
    border-radius: 0.88rem;
    overflow: hidden;
    background: #eef3f8;
}

.mu3-chat-promo-media img {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.mu3-chat-promo-btn {
    margin-top: 0.54rem;
    display: inline-flex;
    width: 100%;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    border-radius: 999px;
    border: 1px solid var(--mu3-brand-strong);
    background: var(--mu3-brand-strong);
    color: #ffffff;
    font-size: 0.74rem;
    font-weight: 800;
    line-height: 1;
    padding: 0.52rem 0.72rem;
}

.mu3-module-grid {
    margin-top: 0.5rem;
    gap: 0.34rem;
}

.mu3-module {
    border-color: #d8e2ed;
    border-radius: 0.78rem;
    background: #ffffff;
    padding: 0.46rem;
}

.mu3-left-foot {
    margin-top: 0.66rem;
    padding-top: 0.56rem;
    border-top-color: #d8e4f0;
}

.mu3-center {
    border: none;
    padding: 0;
}

.mu3-stream-head {
    top: 0.5rem;
    border: 1px solid var(--mu3-line);
    border-radius: 1rem;
    box-shadow: var(--mu3-shadow-soft);
    background: rgba(255, 255, 255, 0.94);
    padding: 0.8rem 0.95rem;
}

.mu3-stream-head h1 {
    font-size: 1.14rem;
}

.mu3-stream-head p {
    margin-top: 0.18rem;
    font-size: 0.75rem;
}

.mu3-head-actions {
    gap: 0.28rem;
}

.mu3-pill,
.mu3-search,
.mu3-auth-btn {
    border-color: #d2dbe7;
    color: #37506c;
    font-size: 0.69rem;
    padding: 0.34rem 0.56rem;
}

.mu3-pill.mu3-pill-active {
    background: #edf2f8;
    border-color: #cad5e1;
    color: var(--mu3-brand-strong);
}

.mu3-search {
    background: var(--mu3-muted);
}

.mu3-auth-btn.mu3-auth-main {
    background: var(--mu3-brand);
    border-color: var(--mu3-brand);
}

.mu3-timeline {
    margin-top: 0;
    border: 1px solid var(--mu3-line);
    border-radius: 1rem;
    background: var(--mu3-surface);
    box-shadow: var(--mu3-shadow-soft);
}

.mu3-timeline > .mu3-hero,
.mu3-timeline > .mu3-card {
    border-bottom: 1px solid #e1e8f1;
    padding: 1.05rem 0.98rem;
}

.mu3-card {
    border: none;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
}

.mu3-compose-shell {
    gap: 0.8rem;
}

.mu3-compose-avatar {
    width: 2.38rem;
    height: 2.38rem;
    background: linear-gradient(145deg, #295ca8, #2f739f);
}

.mu3-composer-head h3 {
    font-size: 1rem;
}

.mu3-composer-head p {
    margin-top: 0.14rem;
    font-size: 0.72rem;
}

.mu3-compose-form {
    margin-top: 0.5rem;
}

.mu3-compose-textarea {
    border-color: #d7e0ea;
    border-radius: 0.88rem;
    background: var(--mu3-muted);
    font-size: 0.84rem;
    line-height: 1.52;
    padding: 0.66rem 0.74rem;
}

.mu3-compose-select {
    min-width: 11rem;
    border-color: #d5dfe9;
    border-radius: 0.68rem;
    font-size: 0.74rem;
    padding: 0.42rem 0.54rem;
}

.mu3-compose-submit {
    border-color: var(--mu3-brand-strong);
    background: var(--mu3-brand-strong);
    font-size: 0.74rem;
    padding: 0.45rem 0.74rem;
}

.mu3-compose-note {
    margin-top: 0.36rem;
    font-size: 0.67rem;
}

.mu3-action-row {
    margin-top: 0.52rem;
    gap: 0.26rem;
}

.mu3-action-row a {
    border-color: #d4deea;
    background: #ffffff;
    font-size: 0.66rem;
    padding: 0.24rem 0.4rem;
}

.mu3-feed-head h3 {
    font-size: 1rem;
}

.mu3-feed-head p {
    margin-top: 0.18rem;
    font-size: 0.72rem;
}

.mu3-feed-head a {
    border-color: #d5dfeb;
    background: #ffffff;
    font-size: 0.67rem;
    padding: 0.28rem 0.5rem;
}

.mu3-feed-card {
    padding: 1rem 0;
}

.mu3-feed-main {
    margin-top: 0.44rem;
    margin-left: 2.92rem;
    border: 1px solid #d6e0eb;
    border-radius: 0.94rem;
    background: #ffffff;
    padding: 0.76rem 0.84rem 0.72rem;
}

.mu3-feed-main > :first-child {
    margin-top: 0 !important;
}

.mu3-feed-actor {
    gap: 0.58rem;
}

.mu3-feed-avatar {
    width: 2.34rem;
    height: 2.34rem;
    border: 1px solid #d6e0eb;
    box-shadow: 0 6px 16px rgba(26, 54, 85, 0.12);
    background: linear-gradient(145deg, #295ca8, #2f739f);
}

.mu3-feed-name {
    font-size: 0.88rem;
}

.mu3-feed-sub {
    margin-top: 0.13rem;
    font-size: 0.72rem;
}

.mu3-feed-title {
    margin-top: 0;
    font-size: 0.95rem;
    line-height: 1.32;
}

.mu3-feed-body {
    margin-top: 0.34rem;
    font-size: 0.84rem;
    line-height: 1.54;
}

.mu3-feed-media {
    margin-top: 0.48rem;
    border-color: #d6e0eb;
    border-radius: 0.95rem;
    background: var(--mu3-muted);
}

.mu3-feed-chips {
    margin-top: 0.4rem;
}

.mu3-feed-chips span {
    border-color: #d6e0eb;
    background: #ffffff;
    color: #38526d;
    font-size: 0.66rem;
    padding: 0.18rem 0.34rem;
}

.mu3-feed-actions {
    margin-top: 0.5rem;
    padding-top: 0.46rem;
    border-top: 1px solid #e1e8f1;
    gap: 0.42rem;
}

.mu3-feed-links {
    gap: 0.32rem;
}

.mu3-feed-link {
    border-color: #d4deea;
    color: #36506b;
    font-size: 0.7rem;
    padding: 0.31rem 0.52rem;
}

.mu3-feed-link-primary {
    border-color: var(--mu3-brand-strong);
    background: var(--mu3-brand-strong);
}

.mu3-feed-link-secondary {
    background: var(--mu3-muted);
}

.mu3-feed-stats span {
    font-size: 0.72rem;
}

.mu3-right .mu3-card,
.mu3-badge-card {
    border-color: var(--mu3-line);
    border-radius: 1rem;
    background: #ffffff;
    box-shadow: var(--mu3-shadow-soft);
    padding: 0.74rem;
}

.mu3-panel-head h3,
.mu3-badge-card h3 {
    font-size: 0.84rem;
}

.mu3-panel-head a {
    font-size: 0.63rem;
}

.mu3-panel-sub {
    font-size: 0.64rem;
}

.mu3-pulse-grid {
    margin-top: 0.48rem;
    gap: 0.3rem;
}

.mu3-pulse-cell {
    border-color: #d6e0eb;
    border-radius: 0.68rem;
    background: #ffffff;
    padding: 0.35rem;
}

.mu3-pulse-cell strong {
    font-size: 0.83rem;
    color: var(--mu3-ink-900);
}

.mu3-list {
    margin-top: 0.46rem;
    gap: 0.28rem;
}

.mu3-list-item {
    border-color: #d6e0eb;
    border-radius: 0.72rem;
    padding: 0.38rem;
    background: #ffffff;
}

.mu3-person {
    gap: 0.46rem;
}

.mu3-person-avatar {
    width: 1.82rem;
    height: 1.82rem;
    border-radius: 999px;
    border: 1px solid #d4dfe9;
    box-shadow: 0 4px 12px rgba(26, 54, 85, 0.1);
}

.mu3-person-name {
    font-size: 0.72rem;
}

.mu3-person-meta,
.mu3-mini-meta {
    font-size: 0.61rem;
}

.mu3-badge-card p {
    font-size: 0.64rem;
}

.mu3-badge-cta-row a {
    border-color: var(--mu3-brand-strong);
    background: var(--mu3-brand-strong);
    font-size: 0.63rem;
    padding: 0.3rem 0.46rem;
}

.mu3-topic-list strong {
    color: var(--mu3-brand-strong);
}

.mu3-feed-name-link:hover,
.mu3-panel-head a {
    color: #2f537a;
}

.mu3-panel-head a:hover {
    color: var(--mu3-brand-strong);
}

.mu3-feed-stats span {
    color: #5f7084;
}

.mu3-compose-fallback {
    border-color: #d6e0ea;
    background: var(--mu3-muted);
    color: #37516d;
}

.mu3-blue-check {
    background: linear-gradient(145deg, #2f5f9f 0%, #265485 100%);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.9), 0 0.22rem 0.46rem rgba(31, 70, 127, 0.22);
}

.mu3-blue-check::before,
.mu3-blue-check::after {
    display: none;
}

.mu3-blue-check.is-premium {
    background: linear-gradient(145deg, #2b6f80 0%, #235966 100%);
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.9), 0 0.22rem 0.46rem rgba(28, 86, 101, 0.26);
}

@media (max-width: 1230px) {
    .mu3-layout {
        grid-template-columns: 222px minmax(0, 1fr) 294px;
    }
}

@media (max-width: 1040px) {
    .mu3-layout {
        grid-template-columns: minmax(0, 1fr) 294px;
        gap: 0.66rem;
    }

    .mu3-left {
        border-color: var(--mu3-line);
        border-radius: 1rem;
        box-shadow: var(--mu3-shadow-soft);
    }
}

@media (max-width: 760px) {
    .mu3-home {
        padding: 0.38rem 0.28rem 1.1rem;
    }

    .mu3-layout {
        grid-template-columns: 1fr;
        grid-template-areas:
            "center"
            "left"
            "right";
        gap: 0.52rem;
    }

    .mu3-left,
    .mu3-right {
        position: static;
        top: auto;
        max-height: none;
        overflow: visible;
    }

    .mu3-left {
        padding: 0.52rem;
    }

    .mu3-menu {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .mu3-timeline {
        margin-top: 0;
        border-radius: 0.9rem;
    }

    .mu3-timeline > .mu3-hero,
    .mu3-timeline > .mu3-card {
        padding: 0.88rem 0.74rem;
    }

    .mu3-feed-link {
        flex: 1 1 auto;
        text-align: center;
    }

    .mu3-feed-main {
        margin-left: 0;
        margin-top: 0.6rem;
        padding: 0.7rem 0.72rem 0.66rem;
    }
}

/* --- END: pages/campus-stream.php --- */

/* --- BEGIN: admin/admin-org-structure.php --- */

.mn-admin-org-structure .org-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.mn-admin-org-structure .org-dept-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.95rem;
  background: linear-gradient(180deg, #fff, var(--off));
}

.mn-admin-org-structure .org-dept-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.55rem;
}

.mn-admin-org-structure .org-dept-head h3 {
  font-size: 0.84rem;
  font-weight: 700;
  color: var(--ink);
}

.mn-admin-org-structure .org-bullets {
  list-style: none;
  display: grid;
  gap: 0.42rem;
}

.mn-admin-org-structure .org-bullets li {
  font-size: 0.75rem;
  color: var(--ink-2);
  padding-left: 0.7rem;
  position: relative;
  line-height: 1.45;
}

.mn-admin-org-structure .org-bullets li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.47rem;
  width: 0.3rem;
  height: 0.3rem;
  border-radius: 999px;
  background: var(--blue-400);
}

.mn-admin-org-structure .org-step-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem;
}

.mn-admin-org-structure .org-step-item {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.65rem 0.75rem;
  background: #fff;
}

.mn-admin-org-structure .org-step-num {
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.66rem;
  font-family: var(--f-mono);
  color: #fff;
  background: var(--blue-600);
  flex: 0 0 1.2rem;
  margin-top: 0.05rem;
}

.mn-admin-org-structure .org-step-text {
  font-size: 0.76rem;
  color: var(--ink);
  line-height: 1.35;
  font-weight: 600;
}

.mn-admin-org-structure .org-panel-header-wrap {
  align-items: center;
}

.mn-admin-org-structure .org-skill-controls {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  max-width: 360px;
}

.mn-admin-org-structure .org-skill-controls .search-bar {
  max-width: none;
}

.mn-admin-org-structure .org-tag-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}

.mn-admin-org-structure .org-skill-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.mn-admin-org-structure .org-skill-card {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.85rem;
  background: var(--white);
}

.mn-admin-org-structure .org-skill-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.5rem;
}

.mn-admin-org-structure .org-skill-head h3 {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.35;
}

.mn-admin-org-structure .org-skill-desc {
  margin-top: 0.55rem;
  font-size: 0.75rem;
  color: var(--ink-2);
  line-height: 1.5;
}

.mn-admin-org-structure .org-skill-details {
  margin-top: 0.55rem;
}

.mn-admin-org-structure .org-skill-details summary {
  cursor: pointer;
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--blue-600);
}

.mn-admin-org-structure .org-skill-meta {
  margin-top: 0.48rem;
  font-size: 0.7rem;
  color: var(--ink-3);
  display: grid;
  gap: 0.35rem;
}

.mn-admin-org-structure .org-skill-meta code {
  background: var(--off);
  border: 1px solid var(--border-s);
  border-radius: 6px;
  padding: 0.08rem 0.24rem;
  font-family: var(--f-mono);
  font-size: 0.66rem;
  color: var(--ink-2);
}

.mn-admin-org-structure .org-skill-meta pre {
  background: var(--ink);
  color: #dbeafe;
  border-radius: 10px;
  padding: 0.6rem;
  font-size: 0.64rem;
  font-family: var(--f-mono);
  line-height: 1.4;
  max-height: 220px;
  overflow: auto;
}

.mn-admin-org-structure .org-source-list {
  list-style: none;
  display: grid;
  gap: 0.55rem;
}

.mn-admin-org-structure .org-source-list li {
  font-size: 0.78rem;
  color: var(--ink-2);
}

.mn-admin-org-structure .org-source-list code {
  background: var(--off);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 0.16rem 0.4rem;
  font-family: var(--f-mono);
  font-size: 0.7rem;
  color: var(--ink-2);
}

@media (max-width: 1200px) {
  .mn-admin-org-structure .org-grid,
  .mn-admin-org-structure .org-skill-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .mn-admin-org-structure .org-step-list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .mn-admin-org-structure .org-grid,
  .mn-admin-org-structure .org-skill-grid {
    grid-template-columns: 1fr;
  }

  .mn-admin-org-structure .org-skill-controls {
    max-width: 100%;
  }

  .mn-admin-org-structure .quick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 500px) {
  .mn-admin-org-structure .quick-grid {
    grid-template-columns: 1fr !important;
  }
}

/* --- END: admin/admin-org-structure.php --- */

/* --- BEGIN: admin/admin-paid-pdf-catalog.php --- */

.mn-admin-paid-pdf-catalog .admin-wireframe-shell {
    margin: 0;
    max-width: none;
    padding: 0;
}

.mn-admin-paid-pdf-catalog .admin-panel {
    border: 1px solid #dbe7f6;
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 1px 3px rgba(4, 16, 31, 0.06), 0 1px 2px rgba(4, 16, 31, 0.04);
}

.mn-admin-paid-pdf-catalog .admin-form-surface {
    border: 1px solid #dbe7f6;
    border-radius: 14px;
    background: #ffffff;
    padding: 1rem;
}

.mn-admin-paid-pdf-catalog .admin-table-wrap {
    width: 100%;
    overflow-x: auto;
}

.mn-admin-paid-pdf-catalog .admin-table-wrap table {
    min-width: 900px;
}

.mn-admin-paid-pdf-catalog .admin-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.75rem;
}

.mn-admin-paid-pdf-catalog .hidden {
    display: none !important;
}

/* --- END: admin/admin-paid-pdf-catalog.php --- */
