/* CSS VERSION: 2.0.0 - 2025-11-28 13:27:07 */
*,: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.18 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,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{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}body{--tw-bg-opacity:1;background-color:rgb(10 11 13/var(--tw-bg-opacity,1));--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,sans-serif;line-height:1.6}h1,h2,h3,h4,h5,h6{font-weight:700}.\!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}}.hero-title{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:3px;background:linear-gradient(90deg,#646cff,#a78bfa 50%,#ec4899);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 4s linear infinite;filter:drop-shadow(0 0 8px rgba(100,108,255,.3))}@media (min-width:640px){.hero-title{font-size:11px;letter-spacing:4px}}.page-heading{margin-bottom:1rem;font-size:1.875rem;line-height:2.25rem;font-weight:800;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}@media (min-width:640px){.page-heading{font-size:2.25rem;line-height:2.5rem}}@media (min-width:1024px){.page-heading{font-size:3rem;line-height:1}}.page-heading{letter-spacing:-.5px;line-height:1.2}@media (min-width:1024px){.page-heading{letter-spacing:-1px}}.section-box{margin-bottom:1.5rem;border-radius:.75rem;padding:1rem}@media (min-width:640px){.section-box{margin-bottom:2rem;border-radius:1rem;padding:1.5rem}}@media (min-width:1024px){.section-box{padding:2rem}}.section-box{background:rgba(26,29,35,.6);border:1px solid rgba(100,108,255,.15);backdrop-filter:blur(10px)}.card{overflow:hidden;border-radius:1rem;--tw-bg-opacity:1;background-color:rgb(26 29 35/var(--tw-bg-opacity,1));border:1px solid hsla(0,0%,100%,.08);transition:all .3s ease}.card:hover{border-color:rgba(100,108,255,.2);box-shadow:0 4px 16px rgba(0,0,0,.3)}.card-body{padding:1.5rem}.card-header{padding:1rem 1.5rem;border-bottom:1px solid hsla(0,0%,100%,.06)}.search-section{border-radius:.75rem;padding:1rem}@media (min-width:640px){.search-section{border-radius:1rem;padding:1.5rem}}.search-section{background:linear-gradient(135deg,rgba(100,108,255,.08),rgba(167,139,250,.06));border:1px solid rgba(100,108,255,.2)}.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;padding:.625rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn:focus{outline:2px solid transparent;outline-offset:2px}.btn:disabled{cursor:not-allowed;opacity:.5}@media (min-width:640px){.btn{border-radius:.75rem;padding:.75rem 1.5rem;font-size:1rem;line-height:1.5rem}}.btn-primary{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;padding:.625rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-primary:focus{outline:2px solid transparent;outline-offset:2px}.btn-primary:disabled{cursor:not-allowed;opacity:.5}@media (min-width:640px){.btn-primary{border-radius:.75rem;padding:.75rem 1.5rem;font-size:1rem;line-height:1.5rem}}.btn-primary{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));background:linear-gradient(135deg,#646cff,#4046d3);border:1px solid rgba(100,108,255,.3)}.btn-primary:hover{background:linear-gradient(135deg,#7078ff,#5056e3);box-shadow:0 4px 12px rgba(100,108,255,.25)}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;padding:.625rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-secondary:focus{outline:2px solid transparent;outline-offset:2px}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}@media (min-width:640px){.btn-secondary{border-radius:.75rem;padding:.75rem 1.5rem;font-size:1rem;line-height:1.5rem}}.btn-secondary{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1));background:linear-gradient(135deg,#a78bfa,#9333ea);border:1px solid rgba(167,139,250,.3)}.btn-secondary:hover{background:linear-gradient(135deg,#b89bff,#a444fa);box-shadow:0 4px 12px rgba(167,139,250,.25)}.btn-outline{display:inline-flex;align-items:center;justify-content:center;border-radius:.5rem;padding:.625rem 1rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.btn-outline:focus{outline:2px solid transparent;outline-offset:2px}.btn-outline:disabled{cursor:not-allowed;opacity:.5}@media (min-width:640px){.btn-outline{border-radius:.75rem;padding:.75rem 1.5rem;font-size:1rem;line-height:1.5rem}}.btn-outline{border:2px solid rgba(100,108,255,.4);color:#646cff;background:rgba(100,108,255,.05)}.btn-outline:hover{background:rgba(100,108,255,.1);border-color:#646cff}.form-input{width:100%;border-radius:.5rem;padding:.625rem .75rem;font-size:.875rem;line-height:1.25rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s}@media (min-width:640px){.form-input{border-radius:.75rem;padding:.75rem 1rem;font-size:1rem;line-height:1.5rem}}.form-input{background:hsla(0,0%,100%,.04);border:1px solid hsla(0,0%,100%,.1);color:#fff}.form-input:focus{outline:none;border-color:rgba(100,108,255,.5);background:hsla(0,0%,100%,.06);box-shadow:0 0 0 3px rgba(100,108,255,.1)}.form-input::-moz-placeholder{color:hsla(0,0%,100%,.3)}.form-input::placeholder{color:hsla(0,0%,100%,.3)}select#dateSelector,select#searchType,select.form-input{cursor:pointer;background-color:rgba(18,21,26,.9)!important;color:#fff!important;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%23a78bfa' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none}select#dateSelector option,select#searchType option,select.form-input option{background:#12151a!important;color:#fff!important;padding:10px}.form-label{margin-bottom:.5rem;display:block;font-size:.75rem;line-height:1rem;font-weight:600}@media (min-width:640px){.form-label{font-size:.875rem;line-height:1.25rem}}.form-label{color:hsla(0,0%,100%,.9)}.alert{display:flex;align-items:flex-start}.alert>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.75rem*var(--tw-space-x-reverse));margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)))}.alert{border-radius:.75rem;border-width:1px;padding:1rem}.alert-info{background:rgba(100,108,255,.08);border-color:rgba(100,108,255,.2);color:#646cff}.\!badge{font-size:.75rem;line-height:1rem;font-weight:600}.\!badge,.badge{display:inline-flex;align-items:center;border-radius:9999px;padding:.25rem .75rem}.badge-premium{background:linear-gradient(135deg,rgba(100,108,255,.15),rgba(167,139,250,.15));color:#fff;border:1px solid rgba(100,108,255,.3)}.spinner{display:inline-block;height:2rem;width:2rem;animation:spin 1s linear infinite;border-radius:9999px;border-width:4px;border-style:solid;border-color:#646cff transparent}.container-custom{margin-left:auto;margin-right:auto;max-width:80rem;padding-left:1rem;padding-right:1rem}@media (min-width:640px){.container-custom{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:1024px){.container-custom{padding-left:2rem;padding-right:2rem}}.stat-card{overflow:hidden;border-radius:1rem;--tw-bg-opacity:1;background-color:rgb(26 29 35/var(--tw-bg-opacity,1));border:1px solid hsla(0,0%,100%,.08);transition:all .3s ease}.stat-card:hover{border-color:rgba(100,108,255,.2);box-shadow:0 4px 16px rgba(0,0,0,.3)}.stat-card{text-align:center;animation:cardAppear .6s ease-out backwards}.stat-value{margin-bottom:.5rem;font-size:2.25rem;line-height:2.5rem;font-weight:700;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.stat-label{font-size:.875rem;line-height:1.25rem;text-transform:uppercase;letter-spacing:.05em;color:hsla(0,0%,100%,.5)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-y-0{top:0;bottom:0}.-right-1{right:-.25rem}.-top-1{top:-.25rem}.left-0{left:0}.left-3{left:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-20{top:5rem}.top-4{top:1rem}.z-10{z-index:10}.z-50{z-index:50}.col-span-full{grid-column:1/-1}.float-right{float:right}.float-left{float:left}.float-none{float:none}.m-1{margin:.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-8{margin-top:2rem;margin-bottom:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mt-1{margin-top:.25rem}.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}.mt-auto{margin-top:auto}.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!important}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-24{height:6rem}.h-32{height:8rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-auto{height:auto}.h-full{height:100%}.max-h-96{max-height:24rem}.max-h-full{max-height:100%}.max-h-screen{max-height:100vh}.min-h-32{min-height:8rem}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-2{width:.5rem}.w-20{width:5rem}.w-32{width:8rem}.w-5{width:1.25rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-80{width:20rem}.w-auto{width:auto}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink{flex-shrink:1}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.flex-grow,.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.-translate-y-1\/2{--tw-translate-y:-50%}.-translate-y-1\/2,.-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))}.-translate-y-2{--tw-translate-y:-0.5rem}.translate-x-full{--tw-translate-x:100%}.transform,.translate-x-full{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 bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}.animate-card-appear{animation:cardAppear .6s ease-out backwards}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse-slow{animation:pulse 3s cubic-bezier(.4,0,.6,1) infinite}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.animate-slide-down{animation:slideDown .4s ease-out}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-wrap-reverse{flex-wrap:wrap-reverse}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.25rem*var(--tw-space-x-reverse));margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.5rem*var(--tw-space-x-reverse));margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(.75rem*var(--tw-space-x-reverse));margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem*var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem*var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.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}.text-nowrap{text-wrap:nowrap}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-primary-600{--tw-border-opacity:1;border-color:rgb(64 70 211/var(--tw-border-opacity,1))}.border-red-500{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.bg-accent{--tw-bg-opacity:1;background-color:rgb(100 108 255/var(--tw-bg-opacity,1))}.bg-bgPrimary{--tw-bg-opacity:1;background-color:rgb(10 11 13/var(--tw-bg-opacity,1))}.bg-bgSecondary{--tw-bg-opacity:1;background-color:rgb(18 21 26/var(--tw-bg-opacity,1))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity,1))}.bg-black\/70{background-color:rgba(0,0,0,.7)}.bg-danger{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity,1))}.bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity,1))}.bg-primary{--tw-bg-opacity:1;background-color:rgb(100 108 255/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-fixed{background-attachment:fixed}.object-cover{-o-object-fit:cover;object-fit:cover}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pl-10{padding-left:2.5rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.align-baseline{vertical-align:baseline}.align-top{vertical-align:top}.align-middle{vertical-align:middle}.align-bottom{vertical-align:bottom}.align-text-top{vertical-align:text-top}.align-text-bottom{vertical-align:text-bottom}.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-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-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.italic{font-style:italic}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.tracking-wider{letter-spacing:.05em}.text-accent{--tw-text-opacity:1;color:rgb(100 108 255/var(--tw-text-opacity,1))}.text-current{color:currentColor}.text-danger{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-pink{--tw-text-opacity:1;color:rgb(236 72 153/var(--tw-text-opacity,1))}.text-purple{--tw-text-opacity:1;color:rgb(167 139 250/var(--tw-text-opacity,1))}.text-success{--tw-text-opacity:1;color:rgb(16 185 129/var(--tw-text-opacity,1))}.text-textMuted{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1))}.text-textSecondary{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.text-warning{--tw-text-opacity:1;color:rgb(245 158 11/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-20{opacity:.2}.opacity-30{opacity:.3}.opacity-70{opacity:.7}.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-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{outline-style:solid}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px rgba(0,0,0,.1)) drop-shadow(0 1px 1px rgba(0,0,0,.06))}.grayscale{--tw-grayscale:grayscale(100%)}.filter,.grayscale{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur:blur(4px)}.backdrop-blur-sm,.backdrop-blur-xl{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-xl{--tw-backdrop-blur:blur(24px)}.backdrop-filter{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-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-150,.transition-transform{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.text-gradient{background:linear-gradient(135deg,#646cff,#a78bfa,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.bg-gradient-accent{background:linear-gradient(135deg,#646cff,#4046d3)}.bg-gradient-purple{background:linear-gradient(135deg,#a78bfa,#9333ea)}.bg-gradient-pink{background:linear-gradient(135deg,#ec4899,#be185d)}.page-bg-animated{position:relative;background:#0a0b0d}.page-bg-animated:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle at 15% 20%,rgba(100,108,255,.08) 0,transparent 40%),radial-gradient(circle at 85% 60%,rgba(167,139,250,.06) 0,transparent 40%),radial-gradient(circle at 50% 85%,rgba(236,72,153,.05) 0,transparent 40%);animation:bgPulse 15s ease-in-out infinite}@keyframes bgPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.page-bg-animated:after{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(100,108,255,.03) 1px,transparent 0),radial-gradient(circle,rgba(167,139,250,.02) 1px,transparent 0);background-size:80px 80px,120px 120px;background-position:0 0,40px 40px;animation:particleFloat 60s linear infinite}@keyframes particleFloat{0%{transform:translate(0) rotate(0deg)}to{transform:translate(50px,50px) rotate(1turn)}}@keyframes gradientShift{0%{background-position:0}to{background-position:200%}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes cardAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-card-appear{animation:cardAppear .6s ease-out backwards}select{background:linear-gradient(135deg,#1a1d23,#12151a)!important;color:#fff!important;border:1px solid rgba(167,139,250,.3)!important}select option{background:#1a1d23!important;color:#fff!important;padding:10px!important}select option:checked,select option:focus,select option:hover{background:linear-gradient(135deg,#646cff,#7c3aed)!important;color:#fff!important}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-track{background:#0a0b0e;border-radius:8px;border:1px solid rgba(100,108,255,.1)}::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#646cff,#7c3aed);border-radius:8px;border:2px solid #0a0b0e;-webkit-transition:all .3s ease;transition:all .3s ease}::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#7c3aed,#ec4899);border-color:rgba(100,108,255,.2);box-shadow:0 0 8px rgba(100,108,255,.4)}::-webkit-scrollbar-thumb:active{background:linear-gradient(135deg,#ec4899,#646cff)}*{scrollbar-width:thin;scrollbar-color:#646cff #0a0b0e}.scrollbar-thin::-webkit-scrollbar{width:8px;height:8px}.scrollbar-thin::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#646cff,#7c3aed);border-radius:6px;border:1px solid #0a0b0e}.rooms-container{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:1.5rem}@media (min-width:1024px){.rooms-container{grid-template-columns:repeat(2,minmax(0,1fr))}}.room-group{overflow:hidden;border-radius:.75rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;background:linear-gradient(145deg,rgba(26,29,35,.6),rgba(18,21,26,.6));border:1px solid rgba(100,108,255,.15);box-shadow:0 4px 12px rgba(0,0,0,.3);backdrop-filter:blur(20px);animation:cardAppear .6s ease-out backwards;display:flex;flex-direction:column;height:100%}.room-group:hover{border-color:rgba(100,108,255,.3);box-shadow:0 8px 24px rgba(0,0,0,.4)}.room-header{position:relative}.room-header img{width:100%;-o-object-fit:cover;object-fit:cover;height:180px}.room-header button[onclick*=openTimeline]{position:absolute;top:.5rem;right:.5rem;border-radius:.5rem;padding:.375rem .75rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background:rgba(100,108,255,.9);border:1px solid rgba(100,108,255,.3);color:#fff;backdrop-filter:blur(10px)}.room-header button[onclick*=openTimeline]:hover{background:#646cff;box-shadow:0 4px 12px rgba(100,108,255,.4)}.room-title-clickable{cursor:pointer;padding:.75rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background:rgba(26,29,35,.8);border-bottom:1px solid hsla(0,0%,100%,.06)}.room-title-clickable:hover{background:rgba(30,34,42,.9)}.room-title-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.room-title-main{min-width:0;flex:1 1 0%}.room-title-main h2{margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1rem;line-height:1.5rem;font-weight:700;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.room-badges{display:flex;flex-wrap:wrap;gap:.25rem}.room-expand-icon{flex-shrink:0;--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity,1));transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;font-size:1.25rem}.room-title-clickable.active .room-expand-icon{transform:rotate(180deg)}.room-info-panel{overflow:hidden;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s;max-height:0;opacity:0;background:rgba(18,21,26,.5)}.room-info-panel.active{max-height:400px;opacity:1}.room-info-description{position:relative;border-bottom-width:1px;padding:.75rem;font-size:.875rem;line-height:1.25rem;--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1));border-color:hsla(0,0%,100%,.06);line-height:1.4;max-height:60px;overflow:hidden;transition:max-height .3s ease}.room-info-description.expanded{max-height:500px;overflow-y:auto}.room-info-description:after{content:"... (click to expand)";position:absolute;bottom:3px;right:8px;background:linear-gradient(90deg,transparent,rgba(18,21,26,.9) 20%);padding-left:40px;color:rgba(167,139,250,.8);font-size:11px;font-style:italic;pointer-events:none}.room-info-description.expanded:after{content:"";display:none}.room-info-description:hover{cursor:pointer}.room-info-description.expanded{cursor:default}.room-info-description.expanded::-webkit-scrollbar{width:6px}.room-info-description.expanded::-webkit-scrollbar-track{background:rgba(0,0,0,.2);border-radius:3px}.room-info-description.expanded::-webkit-scrollbar-thumb{background:rgba(100,108,255,.4);border-radius:3px}.room-info-description.expanded::-webkit-scrollbar-thumb:hover{background:rgba(100,108,255,.6)}.room-info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem;padding:.75rem}.room-info-item{text-align:left}.room-info-label{margin-bottom:.125rem;display:flex;align-items:center;gap:.25rem;font-size:.75rem;line-height:1rem;text-transform:uppercase;letter-spacing:.05em;color:rgba(167,139,250,.7)}.room-info-label i{font-size:.75rem}.room-info-value{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;line-height:1.25rem;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.room-content-tabs{border-bottom-width:1px;padding:.5rem;background:rgba(18,21,26,.5);border-color:hsla(0,0%,100%,.06)}.room-content-tabs,.room-tab{display:flex;gap:.25rem}.room-tab{align-items:center;border-radius:.25rem;padding:.375rem .75rem;font-size:.75rem;line-height:1rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background:hsla(0,0%,100%,.03);border:1px solid hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.6)}.room-tab i{font-size:.875rem}.room-tab:hover{background:hsla(0,0%,100%,.06);color:hsla(0,0%,100%,.8)}.room-tab.active{background:rgba(100,108,255,.15);border-color:rgba(100,108,255,.3);color:#646cff}.room-content-area{padding:.75rem;background:rgba(18,21,26,.3);flex:1;overflow-y:auto;max-height:400px}.tab-content{display:none}.tab-content.active{display:block}.participants-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.participant-card{cursor:pointer;border-radius:.5rem;padding:.5rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background:rgba(26,29,35,.6);border:1px solid hsla(0,0%,100%,.1)}.participant-card:hover{background:rgba(30,34,42,.8);border-color:rgba(100,108,255,.3);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.3)}.participant-avatar{margin-bottom:.25rem;text-align:center}.participant-avatar img{max-height:80px;margin:0 auto}.participant-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;font-size:.75rem;line-height:1rem;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.outfits-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.outfit-card{cursor:pointer;overflow:hidden;border-radius:.5rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background:rgba(26,29,35,.6);border:1px solid hsla(0,0%,100%,.1);display:flex;flex-direction:column}.outfit-card:hover{border-color:rgba(100,108,255,.3);transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.3)}.outfit-card img{height:auto;width:100%;/* max-height:120px; */-o-object-fit:contain;object-fit:contain;flex:1;background:rgba(0,0,0,.2)}.outfit-info{padding:.375rem;text-align:center}.outfit-info .outfit-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1rem;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}#furnitureModalContent .furniture-card,#outfitsModalContent .outfit-card{min-height:220px}#outfitsModalContent .outfit-card img{/* max-height:200px!important; *//* padding:10px; */}#outfitsModalContent .outfit-info{padding:8px 12px}#outfitsModalContent .outfit-info .outfit-name{font-size:.875rem;white-space:normal;overflow:visible;text-overflow:clip;line-height:1.3}.furniture-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.furniture-card{border-radius:.5rem;padding:.5rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background:rgba(26,29,35,.6);border:1px solid hsla(0,0%,100%,.1);display:flex;flex-direction:column}.furniture-card:hover{background:rgba(30,34,42,.8);border-color:rgba(167,139,250,.3)}.furniture-image{margin-bottom:.25rem;text-align:center;flex:1;display:flex;align-items:center;justify-content:center}.furniture-image img{max-height:60px;margin:0 auto}.furniture-name{margin-bottom:.125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600;color:rgb(255 255 255/var(--tw-text-opacity,1))}.furniture-count,.furniture-name{text-align:center;font-size:.75rem;line-height:1rem;--tw-text-opacity:1}.furniture-count{color:rgb(107 114 128/var(--tw-text-opacity,1))}#furnitureModalContent .furniture-card{min-height:180px;padding:12px}#furnitureModalContent .furniture-image img{max-height:120px!important}#furnitureModalContent .furniture-name{font-size:.875rem;white-space:normal;overflow:visible;text-overflow:clip;line-height:1.3;margin-bottom:4px}#furnitureModalContent .furniture-count{font-size:.75rem}.session-navigation-panel{border-top-width:1px;border-bottom-width:1px;padding:.5rem;background:rgba(18,21,26,.5);border-color:hsla(0,0%,100%,.06)}.session-nav-controls{margin-bottom:.5rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem}.session-nav-btn{border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;line-height:1rem;font-weight:500;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;background:rgba(100,108,255,.1);border:1px solid rgba(100,108,255,.3);color:#646cff}.session-nav-btn:hover{background:rgba(100,108,255,.2)}.session-nav-btn:disabled{opacity:.3;cursor:not-allowed}.session-info-text{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.75rem;line-height:1rem;color:rgba(167,139,250,.8)}.snapshot-slider{height:.25rem;width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:rgba(100,108,255,.2);border-radius:5px;outline:none}.snapshot-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:12px;height:12px;background:#646cff;border-radius:50%;cursor:pointer}.snapshot-slider::-moz-range-thumb{width:12px;height:12px;background:#646cff;border-radius:50%;cursor:pointer;border:none}.hidden-room-banner{margin-bottom:1.5rem;border-radius:.75rem;padding:1.5rem;text-align:center;background:linear-gradient(135deg,rgba(26,29,35,.95),rgba(18,21,26,.95));backdrop-filter:blur(20px);border:1px solid rgba(236,72,153,.3)}.hidden-room-banner i{margin-bottom:.75rem;font-size:2.25rem;line-height:2.5rem;color:#ec4899}.hidden-room-banner h3{margin-bottom:.5rem;font-size:1.25rem;line-height:1.75rem;font-weight:700;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hidden-room-banner p{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.loading-room-card{padding:2rem;text-align:center}.loading-room-card i{margin-bottom:.75rem;font-size:2.25rem;line-height:2.5rem;color:#646cff;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.empty-state{padding:2rem;text-align:center}.empty-state i{margin-bottom:1rem;font-size:3rem;line-height:1;color:hsla(0,0%,100%,.2)}.empty-state h3{margin-bottom:.5rem;font-size:1.25rem;line-height:1.75rem;font-weight:600;--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.empty-state p{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity,1))}.badge{border-radius:.25rem;padding:.25rem .5rem;font-size:.75rem;line-height:1rem;font-weight:600}.badge-success{background:rgba(34,197,94,.15);color:#22c55e;border:1px solid rgba(34,197,94,.3)}.badge-warning{background:rgba(251,191,36,.15);color:#fbbf24;border:1px solid rgba(251,191,36,.3)}.badge-danger{background:rgba(239,68,68,.15);color:#ef4444;border:1px solid rgba(239,68,68,.3)}.badge-info{background:rgba(100,108,255,.15);color:#646cff;border:1px solid rgba(100,108,255,.3)}.hover\:translate-x-2:hover{--tw-translate-x:0.5rem;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\:bg-accent\/20:hover{background-color:rgba(100,108,255,.2)}.hover\:bg-accent\/80:hover{background-color:rgba(100,108,255,.8)}.hover\:bg-bgHover:hover{--tw-bg-opacity:1;background-color:rgb(31 34 41/var(--tw-bg-opacity,1))}.hover\:text-gray-300:hover{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity,1))}.hover\:text-purple:hover{--tw-text-opacity:1;color:rgb(167 139 250/var(--tw-text-opacity,1))}.hover\:text-white:hover{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.hover\:opacity-100:hover{opacity:1}.hover\:opacity-80:hover{opacity:.8}.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);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.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-accent:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(100 108 255/var(--tw-ring-opacity,1))}.group:hover .group-hover\:visible{visibility:visible}.group:hover .group-hover\:translate-y-0{--tw-translate-y:0px;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\:opacity-100{opacity:1}.dark\:bg-dark-800:is(.dark *){--tw-bg-opacity:1;background-color:rgb(30 41 59/var(--tw-bg-opacity,1))}.dark\:text-gray-200:is(.dark *){--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity,1))}@media (min-width:640px){.sm\:left-4{left:1rem}.sm\:block{display:block}.sm\:w-auto{width:auto}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:pl-12{padding-left:3rem}.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-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width:768px){.md\:w-64{width:16rem}.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\:flex-row{flex-direction:row}.md\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0px*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0px*var(--tw-space-y-reverse))}}@media (min-width:1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.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\:items-center{align-items:center}.lg\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1rem*var(--tw-space-x-reverse));margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)))}.lg\:space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(1.5rem*var(--tw-space-x-reverse));margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)))}}
/* ==================== CUSTOM GLOBAL OUTFIT BUTTON STYLES ==================== */
/* Outfit Action Buttons - Used across all room/outfit displays */
.outfit-action-btn {
    padding: 8px 16px !important;
    border: none !important;
    border-radius: 6px !important;
    color: white !important;
    cursor: pointer !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    transition: all 0.2s !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    white-space: nowrap !important;
    flex: 1 !important;
    max-width: 140px !important;
}

.outfit-action-btn:hover {
    transform: translateY(-2px);
}

.outfit-button-container {
    padding: 12px !important;
    background: linear-gradient(135deg, rgba(100, 108, 255, 0.08), rgba(100, 108, 255, 0.05)) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    flex-direction: row !important;
    border-top: 1px solid rgba(100, 108, 255, 0.15) !important;
}

/* Progress Bar Customization */
.progress-bar-container {
    position: relative !important;
    background: rgba(0, 0, 0, 0.4) !important;
    height: 15px !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    border: 1px solid rgba(100, 108, 255, 0.2) !important;
}

.progress-percentage {
    font-size: 15px !important;
    font-weight: 900 !important;
    color: #fff !important;
    text-shadow: 
        0 2px 8px rgba(0, 0, 0, 0.9),
        0 0 20px rgba(100, 108, 255, 0.5) !important;
    position: relative !important;
    z-index: 1 !important;
    letter-spacing: 2px !important;
}

/* ==================== PRODUCT MODAL STYLES (Global) ==================== */
/* Product Modal Overlay */
#productModal,
.modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 10000;
    background: rgba(0, 0, 0, 0.95);
    backdrop-filter: blur(4px);
    align-items: center;
    justify-content: center;
    padding: 20px;
}

#productModal[style*="display: flex"],
.modal-overlay[style*="display: flex"] {
    display: flex !important;
}

/* Product Modal Content */
#productModal .modal-content,
.modal-overlay .modal-content {
    background: linear-gradient(135deg, #1a1d23, #12151a);
    border: 1px solid rgba(100, 108, 255, 0.3);
    border-radius: 16px;
    max-width: min(94vw, 1400px);
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    padding: 32px;
    position: relative;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

/* Modal Close Button */
#productModal .modal-close-btn,
#modalCloseBtn,
.modal-overlay .modal-close-btn {
    position: absolute;
    top: 16px;
    right: 16px;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 8px;
    color: white;
    font-size: 32px;
    line-height: 1;
    padding: 4px 12px;
    cursor: pointer;
    transition: all 0.3s;
    z-index: 10001;
}

/* Ensure modal content containers have relative positioning for close buttons */
#productModal .modal-content,
.modal-overlay .modal-content,
.room-card-modal-container {
    position: relative !important;
}

/* Fix close buttons in card headers (outfits/furniture modals) */
.card-header {
    position: relative !important;
}

/* Close buttons in card headers */
.card-header button[onclick*="close"],
.card-header button[onclick*="Close"],
#outfitsModal .card-header button,
#furnitureModal .card-header button {
    position: absolute !important;
    top: 50% !important;
    right: 16px !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    z-index: 10 !important;
}

/* Profile close buttons */
.profile-close-btn {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    z-index: 10001 !important;
}

/* Room card modal close button */
.room-card-modal-close {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    z-index: 10 !important;
}


/* Modal Product Details */
#modalProductDetails {
    color: #fff;
}

#modalProductDetails h2 {
    color: #646cff;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 24px;
    padding-bottom: 16px;
    border-bottom: 2px solid rgba(100, 108, 255, 0.3);
}

/* Product Grid in Modal */
.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 20px;
    margin-top: 20px;
}

/* Individual Product Card */
.product-item {
    background: linear-gradient(145deg, rgba(26, 29, 35, 0.6), rgba(18, 21, 26, 0.6));
    border: 1px solid rgba(100, 108, 255, 0.2);
    border-radius: 12px;
    padding: 16px;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.product-item:hover {
    border-color: rgba(100, 108, 255, 0.4);
    transform: translateY(-2px);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

.product-item.hidden-product {
    border: 2px solid rgba(239, 68, 68, 0.5);
    background: linear-gradient(145deg, rgba(239, 68, 68, 0.1), rgba(239, 68, 68, 0.05));
}

.product-image {
    width: 100%;
    height: 150px;
    object-fit: contain;
    background: rgba(0, 0, 0, 0.3);
    border-radius: 8px;
    padding: 8px;
}

.product-name {
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    text-align: center;
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.product-creator {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.6);
    text-align: center;
}

.product-price {
    font-size: 14px;
    font-weight: 700;
    color: #10b981;
    text-align: center;
}

.product-link {
    display: inline-block;
    padding: 8px 16px;
    background: linear-gradient(135deg, #646cff, #4f46e5);
    color: white;
    text-decoration: none;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 600;
    text-align: center;
    transition: all 0.2s;
}

.product-link:hover {
    background: linear-gradient(135deg, #7078ff, #5056e3);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(100, 108, 255, 0.4);
}

.product-total {
    margin-top: 24px;
    padding: 16px;
    background: linear-gradient(135deg, rgba(100, 108, 255, 0.15), rgba(167, 139, 250, 0.1));
    border: 1px solid rgba(100, 108, 255, 0.3);
    border-radius: 12px;
    text-align: center;
}

.product-total-label {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.7);
    margin-bottom: 8px;
}

.product-total-amount {
    font-size: 32px;
    font-weight: 700;
    color: #10b981;
}

/* Scrollbar for modal content */
#productModal .modal-content::-webkit-scrollbar,
.modal-overlay .modal-content::-webkit-scrollbar {
    width: 8px;
}

#productModal .modal-content::-webkit-scrollbar-track,
.modal-overlay .modal-content::-webkit-scrollbar-track {
    background: #12151a;
    border-radius: 8px;
}

#productModal .modal-content::-webkit-scrollbar-thumb,
.modal-overlay .modal-content::-webkit-scrollbar-thumb {
    background: linear-gradient(145deg, #646cff, #7c3aed);
    border-radius: 8px;
}

#productModal .modal-content::-webkit-scrollbar-thumb:hover,
.modal-overlay .modal-content::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(145deg, #7c3aed, #ec4899);
}

/* Force modal display when style attribute is set */
#productModal[style*="display: flex"],
#productModal[style*="display: block"],
.modal-overlay[style*="display: flex"],
.modal-overlay[style*="display: block"] {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
}

/* Ensure modal is above everything */
#productModal {
    z-index: 99999 !important;
}

.modal-overlay {
    z-index: 99999 !important;
}

/* Product Meta Info (ID and Rating) */
.product-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 8px 0;
    padding: 8px;
    background: rgba(0, 0, 0, 0.2);
    border-radius: 6px;
    font-size: 11px;
}

.product-id {
    color: rgba(255, 255, 255, 0.5);
}

.product-rating {
    font-weight: 600;
    padding: 3px 8px;
    background: rgba(100, 108, 255, 0.2);
    border-radius: 4px;
    color: #646cff;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.hidden-product .product-meta {
    background: rgba(239, 68, 68, 0.1);
}

.hidden-product .product-rating {
    background: rgba(239, 68, 68, 0.2);
    color: #ef4444;
}

/* ==================== ROOM OWNER BADGE ==================== */
.room-owner-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    background: linear-gradient(135deg, rgba(100, 108, 255, 0.15), rgba(167, 139, 250, 0.1));
    border: 1px solid rgba(100, 108, 255, 0.3);
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
    color: #a78bfa;
    margin-top: 6px;
    white-space: nowrap;
    transition: all 0.2s ease;
}

.room-owner-badge i {
    color: #fbbf24;
    font-size: 13px;
}

.room-owner-badge:hover {
    background: linear-gradient(135deg, rgba(100, 108, 255, 0.25), rgba(167, 139, 250, 0.15));
    border-color: rgba(100, 108, 255, 0.5);
    transform: translateY(-1px);
}

/* Responsive adjustments */
@media (max-width: 640px) {
    .room-owner-badge {
        font-size: 11px;
        padding: 3px 10px;
        gap: 4px;
    }
    
    .room-owner-badge i {
        font-size: 11px;
    }
}

/* ==================== UNIFIED MODAL STYLING ==================== */
/* Apply to all modals: Outfits, Products, Furniture */

/* Modal Headers - Consistent across all modals */
#outfitsModal .card-header,
#furnitureModal .card-header,
#productModal .modal-content h2:first-child {
    background: linear-gradient(135deg, rgba(100, 108, 255, 0.15), rgba(167, 139, 250, 0.1));
    border-bottom: 2px solid rgba(100, 108, 255, 0.3);
    padding: 20px 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

#outfitsModal .card-header h2,
#furnitureModal .card-header h2,
#productModal h2:first-child {
    color: #8b9eff;
    font-size: 22px;
    font-weight: 700;
    margin: 0;
    display: flex;
    align-items: center;
    gap: 12px;
}

#outfitsModal .card-header i,
#furnitureModal .card-header i,
#productModal h2 i {
    color: #8b9eff;
    font-size: 24px;
}

/* Modal Stats Section (for Furniture) */
.furniture-stats-section,
.modal-stats-section {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 16px;
    padding: 20px 24px;
    background: rgba(0, 0, 0, 0.2);
    border-bottom: 1px solid rgba(100, 108, 255, 0.2);
}

.stat-box {
    text-align: center;
    padding: 16px;
    background: linear-gradient(145deg, rgba(100, 108, 255, 0.08), rgba(100, 108, 255, 0.04));
    border: 1px solid rgba(100, 108, 255, 0.2);
    border-radius: 12px;
}

.stat-box i {
    font-size: 32px;
    color: #8b9eff;
    margin-bottom: 8px;
    display: block;
}

.stat-box .stat-value {
    font-size: 28px;
    font-weight: 700;
    color: #fff;
    display: block;
    margin-bottom: 4px;
}

.stat-box .stat-label {
    font-size: 12px;
    color: rgba(255, 255, 255, 0.6);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Unified Card Styling - All modals */
.outfit-card,
.product-item,
.furniture-card,
#outfitsModalContent .outfit-card,
#furnitureModalContent .furniture-card,
#productModal .product-item {
    background: linear-gradient(145deg, rgba(26, 29, 35, 0.6), rgba(18, 21, 26, 0.6));
    border: 1px solid rgba(100, 108, 255, 0.2);
    border-radius: 12px;
    padding: 0;
    overflow: hidden;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
}

.outfit-card:hover,
.product-item:hover,
.furniture-card:hover {
    border-color: rgba(100, 108, 255, 0.4);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

/* Card Headers (for outfit/furniture cards) */
.outfit-card > div:first-child,
.furniture-card .furniture-name-header {
    background: rgba(100, 108, 255, 0.15);
    padding: 12px 16px;
    text-align: center;
    border-bottom: 1px solid rgba(100, 108, 255, 0.2);
}

.outfit-card h3,
.furniture-card .furniture-name {
    color: #8b9eff;
    margin: 0;
    font-size: 16px;
    font-weight: 700;
}

/* Card Images */
.product-item img.product-image,
.furniture-card img {
    width: 100%;
    height: 250px;
    object-fit: contain;
    background: rgba(0, 0, 0, 0.3);
    padding: 12px;
}

/* Outfit card images - larger display */
.outfit-card img {
    height: auto;
    width: 100%;
    object-fit: contain;
    flex: 1;
    background: rgba(0, 0, 0, 0.2);
}

/* Card Content/Info Sections */
.furniture-card .furniture-info {
    padding: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.furniture-creator,
.furniture-items {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.7);
}

.furniture-creator i,
.furniture-items i {
    color: #a78bfa;
    font-size: 14px;
}

/* Unified Button Styling - All modals */
.outfit-action-btn,
.product-link,
.furniture-view-btn,
button[onclick*="View"]:not(.room-3d-btn),
a[href*="imvu.com"] {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    flex-direction: row !important;
    padding: 10px 20px !important;
    background: linear-gradient(135deg, #646cff, #4f46e5) !important;
    color: white !important;
    text-decoration: none !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-align: center !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    width: 100% !important;
}

.outfit-action-btn:hover,
.product-link:hover,
.furniture-view-btn:hover,
button[onclick*="View"]:not(.room-3d-btn):hover,
a[href*="imvu.com"]:hover {
    background: linear-gradient(135deg, #7078ff, #5056e3) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(100, 108, 255, 0.4) !important;
}

/* Try On Button (green variant) */
button[onclick*="TryOnOutfit"],
.try-on-btn {
    background: linear-gradient(135deg, #10b981, #059669) !important;
}

button[onclick*="TryOnOutfit"]:hover,
.try-on-btn:hover {
    background: linear-gradient(135deg, #14b98a, #06a573) !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4) !important;
}

/* View in Shop Button (green variant for furniture) */
button[onclick*="View in Shop"],
.furniture-view-btn {
    background: linear-gradient(135deg, #10b981, #059669) !important;
}

button[onclick*="View in Shop"]:hover,
.furniture-view-btn:hover {
    background: linear-gradient(135deg, #14b98a, #06a573) !important;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.4) !important;
}

/* Grid Layouts - Consistent across all modals */
.products-grid,
#outfitsModalContent > div,
#furnitureModalContent .furniture-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 20px;
    padding: 24px;
}

/* Modal Close Buttons - Unified */
#outfitsModal button[onclick*="close"],
#furnitureModal button[onclick*="close"],
#productModal .modal-close-btn,
#modalCloseBtn {
    position: absolute;
    top: 16px;
    right: 16px;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 8px !important;
    color: white !important;
    font-size: 32px !important;
    line-height: 1 !important;
    padding: 4px 12px !important;
    cursor: pointer !important;
    transition: all 0.3s !important;
    z-index: 10001 !important;
    width: auto !important;
}


/* Ensure consistent modal backgrounds */
#outfitsModal,
#furnitureModal,
#productModal,
.modal-overlay {
    background: rgba(0, 0, 0, 0.95) !important;
    backdrop-filter: blur(4px) !important;
}

#outfitsModal .card,
#furnitureModal .card,
#productModal .modal-content {
    background: linear-gradient(135deg, #1a1d23, #12151a) !important;
    border: 1px solid rgba(100, 108, 255, 0.3) !important;
}

/* Scrollbar consistency */
#outfitsModalContent::-webkit-scrollbar,
#furnitureModalContent::-webkit-scrollbar,
#productModal .modal-content::-webkit-scrollbar {
    width: 8px;
}

#outfitsModalContent::-webkit-scrollbar-track,
#furnitureModalContent::-webkit-scrollbar-track,
#productModal .modal-content::-webkit-scrollbar-track {
    background: #12151a;
    border-radius: 8px;
}

#outfitsModalContent::-webkit-scrollbar-thumb,
#furnitureModalContent::-webkit-scrollbar-thumb,
#productModal .modal-content::-webkit-scrollbar-thumb {
    background: linear-gradient(145deg, #646cff, #7c3aed);
    border-radius: 8px;
}

#outfitsModalContent::-webkit-scrollbar-thumb:hover,
#furnitureModalContent::-webkit-scrollbar-thumb:hover,
#productModal .modal-content::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(145deg, #7c3aed, #ec4899);
}

/* ==================== FORCE CONSISTENT FURNITURE CARD STYLING ==================== */
/* Override any existing styles to match product modal */

#furnitureModalContent .room-products-grid > a,
#furnitureModalContent a[href*="imvu.com/next/shop"],
.room-products-grid > a {
    background: linear-gradient(145deg, rgba(26, 29, 35, 0.6), rgba(18, 21, 26, 0.6)) !important;
    border: 1px solid rgba(100, 108, 255, 0.2) !important;
    border-radius: 12px !important;
    padding: 0 !important;
    transition: all 0.3s ease !important;
    display: flex !important;
    flex-direction: column !important;
    text-decoration: none !important;
    color: inherit !important;
    overflow: hidden !important;
}

#furnitureModalContent .room-products-grid > a:hover,
#furnitureModalContent a[href*="imvu.com/next/shop"]:hover {
    border-color: rgba(100, 108, 255, 0.4) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4) !important;
}

/* Furniture card images - match product modal */
#furnitureModalContent img,
.room-products-grid img {
    width: 100% !important;
    height: 200px !important;
    object-fit: contain !important;
    background: rgba(0, 0, 0, 0.3) !important;
    padding: 12px !important;
    border-radius: 0 !important;
}

/* Furniture card content area */
#furnitureModalContent .room-products-grid > a > div {
    padding: 12px 16px !important;
}

/* Furniture product name */
#furnitureModalContent .room-products-grid > a > div:nth-child(2) {
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    min-height: 42px !important;
}

/* Furniture creator name */
#furnitureModalContent .room-products-grid > a > div:nth-child(3) {
    color: rgba(255, 255, 255, 0.6) !important;
    font-size: 12px !important;
    padding: 8px 16px !important;
}

/* Furniture item count */
#furnitureModalContent .room-products-grid > a > div:nth-child(4) {
    color: #a78bfa !important;
    font-size: 13px !important;
    padding: 8px 16px !important;
}

/* View in Shop button - inside furniture cards */
#furnitureModalContent .room-products-grid > a > div:last-child {
    background: linear-gradient(135deg, #10b981, #059669) !important;
    color: white !important;
    padding: 12px !important;
    border-radius: 0 0 12px 12px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-align: center !important;
    margin: 0 !important;
    margin-top: auto !important;
}

#furnitureModalContent .room-products-grid > a:hover > div:last-child {
    background: linear-gradient(135deg, #14b98a, #06a573) !important;
}

/* Ensure grid consistency */
#furnitureModalContent .room-products-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)) !important;
    gap: 20px !important;
    padding: 24px !important;
}

/* Furniture item count badge */
.furniture-card .product-item > div:nth-child(4),
.product-item > div[style*="clone"] {
    color: #a78bfa !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    padding: 8px 16px !important;
    background: rgba(167, 139, 250, 0.1) !important;
    border-radius: 6px !important;
    margin: 0 12px !important;
}

/* Ensure furniture cards are NOT links (use div wrapper instead) */

/* Furniture Item Count Badge */
.furniture-item-count {
    color: #a78bfa !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 10px 16px !important;
    background: rgba(167, 139, 250, 0.1) !important;
    border-top: 1px solid rgba(100, 108, 255, 0.1) !important;
    border-bottom: 1px solid rgba(100, 108, 255, 0.1) !important;
}

/* Product Creator Styling (consistent across all modals) */
.product-creator {
    color: rgba(255, 255, 255, 0.6) !important;
    font-size: 13px !important;
    text-align: center !important;
    padding: 8px 16px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
}

.product-creator i {
    color: #a78bfa !important;
    font-size: 14px !important;
}

/* Product Name Styling (consistent) */
.product-name {
    color: #fff !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    text-align: center !important;
    padding: 12px 16px !important;
    min-height: 50px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1.3 !important;
}

/* Product Price Styling */
.product-price {
    color: #10b981 !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    text-align: center !important;
    padding: 12px 16px !important;
    background: rgba(16, 185, 129, 0.1) !important;
    border-top: 1px solid rgba(16, 185, 129, 0.2) !important;
    border-bottom: 1px solid rgba(16, 185, 129, 0.2) !important;
}

/* Product Image - Consistent sizing */
.product-image {
    width: 100% !important;
    height: 200px !important;
    object-fit: contain !important;
    background: rgba(0, 0, 0, 0.3) !important;
    padding: 16px !important;
    border-radius: 0 !important;
}

/* Product Link Button - UNIFIED for all modals */
.product-link,
a.product-link,
.furniture-view-btn {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    flex-direction: row !important;
    padding: 14px 20px !important;
    background: linear-gradient(135deg, #646cff, #4f46e5) !important;
    color: white !important;
    text-decoration: none !important;
    border: none !important;
    border-radius: 0 0 12px 12px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    text-align: center !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    width: 100% !important;
    margin: 0 !important;
    margin-top: auto !important;
}

.product-link:hover,
a.product-link:hover,
.furniture-view-btn:hover {
    background: linear-gradient(135deg, #7078ff, #5056e3) !important;
    transform: translateY(0) !important;
    box-shadow: 0 0 20px rgba(100, 108, 255, 0.4) !important;
}


/* ==================== Button Row Styles (Unified) - UPDATED ==================== */
.button-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    flex-direction: row !important;
    padding: 0 12px 12px 12px !important;
}

.button-row .product-link {
    flex: 1 1 calc(50% - 3px) !important;
    min-width: 0 !important;
    width: auto !important;
    padding: 8px 4px !important;
    font-size: 11px !important;
    background: linear-gradient(135deg, #646cff, #4f46e5) !important;
    border-radius: 8px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.button-row .product-link:first-child {
    border-radius: 0 0 0 12px !important;
}

.button-row .product-link:last-child {
    border-radius: 0 0 12px 0 !important;
}

.button-row .product-link:hover {
    background: linear-gradient(135deg, #7078ff, #5056e3) !important;
    box-shadow: 0 0 20px rgba(100, 108, 255, 0.4) !important;
}

.button-row-single {
    padding: 0 12px 12px 12px !important;
}

.button-row-single .product-link {
    border-radius: 8px !important;
    width: 100% !important;
    padding: 8px !important;
    font-size: 11px !important;
}

/* Try On Button (Green) */
.try-on-btn {
    background: linear-gradient(135deg, #10b981, #059669) !important;
}

.try-on-btn:hover {
    background: linear-gradient(135deg, #14b98a, #06a573) !important;
    box-shadow: 0 0 20px rgba(16, 185, 129, 0.4) !important;
}

/* Hidden Product Buttons (Red) */
.hidden-product-btn {
    background: linear-gradient(135deg, #ef4444, #dc2626) !important;
}

.hidden-product-btn:hover {
    background: linear-gradient(135deg, #f87171, #ef4444) !important;
    box-shadow: 0 0 20px rgba(239, 68, 68, 0.4) !important;
}
/* Cache buster: 1764335878 */
/* Force reload: 1764336130574085240 */

/* ==================== FORCE BUTTON STYLING - NUCLEAR OPTION ==================== */
#furnitureModalContent .button-row .product-link,
#modalProductDetails .button-row .product-link,
#outfitsModalContent .button-row .product-link,
.button-row > a.product-link,
div.button-row > a[class="product-link"] {
    flex: 1 1 calc(50% - 3px) !important;
    min-width: 0 !important;
    background: linear-gradient(135deg, #646cff, #4f46e5) !important;
    border-radius: 8px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    flex-direction: row !important;
    padding: 8px 4px !important;
    color: white !important;
    text-decoration: none !important;
    border: none !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-align: center !important;
    transition: all 0.2s ease !important;
    cursor: pointer !important;
    width: auto !important;
    margin: 0 !important;
}

#furnitureModalContent .button-row .product-link:first-child,
#modalProductDetails .button-row .product-link:first-child,
#outfitsModalContent .button-row .product-link:first-child,
.button-row > a.product-link:first-child {
    border-radius: 0 0 0 12px !important;
}

#furnitureModalContent .button-row .product-link:last-child,
#modalProductDetails .button-row .product-link:last-child,
#outfitsModalContent .button-row .product-link:last-child,
.button-row > a.product-link:last-child {
    border-radius: 0 0 12px 0 !important;
}

#furnitureModalContent .button-row .product-link:hover,
#modalProductDetails .button-row .product-link:hover,
#outfitsModalContent .button-row .product-link:hover,
.button-row > a.product-link:hover {
    background: linear-gradient(135deg, #7078ff, #5056e3) !important;
    box-shadow: 0 0 20px rgba(100, 108, 255, 0.4) !important;
    transform: translateY(0) !important;
}

/* CSS VERSION UPDATE */
/* FORCED UPDATE: v3.1.0 - Icon Fix */

/* Room PID Badge - Match room-owner-badge styling */
.room-pid-badge {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 4px 12px !important;
    background: linear-gradient(135deg, rgba(100, 108, 255, 0.15), rgba(167, 139, 250, 0.1)) !important;
    border: 1px solid rgba(100, 108, 255, 0.3) !important;
    border-radius: 12px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    color: #a78bfa !important;
    margin-top: 6px !important;
    white-space: nowrap !important;
    transition: all 0.2s ease !important;
}

.room-pid-badge i {
    color: #8b9eff !important;
    font-size: 13px !important;
}

.room-pid-badge:hover {
    background: linear-gradient(135deg, rgba(100, 108, 255, 0.25), rgba(167, 139, 250, 0.15)) !important;
    border-color: rgba(100, 108, 255, 0.5) !important;
    transform: translateY(-1px) !important;
}

@media (max-width: 640px) {
    .room-pid-badge {
        font-size: 11px !important;
        padding: 3px 10px !important;
        gap: 4px !important;
    }
    .room-pid-badge i {
        font-size: 11px !important;
    }
}

/* ==================== MOBILE RESPONSIVE MODAL STYLES ==================== */
@media (max-width: 768px) {
    #productModal,
    .modal-overlay {
        padding: 12px !important;
    }
    
    #productModal .modal-content,
    .modal-overlay .modal-content {
        padding: 20px !important;
        max-width: 100% !important;
        border-radius: 12px !important;
        max-height: 95vh !important;
    }
    
    #productModal .modal-close-btn,
    #modalCloseBtn,
    .modal-overlay .modal-close-btn {
        top: 12px !important;
        right: 12px !important;
        width: 36px !important;
        height: 36px !important;
        font-size: 22px !important;
    }
    
    /* Modal product grid - 2 columns on mobile */
    #productModal .grid,
    .modal-overlay .grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    /* Modal heading */
    #productModal h3,
    .modal-overlay h3 {
        font-size: 18px !important;
    }
    
    /* Button row in modals */
    .button-row {
        flex-direction: column !important;
        gap: 8px !important;
    }
    
    .button-row > a,
    .button-row > button {
        width: 100% !important;
        border-radius: 8px !important;
    }
}

@media (max-width: 480px) {
    #productModal,
    .modal-overlay {
        padding: 8px !important;
    }
    
    #productModal .modal-content,
    .modal-overlay .modal-content {
        padding: 16px !important;
        border-radius: 8px !important;
    }
    
    /* Single column on small phones */
    #productModal .grid,
    .modal-overlay .grid {
        grid-template-columns: 1fr !important;
        gap: 10px !important;
    }
    
    .outfit-action-btn {
        padding: 6px 12px !important;
        font-size: 12px !important;
        max-width: none !important;
    }
    
    .outfit-button-container {
        padding: 10px !important;
        gap: 6px !important;
        flex-wrap: wrap !important;
    }
}
/* ==================== COMPREHENSIVE MOBILE STYLES ==================== */

/* ===== GLOBAL MOBILE UTILITIES ===== */
@media (max-width: 768px) {
    /* Container padding */
    .container, .container-fluid, .max-w-4xl, .max-w-6xl, .max-w-7xl {
        padding-left: 12px !important;
        padding-right: 12px !important;
    }
    
    /* Section boxes - less padding on mobile */
    .section-box, .card, .card-body {
        padding: 16px !important;
    }
    
    /* Headers - smaller on mobile */
    h1, .text-3xl, .text-4xl {
        font-size: 1.5rem !important;
        line-height: 1.3 !important;
    }
    
    h2, .text-2xl {
        font-size: 1.25rem !important;
    }
    
    /* Form inputs - full width */
    .form-input, input[type="text"], input[type="email"], input[type="password"], select, textarea {
        font-size: 16px !important; /* Prevents iOS zoom */
    }
    
    /* Flex gap adjustments */
    .gap-4 { gap: 12px !important; }
    .gap-6 { gap: 16px !important; }
    .gap-8 { gap: 20px !important; }
}

@media (max-width: 480px) {
    .section-box, .card, .card-body {
        padding: 12px !important;
    }
    
    h1, .text-3xl, .text-4xl {
        font-size: 1.25rem !important;
    }
    
    .gap-4 { gap: 8px !important; }
    .gap-6 { gap: 12px !important; }
}

/* ===== MOBILE GRIDS ===== */
@media (max-width: 768px) {
    /* Force 2 columns max on tablet */
    .grid-cols-3, .grid-cols-4, .lg\\:grid-cols-3, .lg\\:grid-cols-4,
    .xl\\:grid-cols-4, .xl\\:grid-cols-5 {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 480px) {
    /* Force single column on phone */
    .grid-cols-2, .grid-cols-3, .grid-cols-4,
    .sm\\:grid-cols-2, .md\\:grid-cols-2, .lg\\:grid-cols-3 {
        grid-template-columns: 1fr !important;
    }
    
    /* Exception: keep 2 columns for small items like products */
    .products-grid, .outfit-grid, .items-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* ===== MOBILE BUTTONS ===== */
@media (max-width: 768px) {
    .btn-primary, .btn-secondary, .btn-outline {
        padding: 10px 16px !important;
        font-size: 13px !important;
    }
    
    /* Stack buttons vertically in button groups */
    .flex.gap-4.justify-center.flex-wrap,
    .button-group, .btn-group {
        flex-direction: column !important;
        width: 100% !important;
    }
    
    .flex.gap-4.justify-center.flex-wrap > a,
    .flex.gap-4.justify-center.flex-wrap > button,
    .button-group > *, .btn-group > * {
        width: 100% !important;
    }
}

@media (max-width: 480px) {
    .btn-primary, .btn-secondary, .btn-outline {
        padding: 10px 14px !important;
        font-size: 12px !important;
    }
}

/* ===== MOBILE TABS ===== */
@media (max-width: 768px) {
    /* Tab buttons - icons above text */
    .tab-btn {
        flex-direction: column !important;
        padding: 10px 8px !important;
        gap: 4px !important;
        font-size: 10px !important;
        flex: 1 !important;
        text-align: center !important;
    }
    
    .tab-btn i {
        font-size: 16px !important;
        margin-right: 0 !important;
        margin-bottom: 2px !important;
    }
    
    /* Stats tabs in modals - smaller */
    .stats-tabs, .stats-tab {
        font-size: 11px !important;
        padding: 8px 12px !important;
    }
}

/* ===== MOBILE MODALS & POPOUTS ===== */
@media (max-width: 768px) {
    /* Full-screen modals on mobile */
    .modal, .modal-overlay, [class*="modal"] {
        padding: 8px !important;
    }
    
    .modal-content, [class*="modal-content"] {
        width: 100% !important;
        max-width: 100% !important;
        max-height: 90vh !important;
        margin: 0 !important;
        border-radius: 12px !important;
        overflow-y: auto !important;
    }
    
    /* Modal close button - larger touch target */
    .modal-close, .modal-close-btn, [class*="close"] {
        min-width: 44px !important;
        min-height: 44px !important;
        font-size: 24px !important;
    }
    
    /* Modal headers */
    .modal-header, [class*="modal"] h2, [class*="modal"] h3 {
        font-size: 16px !important;
        padding: 12px !important;
    }
    
    /* Modal body */
    .modal-body {
        padding: 12px !important;
    }
}

@media (max-width: 480px) {
    .modal-content, [class*="modal-content"] {
        max-height: 95vh !important;
        border-radius: 8px !important;
    }
}

/* ===== MOBILE CARDS ===== */
@media (max-width: 768px) {
    /* Room cards, user cards, etc */
    .room-card, .user-card, .outfit-card, .product-card {
        padding: 12px !important;
    }
    
    /* Card images */
    .card-image, .room-image, .avatar-image {
        max-width: 100% !important;
        height: auto !important;
    }
    
    /* Card actions */
    .card-actions, .card-footer {
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    
    .card-actions button, .card-footer button {
        flex: 1 !important;
        min-width: 100px !important;
    }
}

/* ===== MOBILE TABLES ===== */
@media (max-width: 768px) {
    /* Make tables scrollable */
    table, .table-container {
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }
    
    th, td {
        padding: 8px 10px !important;
        font-size: 12px !important;
        white-space: nowrap !important;
    }
}

/* ===== MOBILE SEARCH BOXES ===== */
@media (max-width: 768px) {
    .search-section, .search-container, .search-box {
        padding: 16px !important;
    }
    
    /* Stack search input and button */
    .search-row, .search-form {
        flex-direction: column !important;
        gap: 10px !important;
    }
    
    .search-row input, .search-form input {
        width: 100% !important;
    }
    
    .search-row button, .search-form button {
        width: 100% !important;
    }
}

/* ===== MOBILE ALERTS & NOTICES ===== */
@media (max-width: 768px) {
    .alert, .notice, .info-box {
        padding: 12px !important;
        font-size: 13px !important;
    }
    
    .alert i, .notice i {
        font-size: 16px !important;
    }
}

/* ===== MOBILE USER/AVATAR LISTS ===== */
@media (max-width: 768px) {
    .users-grid, .participants-grid, .avatars-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
    
    .user-item, .participant-item {
        padding: 8px !important;
        font-size: 12px !important;
    }
}

@media (max-width: 400px) {
    .users-grid, .participants-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ===== MOBILE PAGINATION ===== */
@media (max-width: 768px) {
    .pagination, .pagination-container {
        gap: 6px !important;
    }
    
    .pagination button, .pagination-btn {
        padding: 8px 12px !important;
        font-size: 12px !important;
        min-width: 36px !important;
    }
    
    /* Hide page numbers, show only prev/next */
    .pagination .page-numbers {
        display: none !important;
    }
    
    .pagination .page-indicator {
        display: inline-flex !important;
    }
}

/* ===== MOBILE DROPDOWNS ===== */
@media (max-width: 768px) {
    select, .dropdown, .styled-dropdown {
        width: 100% !important;
        padding: 12px !important;
        font-size: 14px !important;
    }
}

/* ===== MOBILE BADGES & TAGS ===== */
@media (max-width: 768px) {
    .badge, .tag, .chip {
        padding: 4px 8px !important;
        font-size: 10px !important;
    }
}

/* ===== MOBILE LIGHTBOX/IMAGE VIEWER ===== */
@media (max-width: 768px) {
    .lightbox, .image-viewer, #outfitLightbox {
        padding: 10px !important;
    }
    
    .lightbox img, .image-viewer img, #outfitLightbox img {
        max-width: 95% !important;
        max-height: 80vh !important;
    }
    
    .lightbox-close, .image-viewer-close {
        top: 10px !important;
        right: 10px !important;
        width: 40px !important;
        height: 40px !important;
        font-size: 24px !important;
    }
}

/* ===== MOBILE STATS/METRICS ===== */
@media (max-width: 768px) {
    .stats-container, .metrics-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
    }
    
    .stat-item, .metric-item {
        padding: 12px !important;
    }
    
    .stat-value, .metric-value {
        font-size: 18px !important;
    }
    
    .stat-label, .metric-label {
        font-size: 11px !important;
    }
}

@media (max-width: 400px) {
    .stats-container, .metrics-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ===== MOBILE TOOLTIPS ===== */
@media (max-width: 768px) {
    /* Convert tooltips to tap-to-show on mobile */
    [data-tooltip], .tooltip {
        position: relative;
    }
    
    .tooltip-content {
        position: fixed !important;
        bottom: 20px !important;
        left: 10px !important;
        right: 10px !important;
        max-width: none !important;
        z-index: 9999 !important;
    }
}

/* ===== MOBILE FLOATING ELEMENTS ===== */
@media (max-width: 768px) {
    /* Scroll to top button */
    .scroll-to-top, .back-to-top {
        bottom: 70px !important; /* Above mobile nav if any */
        right: 15px !important;
        width: 44px !important;
        height: 44px !important;
    }
    
    /* Fixed bottom bars */
    .fixed-bottom, .sticky-bottom {
        padding: 10px !important;
    }
}

/* ===== FIX iOS INPUT ZOOM ===== */
@media (max-width: 768px) {
    input, select, textarea {
        font-size: 16px !important; /* Prevents zoom on focus */
    }
}

/* ===== HIDE ON MOBILE / SHOW ON MOBILE ===== */
@media (max-width: 768px) {
    .hide-mobile, .desktop-only {
        display: none !important;
    }
    
    .show-mobile, .mobile-only {
        display: block !important;
    }
}

@media (min-width: 769px) {
    .show-mobile, .mobile-only {
        display: none !important;
    }
}

/* ============================================================================
   GLOBAL MOBILE FIXES - Applied to ALL Services
   Version 5.0.0 - Comprehensive mobile overflow prevention
   ============================================================================ */

/* Box sizing reset - prevent any element from causing overflow */
*, *::before, *::after {
    box-sizing: border-box !important;
}

@media (max-width: 768px) {
    /* ===== CRITICAL: Prevent horizontal overflow ===== */
    html {
        overflow-x: hidden !important;
        max-width: 100vw !important;
        width: 100% !important;
    }
    
    body {
        overflow-x: hidden !important;
        max-width: 100vw !important;
        width: 100% !important;
        min-height: 100vh !important;
    }
    
    /* ===== All containers must fit viewport ===== */
    .container,
    .container-custom,
    .container-search,
    .inner-container,
    main,
    section,
    article,
    .section,
    .section-lg,
    .section-md,
    .section-box,
    [class*="container"] {
        max-width: 100% !important;
        width: 100% !important;
        padding-left: 12px !important;
        padding-right: 12px !important;
        overflow-x: hidden !important;
        box-sizing: border-box !important;
    }
    
    /* ===== Tailwind max-width overrides ===== */
    .max-w-2xl,
    .max-w-3xl,
    .max-w-4xl,
    .max-w-5xl,
    .max-w-6xl,
    .max-w-7xl,
    .max-w-full,
    .max-w-md,
    .max-w-lg,
    .max-w-xl {
        max-width: calc(100% - 16px) !important;
        margin-left: 8px !important;
        margin-right: 8px !important;
    }
    
    /* ===== Main content area ===== */
    main.flex-1,
    .flex-1 {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }
    
    /* ===== Text wrapping ===== */
    h1, h2, h3, h4, h5, h6,
    p, span, div, a, label,
    .page-heading, .hero-title {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        hyphens: auto !important;
    }
    
    /* ===== Page headings ===== */
    .page-heading {
        font-size: 1.5rem !important;
        line-height: 1.2 !important;
    }
    
    .hero-title {
        font-size: 9px !important;
        letter-spacing: 2px !important;
    }
    
    /* ===== Section boxes ===== */
    .section-box {
        padding: 12px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        border-radius: 8px !important;
    }
    
    /* ===== Cards ===== */
    .card, .stat-card {
        padding: 12px !important;
        border-radius: 10px !important;
    }
    
    .card-body {
        padding: 12px !important;
    }
    
    .card-header {
        padding: 10px 12px !important;
    }
    
    /* ===== Search section ===== */
    .search-section {
        padding: 12px !important;
        border-radius: 10px !important;
    }
    
    /* ===== Alerts ===== */
    .alert {
        padding: 10px !important;
        border-radius: 8px !important;
        flex-direction: column !important;
        gap: 8px !important;
    }
    
    .alert > :not([hidden]) ~ :not([hidden]) {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }
    
    .alert p {
        font-size: 13px !important;
        line-height: 1.4 !important;
    }
    
    .alert i {
        font-size: 18px !important;
    }
    
    /* ===== Buttons ===== */
    .btn, .btn-primary, .btn-secondary, .btn-outline {
        padding: 10px 16px !important;
        font-size: 14px !important;
        border-radius: 8px !important;
        /* Note: width: 100% moved to 639px media query to not break sm:flex-row layouts */
    }
    
    /* ===== Form inputs ===== */
    .form-input,
    input[type="text"],
    input[type="search"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    select,
    textarea {
        width: 100% !important;
        max-width: 100% !important;
        font-size: 16px !important; /* Prevent iOS zoom */
        padding: 12px !important;
        border-radius: 8px !important;
    }
    
    /* Date selector - compact override for toolbar */
    #dateSelector {
        font-size: 11px !important;
        padding: 0 2rem 0 8px !important;
        height: 32px !important;
        width: auto !important;
    }
    
    /* Input with icon - adjust padding */
    input.pl-10, input.pl-12,
    .form-input.pl-10, .form-input.pl-12 {
        padding-left: 40px !important;
    }
    
    /* ===== Flex layouts ===== */
    .flex.gap-3,
    .flex.gap-4 {
        gap: 8px !important;
    }
    
    /* Stack flex rows on mobile - only below sm breakpoint (639px) */
    /* sm:flex-row should work at 640px+, so don't override it here */
    /* .sm\\:flex-row and .md\\:flex-row rules moved to narrower media query */
    
    /* ===== Grids ===== */
    /* Note: sm/md/lg grid overrides moved to appropriate breakpoint media queries below */
    .grid,
    .grid-cols-2,
    .grid-cols-3,
    .grid-cols-4 {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    
    /* Stats grid - 2 columns on mobile */
    .stat-card {
        padding: 12px !important;
    }
    
    .stat-value {
        font-size: 1.5rem !important;
    }
    
    .stat-label {
        font-size: 11px !important;
    }
    
    /* ===== Rooms container ===== */
    .rooms-container {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        padding: 0 !important;
    }
    
    .room-group {
        margin: 0 !important;
    }
    
    /* ===== Room content ===== */
    .room-header img {
        height: 140px !important;
    }
    
    .room-title-main h2 {
        font-size: 14px !important;
    }
    
    .room-info-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 8px !important;
        padding: 8px !important;
    }
    
    .room-info-label {
        font-size: 10px !important;
    }
    
    .room-info-value {
        font-size: 12px !important;
    }
    
    /* ===== Room tabs ===== */
    .room-content-tabs {
        padding: 6px !important;
        gap: 4px !important;
        justify-content: space-around !important;
    }
    
    .room-tab {
        padding: 8px !important;
        font-size: 10px !important;
        flex-direction: column !important;
        gap: 2px !important;
        flex: 1 !important;
        min-width: 0 !important;
    }
    
    .room-tab i {
        font-size: 16px !important;
    }
    
    .room-tab .tab-label {
        font-size: 9px !important;
    }
    
    /* ===== Participants/Outfits/Furniture grids ===== */
    .participants-grid,
    .outfits-grid,
    .furniture-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
    
    .participant-card,
    .outfit-card,
    .furniture-card {
        padding: 8px !important;
    }
    
    .participant-name,
    .outfit-info .outfit-name,
    .furniture-name {
        font-size: 11px !important;
    }
    
    /* ===== Modals/Popups ===== */
    .modal,
    .modal-overlay,
    [class*="Modal"],
    .fixed.inset-0 {
        padding: 0 !important;
    }
    
    .modal-content,
    .modal .card,
    [class*="Modal"] > .card,
    [class*="Modal"] > div {
        margin: 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        height: 100vh !important;
        max-height: 100vh !important;
        border-radius: 0 !important;
    }
    
    .modal-close-btn,
    #modalCloseBtn,
    [onclick*="close"] {
        min-width: 44px !important;
        min-height: 44px !important;
        font-size: 28px !important;
    }
    
    /* ===== Hidden room banner ===== */
    .hidden-room-banner {
        padding: 16px !important;
        margin-bottom: 12px !important;
    }
    
    .hidden-room-banner h3 {
        font-size: 16px !important;
    }
    
    .hidden-room-banner p {
        font-size: 13px !important;
    }
    
    /* ===== Badges ===== */
    .badge {
        padding: 3px 6px !important;
        font-size: 10px !important;
    }
    
    /* ===== Loading states ===== */
    .loading-room-card,
    .empty-state {
        padding: 24px 16px !important;
    }
    
    /* ===== Products grid ===== */
    [class*="products-grid"],
    [class*="product-grid"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }
    
    /* ===== Spacing adjustments ===== */
    .py-8 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
    }
    
    .mb-8 {
        margin-bottom: 1.5rem !important;
    }
    
    .mb-6 {
        margin-bottom: 1rem !important;
    }
    
    .gap-6 {
        gap: 1rem !important;
    }
    
    .gap-8 {
        gap: 1rem !important;
    }
}

/* ===== Below sm breakpoint (< 640px) - Stack sm:flex-row and sm:grid ===== */
@media (max-width: 639px) {
    .sm\\:flex-row {
        flex-direction: column !important;
    }
    .sm\\:grid-cols-2 {
        grid-template-columns: 1fr !important;
    }
    
    /* Full-width buttons when stacked vertically */
    .btn, .btn-primary, .btn-secondary, .btn-outline {
        width: 100% !important;
    }
    
    /* Make sm:w-auto buttons full width on mobile */
    .sm\\:w-auto {
        width: 100% !important;
    }
}

/* ===== Below md breakpoint (< 768px) - Stack md:flex-row and md:grid ===== */
@media (max-width: 767px) {
    .md\\:flex-row {
        flex-direction: column !important;
    }
    .md\\:grid-cols-2,
    .md\\:grid-cols-3 {
        grid-template-columns: 1fr !important;
    }
}

/* ===== Below lg breakpoint (< 1024px) - Stack lg:grid ===== */
@media (max-width: 1023px) {
    .lg\\:grid-cols-2,
    .lg\\:grid-cols-3,
    .lg\\:grid-cols-4 {
        grid-template-columns: 1fr !important;
    }
}

/* ===== Extra small screens (< 480px) ===== */
@media (max-width: 480px) {
    .page-heading {
        font-size: 1.25rem !important;
    }
    
    .container,
    .container-custom,
    main,
    [class*="container"] {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }
    
    .max-w-2xl,
    .max-w-3xl,
    .max-w-4xl,
    .max-w-5xl,
    .max-w-6xl,
    .max-w-7xl {
        margin-left: 4px !important;
        margin-right: 4px !important;
        max-width: calc(100% - 8px) !important;
    }
    
    .section-box,
    .card,
    .search-section {
        padding: 10px !important;
    }
    
    .alert {
        padding: 8px !important;
    }
    
    .alert p {
        font-size: 12px !important;
    }
    
    /* Single column grids on very small screens */
    .participants-grid,
    .outfits-grid,
    .furniture-grid {
        grid-template-columns: 1fr !important;
    }
    
    .room-tab {
        padding: 6px 4px !important;
    }
    
    .room-tab i {
        font-size: 14px !important;
    }
    
    .room-tab .tab-label {
        display: none !important;
    }
    
    .room-header img {
        height: 120px !important;
    }
}

/* Updated: 2025-12-13 - Comprehensive mobile responsive styles */
/* CSS v5.0.0 - Full mobile optimization for ALL services */

/* ===== FOOTER LAYOUT SHIFT PREVENTION ===== */
/* Adblock banner container - completely removed from layout when empty */
/* CRITICAL: Must never affect layout calculations when empty */
#adblock-banner-container {
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 999998 !important;
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
    height: 0 !important;
    max-height: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    opacity: 0 !important;
    /* Ensure it doesn't affect any layout calculations */
    contain: strict !important;
    will-change: auto !important;
}

/* Only show when it has content (banner is displayed) */
#adblock-banner-container:not(:empty) {
    display: block !important;
    visibility: visible !important;
    pointer-events: all !important;
    height: auto !important;
    max-height: none !important;
    min-height: auto !important;
    overflow: visible !important;
    opacity: 1 !important;
}

/* Ensure footer never shifts - prevent any margin/padding issues */
footer.mt-auto {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    position: relative !important;
    min-height: auto !important;
    max-height: none !important;
}

/* Prevent footer container from having extra spacing */
footer.mt-auto > .container-custom {
    margin-bottom: 0 !important;
    padding-bottom: 3rem !important; /* py-12 = 3rem */
}

/* Body padding is handled by JavaScript in adblock-detector.js */
/* No CSS-based padding to prevent layout shifts */

/* ==================== HOMEPAGE SCROLLBAR FIX ==================== */
/* AGGRESSIVE FIX: Prevent ALL unwanted scrollbars on homepage elements */

/* Global scrollbar hide for homepage sections */
.hero-section,
.hero-section *,
.hero-content,
.hero-content *,
.hero-stats-container,
.hero-stats-container *,
.hero-stats-primary,
.hero-stats-primary *,
.hero-stats-secondary,
.hero-stats-secondary *,
.hero-stat-card,
.hero-stat-card *,
.tool-category,
.tool-category *,
.tools-grid,
.tools-grid *,
.tool-card,
.tool-card *,
.tool-visual,
.tool-visual *,
.tool-content,
.tool-content *,
.showcase-wrapper,
.showcase-wrapper *,
.showcase-container,
.showcase-container *,
.section-header,
.section-header *,
.tech-badges,
.tech-badges *,
.tech-badge,
.tech-badge *,
.live-indicator,
.live-indicator *,
[class^="visual-"],
[class^="visual-"] *,
[class*="-container"],
[class*="-container"] *,
[class*="extraction"],
[class*="extraction"] *,
[class*="scanning"],
[class*="scanning"] *,
[class*="catalog"],
[class*="catalog"] *,
[class*="archive"],
[class*="archive"] *,
[class*="tracker"],
[class*="tracker"] *,
[class*="profile"],
[class*="profile"] *,
[class*="outfit"],
[class*="outfit"] *,
[class*="room"],
[class*="room"] *,
[class*="avatar"],
[class*="avatar"] *,
[class*="pulse"],
[class*="pulse"] *,
[class*="radar"],
[class*="radar"] * {
    overflow: hidden !important;
    overflow-x: hidden !important;
    overflow-y: hidden !important;
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
}

/* Webkit scrollbar hide for all above elements */
.hero-section::-webkit-scrollbar,
.hero-section *::-webkit-scrollbar,
.hero-content::-webkit-scrollbar,
.hero-content *::-webkit-scrollbar,
.tool-category::-webkit-scrollbar,
.tool-category *::-webkit-scrollbar,
.tools-grid::-webkit-scrollbar,
.tools-grid *::-webkit-scrollbar,
.tool-card::-webkit-scrollbar,
.tool-card *::-webkit-scrollbar,
.tool-visual::-webkit-scrollbar,
.tool-visual *::-webkit-scrollbar,
.tool-content::-webkit-scrollbar,
.tool-content *::-webkit-scrollbar,
.showcase-wrapper::-webkit-scrollbar,
.showcase-wrapper *::-webkit-scrollbar,
.showcase-container::-webkit-scrollbar,
.showcase-container *::-webkit-scrollbar,
[class^="visual-"]::-webkit-scrollbar,
[class^="visual-"] *::-webkit-scrollbar,
[class*="-container"]::-webkit-scrollbar,
[class*="-container"] *::-webkit-scrollbar,
[class*="extraction"]::-webkit-scrollbar,
[class*="extraction"] *::-webkit-scrollbar,
[class*="scanning"]::-webkit-scrollbar,
[class*="scanning"] *::-webkit-scrollbar,
[class*="catalog"]::-webkit-scrollbar,
[class*="catalog"] *::-webkit-scrollbar,
[class*="archive"]::-webkit-scrollbar,
[class*="archive"] *::-webkit-scrollbar,
[class*="tracker"]::-webkit-scrollbar,
[class*="tracker"] *::-webkit-scrollbar,
[class*="profile"]::-webkit-scrollbar,
[class*="profile"] *::-webkit-scrollbar,
[class*="outfit"]::-webkit-scrollbar,
[class*="outfit"] *::-webkit-scrollbar,
[class*="room"]::-webkit-scrollbar,
[class*="room"] *::-webkit-scrollbar,
[class*="avatar"]::-webkit-scrollbar,
[class*="avatar"] *::-webkit-scrollbar,
[class*="pulse"]::-webkit-scrollbar,
[class*="pulse"] *::-webkit-scrollbar,
[class*="radar"]::-webkit-scrollbar,
[class*="radar"] *::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    background: transparent !important;
}

/* Mobile-specific aggressive fix */
@media (max-width: 1024px) {
    .hero-section,
    .hero-section *,
    .tool-category,
    .tool-category *,
    .tool-card,
    .tool-card *,
    .tool-visual,
    .tool-visual *,
    .showcase-wrapper,
    .showcase-wrapper *,
    .showcase-container,
    .showcase-container *,
    .tools-grid,
    .tools-grid *,
    [class^="visual-"],
    [class^="visual-"] *,
    [class*="-container"],
    [class*="-container"] * {
        overflow: hidden !important;
        overflow-x: hidden !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: auto !important;
        scrollbar-width: none !important;
        -ms-overflow-style: none !important;
    }
}


/* Session navigation controls - responsive styles */
.session-nav-controls-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}

@media (min-width: 640px) {
  .session-nav-controls-row {
    gap: 20px;
    flex-wrap: nowrap;
  }
}

.session-nav-arrow {
  width: 36px;
  height: 36px;
  min-width: 36px;
  background: linear-gradient(135deg, #a78bfa, #8b5cf6);
  color: white;
  border: 1px solid rgba(167, 139, 250, 0.3);
  border-radius: 8px;
  cursor: pointer;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
  box-shadow: 0 2px 8px rgba(167, 139, 250, 0.3);
  flex-shrink: 0;
}

@media (min-width: 640px) {
  .session-nav-arrow {
    width: 44px;
    height: 44px;
    min-width: 44px;
    font-size: 16px;
  }
}

.session-nav-arrow:hover:not(:disabled) {
  transform: scale(1.05);
  box-shadow: 0 4px 16px rgba(167, 139, 250, 0.5);
}

.session-nav-arrow:disabled {
  background: rgba(167, 139, 250, 0.1);
  cursor: not-allowed;
  opacity: 0.4;
  box-shadow: none;
}

/* Session dropdown - use native picker on mobile for better UX */
.session-dropdown {
  background-color: #1a1d23 !important;
  background-image: none !important;
  color: white !important;
  border: 1px solid rgba(167, 139, 250, 0.3) !important;
  padding: 8px 10px !important;
  border-radius: 8px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  outline: none !important;
  min-width: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  transition: all 0.3s ease !important;
  flex: 1 1 0% !important;
  /* CRITICAL: Use native appearance on mobile for proper picker */
  -webkit-appearance: menulist !important;
  -moz-appearance: menulist !important;
  appearance: menulist !important;
}

@media (min-width: 769px) {
  /* Desktop: custom styled dropdown */
  .session-dropdown {
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
    background: linear-gradient(135deg, #1a1d23, #12151a) !important;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%23a78bfa' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E") !important;
    background-position: right 8px center !important;
    background-repeat: no-repeat !important;
    background-size: 16px !important;
    padding: 10px 32px 10px 16px !important;
    font-size: 13px !important;
    max-width: 280px !important;
    width: auto !important;
    flex: none !important;
  }
}

.session-dropdown:hover,
.session-dropdown:focus {
  border-color: rgba(167, 139, 250, 0.6) !important;
  box-shadow: 0 0 12px rgba(167, 139, 250, 0.3) !important;
}

/* MOBILE FIX: Override global select gradient for session dropdown */
@media (max-width: 768px) {
  select.session-dropdown,
  .session-dropdown,
  select[class*="session-dropdown"] {
    background: #1a1d23 !important;
    background-image: none !important;
    background-color: #1a1d23 !important;
    -webkit-appearance: menulist !important;
    -moz-appearance: menulist !important;
    appearance: menulist !important;
  }
}

/* ============================================================================
   HIDDEN PRODUCT — GATED (Non-Premium) Cards
   ============================================================================ */
@keyframes vuGatedFadeIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes vuGatedShimmer {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

.vu-hidden-gated {
  transition: transform 0.25s ease, border-color 0.25s ease;
}

.vu-hidden-gated:hover {
  transform: translateY(-3px) !important;
  border-color: rgba(251, 191, 36, 0.6) !important;
}

/* Animated shimmer stripe */
.vu-gated-shimmer {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
}

.vu-gated-shimmer::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(251, 191, 36, 0.06),
    transparent
  );
  animation: vuGatedShimmer 3s ease-in-out infinite;
}

/* Upgrade CTA button */
.vu-gated-upgrade-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  padding: 10px 0;
  margin-top: 4px;
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.2), rgba(245, 158, 11, 0.15));
  border: 1px solid rgba(251, 191, 36, 0.35);
  border-radius: 8px;
  color: #fbbf24;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  transition: all 0.25s ease;
  position: relative;
  z-index: 2;
}

.vu-gated-upgrade-btn:hover {
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.35), rgba(245, 158, 11, 0.25));
  box-shadow: 0 4px 16px rgba(251, 191, 36, 0.25);
  transform: translateY(-1px);
  color: #fcd34d;
}
