/*
! tailwindcss v3.4.1 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]{display:none}*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.sr-only{border-width:0}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.-top-3{top:-.75rem}.bottom-0{bottom:0}.bottom-2{bottom:.5rem}.bottom-4{bottom:1rem}.left-0{left:0}.left-1\/2{left:50%}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-2{right:.5rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-2{top:.5rem}.top-2\.5{top:.625rem}.top-20{top:5rem}.top-4{top:1rem}.z-10{z-index:10}.z-50{z-index:50}.z-\[60\]{z-index:60}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.-ml-1{margin-left:-.25rem}.-mr-2{margin-right:-.5rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-11{margin-left:2.75rem}.ml-16{margin-left:4rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.mt-0{margin-top:0}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-10{margin-top:2.5rem}.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}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-0{height:0}.h-0\.5{height:.125rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-32{height:8rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-56{height:14rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-\[320px\]{height:320px}.h-full{height:100%}.h-screen{height:100vh}.max-h-72{max-height:18rem}.max-h-\[80vh\]{max-height:80vh}.max-h-\[85vh\]{max-height:85vh}.max-h-\[90vh\]{max-height:90vh}.max-h-\[calc\(80vh-200px\)\]{max-height:calc(80vh - 200px)}.min-h-screen{min-height:100vh}.w-1\/2{width:50%}.w-1\/3{width:33.333333%}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-20{width:5rem}.w-28{width:7rem}.w-32{width:8rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-80{width:20rem}.w-96{width:24rem}.w-full{width:100%}.min-w-0{min-width:0}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-7xl{max-width:80rem}.max-w-lg{max-width:32rem}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-xs{max-width:20rem}.flex-1{flex:1 1}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.origin-top-right{transform-origin:top right}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-1\/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-1\/2{--tw-translate-y:-50%}.translate-x-1{--tw-translate-x:0.25rem}.translate-x-1,.translate-x-1\/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-x-1\/2{--tw-translate-x:50%}.translate-x-6{--tw-translate-x:1.5rem}.scale-110,.translate-x-6{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-110{--tw-scale-x:1.1;--tw-scale-y:1.1}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.resize{resize:both}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-x-4{column-gap:1rem}.gap-y-1{row-gap:.25rem}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.75rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.75rem*var(--tw-space-x-reverse))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1.5rem*var(--tw-space-x-reverse))}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.125rem*var(--tw-space-y-reverse));margin-top:calc(.125rem*(1 - var(--tw-space-y-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-10>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(2.5rem*var(--tw-space-y-reverse));margin-top:calc(2.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.5rem*var(--tw-space-y-reverse));margin-top:calc(.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.75rem*var(--tw-space-y-reverse));margin-top:calc(.75rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1.5rem*var(--tw-space-y-reverse));margin-top:calc(1.5rem*(1 - var(--tw-space-y-reverse)))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(2rem*var(--tw-space-y-reverse));margin-top:calc(2rem*(1 - var(--tw-space-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.whitespace-pre-line{white-space:pre-line}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{overflow-wrap:break-word}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-b-lg{border-bottom-left-radius:.5rem;border-bottom-right-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-blue-200{--tw-border-opacity:1;border-color:rgb(191 219 254/var(--tw-border-opacity))}.border-blue-300{--tw-border-opacity:1;border-color:rgb(147 197 253/var(--tw-border-opacity))}.border-blue-500{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity))}.border-blue-600{--tw-border-opacity:1;border-color:rgb(37 99 235/var(--tw-border-opacity))}.border-gray-100{--tw-border-opacity:1;border-color:rgb(243 244 246/var(--tw-border-opacity))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.border-gray-600{--tw-border-opacity:1;border-color:rgb(75 85 99/var(--tw-border-opacity))}.border-green-200{--tw-border-opacity:1;border-color:rgb(187 247 208/var(--tw-border-opacity))}.border-green-300{--tw-border-opacity:1;border-color:rgb(134 239 172/var(--tw-border-opacity))}.border-green-500{--tw-border-opacity:1;border-color:rgb(34 197 94/var(--tw-border-opacity))}.border-green-600{--tw-border-opacity:1;border-color:rgb(22 163 74/var(--tw-border-opacity))}.border-indigo-200{--tw-border-opacity:1;border-color:rgb(199 210 254/var(--tw-border-opacity))}.border-purple-200{--tw-border-opacity:1;border-color:rgb(233 213 255/var(--tw-border-opacity))}.border-red-200{--tw-border-opacity:1;border-color:rgb(254 202 202/var(--tw-border-opacity))}.border-red-300{--tw-border-opacity:1;border-color:rgb(252 165 165/var(--tw-border-opacity))}.border-red-400{--tw-border-opacity:1;border-color:rgb(248 113 113/var(--tw-border-opacity))}.border-slate-600{--tw-border-opacity:1;border-color:rgb(71 85 105/var(--tw-border-opacity))}.border-transparent{border-color:#0000}.border-white{--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity))}.border-yellow-200{--tw-border-opacity:1;border-color:rgb(254 240 138/var(--tw-border-opacity))}.border-yellow-300{--tw-border-opacity:1;border-color:rgb(253 224 71/var(--tw-border-opacity))}.border-yellow-400{--tw-border-opacity:1;border-color:rgb(250 204 21/var(--tw-border-opacity))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity))}.bg-black\/0{background-color:#0000}.bg-black\/50{background-color:#00000080}.bg-blue-100{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity))}.bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity))}.bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.bg-gray-400{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity))}.bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.bg-gray-600{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity))}.bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}.bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity))}.bg-green-100{--tw-bg-opacity:1;background-color:rgb(220 252 231/var(--tw-bg-opacity))}.bg-green-400{--tw-bg-opacity:1;background-color:rgb(74 222 128/var(--tw-bg-opacity))}.bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity))}.bg-green-500\/30{background-color:#22c55e4d}.bg-green-600{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity))}.bg-green-700{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity))}.bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity))}.bg-orange-600{--tw-bg-opacity:1;background-color:rgb(234 88 12/var(--tw-bg-opacity))}.bg-pink-100{--tw-bg-opacity:1;background-color:rgb(252 231 243/var(--tw-bg-opacity))}.bg-pink-600{--tw-bg-opacity:1;background-color:rgb(219 39 119/var(--tw-bg-opacity))}.bg-purple-100{--tw-bg-opacity:1;background-color:rgb(243 232 255/var(--tw-bg-opacity))}.bg-purple-50{--tw-bg-opacity:1;background-color:rgb(250 245 255/var(--tw-bg-opacity))}.bg-purple-600{--tw-bg-opacity:1;background-color:rgb(147 51 234/var(--tw-bg-opacity))}.bg-red-100{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity))}.bg-red-400{--tw-bg-opacity:1;background-color:rgb(248 113 113/var(--tw-bg-opacity))}.bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity))}.bg-red-700{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.bg-slate-700{--tw-bg-opacity:1;background-color:rgb(51 65 85/var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.bg-white\/20{background-color:#fff3}.bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(254 249 195/var(--tw-bg-opacity))}.bg-yellow-50{--tw-bg-opacity:1;background-color:rgb(254 252 232/var(--tw-bg-opacity))}.bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(234 179 8/var(--tw-bg-opacity))}.bg-yellow-600{--tw-bg-opacity:1;background-color:rgb(202 138 4/var(--tw-bg-opacity))}.bg-yellow-800{--tw-bg-opacity:1;background-color:rgb(133 77 14/var(--tw-bg-opacity))}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-opacity-90{--tw-bg-opacity:0.9}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.from-black\/70{--tw-gradient-from:#000000b3 var(--tw-gradient-from-position);--tw-gradient-to:#0000 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-400{--tw-gradient-from:#60a5fa var(--tw-gradient-from-position);--tw-gradient-to:#60a5fa00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from:#eff6ff var(--tw-gradient-from-position);--tw-gradient-to:#eff6ff00 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from:#3b82f6 var(--tw-gradient-from-position);--tw-gradient-to:#3b82f600 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-gray-500{--tw-gradient-from:#6b7280 var(--tw-gradient-from-position);--tw-gradient-to:#6b728000 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-pink-500{--tw-gradient-from:#ec4899 var(--tw-gradient-from-position);--tw-gradient-to:#ec489900 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-blue-600{--tw-gradient-to:#2563eb var(--tw-gradient-to-position)}.to-gray-600{--tw-gradient-to:#4b5563 var(--tw-gradient-to-position)}.to-indigo-100{--tw-gradient-to:#e0e7ff var(--tw-gradient-to-position)}.to-pink-600{--tw-gradient-to:#db2777 var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to:#0000 var(--tw-gradient-to-position)}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0{padding-bottom:0;padding-top:0}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-12{padding-bottom:3rem;padding-top:3rem}.py-16{padding-bottom:4rem;padding-top:4rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.pb-1{padding-bottom:.25rem}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pl-10{padding-left:2.5rem}.pl-3{padding-left:.75rem}.pr-4{padding-right:1rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-middle{vertical-align:middle}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-9xl{font-size:8rem;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-extrabold{font-weight:800}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-4{line-height:1rem}.leading-6{line-height:1.5rem}.leading-8{line-height:2rem}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.text-blue-100{--tw-text-opacity:1;color:rgb(219 234 254/var(--tw-text-opacity))}.text-blue-200{--tw-text-opacity:1;color:rgb(191 219 254/var(--tw-text-opacity))}.text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity))}.text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity))}.text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}.text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity))}.text-green-700{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity))}.text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity))}.text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity))}.text-orange-600{--tw-text-opacity:1;color:rgb(234 88 12/var(--tw-text-opacity))}.text-pink-500{--tw-text-opacity:1;color:rgb(236 72 153/var(--tw-text-opacity))}.text-purple-500{--tw-text-opacity:1;color:rgb(168 85 247/var(--tw-text-opacity))}.text-purple-600{--tw-text-opacity:1;color:rgb(147 51 234/var(--tw-text-opacity))}.text-purple-800{--tw-text-opacity:1;color:rgb(107 33 168/var(--tw-text-opacity))}.text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity))}.text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity))}.text-yellow-600{--tw-text-opacity:1;color:rgb(202 138 4/var(--tw-text-opacity))}.text-yellow-700{--tw-text-opacity:1;color:rgb(161 98 7/var(--tw-text-opacity))}.text-yellow-800{--tw-text-opacity:1;color:rgb(133 77 14/var(--tw-text-opacity))}.underline{text-decoration-line:underline}.placeholder-gray-500::placeholder{--tw-placeholder-opacity:1;color:rgb(107 114 128/var(--tw-placeholder-opacity))}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-90{opacity:.9}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.shadow,.shadow-lg{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.shadow-md{--tw-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--tw-shadow-colored:0 4px 6px -1px var(--tw-shadow-color),0 2px 4px -2px var(--tw-shadow-color)}.shadow-md,.shadow-sm{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-black{--tw-ring-opacity:1;--tw-ring-color:rgb(0 0 0/var(--tw-ring-opacity))}.ring-opacity-5{--tw-ring-opacity:0.05}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-shadow{transition-duration:.15s;transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.focus-within\:border-blue-500:focus-within{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity))}.focus-within\:ring-2:focus-within{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus-within\:ring-blue-500:focus-within{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity))}.hover\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-blue-400:hover{--tw-border-opacity:1;border-color:rgb(96 165 250/var(--tw-border-opacity))}.hover\:border-gray-300:hover{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.hover\:border-gray-400:hover{--tw-border-opacity:1;border-color:rgb(156 163 175/var(--tw-border-opacity))}.hover\:bg-black\/20:hover{background-color:#0003}.hover\:bg-black\/70:hover{background-color:#000000b3}.hover\:bg-blue-50:hover{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity))}.hover\:bg-gray-100:hover{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.hover\:bg-gray-400:hover{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.hover\:bg-gray-700:hover{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}.hover\:bg-green-50:hover{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity))}.hover\:bg-green-700:hover{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity))}.hover\:bg-green-800:hover{--tw-bg-opacity:1;background-color:rgb(22 101 52/var(--tw-bg-opacity))}.hover\:bg-indigo-50:hover{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity))}.hover\:bg-orange-700:hover{--tw-bg-opacity:1;background-color:rgb(194 65 12/var(--tw-bg-opacity))}.hover\:bg-pink-700:hover{--tw-bg-opacity:1;background-color:rgb(190 24 93/var(--tw-bg-opacity))}.hover\:bg-purple-50:hover{--tw-bg-opacity:1;background-color:rgb(250 245 255/var(--tw-bg-opacity))}.hover\:bg-purple-700:hover{--tw-bg-opacity:1;background-color:rgb(126 34 206/var(--tw-bg-opacity))}.hover\:bg-red-100:hover{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity))}.hover\:bg-red-50:hover{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.hover\:bg-red-800:hover{--tw-bg-opacity:1;background-color:rgb(153 27 27/var(--tw-bg-opacity))}.hover\:bg-white\/30:hover{background-color:#ffffff4d}.hover\:bg-yellow-50:hover{--tw-bg-opacity:1;background-color:rgb(254 252 232/var(--tw-bg-opacity))}.hover\:bg-yellow-700:hover{--tw-bg-opacity:1;background-color:rgb(161 98 7/var(--tw-bg-opacity))}.hover\:bg-yellow-900:hover{--tw-bg-opacity:1;background-color:rgb(113 63 18/var(--tw-bg-opacity))}.hover\:text-blue-600:hover{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity))}.hover\:text-blue-700:hover{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity))}.hover\:text-gray-500:hover{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.hover\:text-gray-800:hover{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}.hover\:text-gray-900:hover{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.hover\:text-green-800:hover{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity))}.hover\:text-green-900:hover{--tw-text-opacity:1;color:rgb(20 83 45/var(--tw-text-opacity))}.hover\:text-indigo-800:hover{--tw-text-opacity:1;color:rgb(55 48 163/var(--tw-text-opacity))}.hover\:text-purple-800:hover{--tw-text-opacity:1;color:rgb(107 33 168/var(--tw-text-opacity))}.hover\:text-red-700:hover{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity))}.hover\:text-red-800:hover{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity))}.hover\:text-yellow-800:hover{--tw-text-opacity:1;color:rgb(133 77 14/var(--tw-text-opacity))}.hover\:text-yellow-900:hover{--tw-text-opacity:1;color:rgb(113 63 18/var(--tw-text-opacity))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.hover\:shadow-lg:hover,.hover\:shadow-sm:hover{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.hover\:shadow-sm:hover{--tw-shadow:0 1px 2px 0 #0000000d;--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color)}.focus\:border-blue-500:focus{--tw-border-opacity:1;border-color:rgb(59 130 246/var(--tw-border-opacity))}.focus\:border-red-500:focus{--tw-border-opacity:1;border-color:rgb(239 68 68/var(--tw-border-opacity))}.focus\:border-transparent:focus{border-color:#0000}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-1: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(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-1:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-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)}.focus\:ring-inset:focus{--tw-ring-inset:inset}.focus\:ring-blue-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(59 130 246/var(--tw-ring-opacity))}.focus\:ring-gray-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(107 114 128/var(--tw-ring-opacity))}.focus\:ring-green-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(34 197 94/var(--tw-ring-opacity))}.focus\:ring-pink-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(236 72 153/var(--tw-ring-opacity))}.focus\:ring-purple-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(168 85 247/var(--tw-ring-opacity))}.focus\:ring-red-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(239 68 68/var(--tw-ring-opacity))}.focus\:ring-yellow-500:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(234 179 8/var(--tw-ring-opacity))}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-100:disabled{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.disabled\:bg-gray-300:disabled{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.disabled\:bg-gray-400:disabled{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity))}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:opacity-100{opacity:1}@media (min-width:640px){.sm\:mx-auto{margin-left:auto;margin-right:auto}.sm\:ml-6{margin-left:1.5rem}.sm\:mt-0{margin-top:0}.sm\:mt-12{margin-top:3rem}.sm\:mt-5{margin-top:1.25rem}.sm\:mt-8{margin-top:2rem}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:hidden{display:none}.sm\:h-72{height:18rem}.sm\:w-auto{width:auto}.sm\:max-w-xl{max-width:36rem}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-center{justify-content:center}.sm\:justify-between{justify-content:space-between}.sm\:space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(2rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(2rem*var(--tw-space-x-reverse))}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-20{padding-bottom:5rem;padding-top:5rem}.sm\:pb-16{padding-bottom:4rem}.sm\:text-center{text-align:center}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-8xl{font-size:6rem;line-height:1}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}}@media (min-width:768px){.md\:order-1{order:1}.md\:order-2{order:2}.md\:col-span-2{grid-column:span 2/span 2}.md\:mt-0{margin-top:0}.md\:mt-16{margin-top:4rem}.md\:mt-5{margin-top:1.25rem}.md\:flex{display:flex}.md\:grid{display:grid}.md\:h-96{height:24rem}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}.md\:justify-between{justify-content:space-between}.md\:gap-x-8{column-gap:2rem}.md\:gap-y-10{row-gap:2.5rem}.md\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.md\:p-12{padding:3rem}.md\:px-10{padding-left:2.5rem;padding-right:2.5rem}.md\:py-4{padding-bottom:1rem;padding-top:1rem}.md\:pb-20{padding-bottom:5rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-9xl{font-size:8rem;line-height:1}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width:1024px){.lg\:absolute{position:absolute}.lg\:inset-y-0{bottom:0;top:0}.lg\:right-0{right:0}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:col-span-4{grid-column:span 4/span 4}.lg\:mx-0{margin-left:0;margin-right:0}.lg\:mx-auto{margin-left:auto;margin-right:auto}.lg\:mt-20{margin-top:5rem}.lg\:block{display:block}.lg\:h-full{height:100%}.lg\:w-1\/2{width:50%}.lg\:w-full{width:100%}.lg\:max-w-2xl{max-width:42rem}.lg\:max-w-md{max-width:28rem}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.lg\:justify-start{justify-content:flex-start}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:pb-28{padding-bottom:7rem}.lg\:text-left{text-align:left}.lg\:text-center{text-align:center}.lg\:text-\[10rem\]{font-size:10rem}}@media (min-width:1280px){.xl\:mt-28{margin-top:7rem}.xl\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.xl\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.xl\:pb-32{padding-bottom:8rem}}.loading-spinner-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:20px}.loading-spinner-container.small{padding:10px}.loading-spinner-container.large{padding:40px}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:30px;width:30px}.loading-spinner-container.small .loading-spinner{border-width:2px;height:20px;width:20px}.loading-spinner-container.large .loading-spinner{border-width:4px;height:50px;width:50px}.loading-message{color:#666;font-size:14px;margin-top:10px;text-align:center}.loading-spinner-container.small .loading-message{font-size:12px;margin-top:5px}.loading-spinner-container.large .loading-message{font-size:16px;margin-top:15px}.admin-navigation{background:#2c3e50;box-sizing:border-box;color:#fff;flex-direction:column;height:100%;max-width:280px;min-width:0;overflow:hidden;transition:all .3s ease;width:280px}.admin-navigation.collapsed{min-width:0;width:0}.admin-nav-header{background:#2c3e50;border-bottom:1px solid #34495e;padding:6px 16px;text-align:center}.admin-nav-title{color:#ecf0f1;font-size:16px;font-weight:700;margin:0}.admin-nav-section-title{color:#95a5a6;font-size:.75rem;letter-spacing:.05em;margin:0;padding:2px 20px}.admin-navigation.collapsed .admin-nav-header{padding:20px 10px}.admin-nav-list{list-style:none;margin:0;overflow:hidden;padding:0}.admin-nav-item{margin:0}.admin-nav-button{background:none;border:none;box-sizing:border-box;color:#bdc3c7;max-width:100%;overflow:hidden;padding:8px 16px;position:relative;text-align:left;width:100%}.admin-navigation.collapsed .admin-nav-button{justify-content:center;padding:16px}.admin-nav-button:hover{background:#34495e;color:#ecf0f1}.admin-nav-button.active{background:#3498db}.admin-nav-button.active:before{background:#2980b9;bottom:0;content:"";left:0;position:absolute;top:0;width:4px}.admin-nav-icon{font-size:18px;min-width:20px;text-align:center}.admin-nav-label{flex:1 1;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-navigation.collapsed .admin-nav-label{display:none}.admin-nav-indicator{background:#2980b9;border-radius:50%;height:6px;position:absolute;right:16px;width:6px}.admin-navigation.collapsed .admin-nav-indicator{display:none}.admin-nav-section{padding:20px}.admin-nav-section-title{color:#7f8c8d;font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.admin-navigation.collapsed .admin-nav-section-title{display:none}.admin-nav-quick-action{align-items:center;background:none;border:none;border-radius:6px;color:#bdc3c7;cursor:pointer;display:flex;font-size:13px;gap:8px;margin-bottom:8px;padding:12px;transition:all .2s ease;width:100%}.admin-navigation.collapsed .admin-nav-quick-action{justify-content:center;padding:12px}.admin-nav-quick-action:hover{background:#34495e;color:#ecf0f1}.admin-navigation.collapsed .admin-nav-quick-action span:not(.admin-nav-icon){display:none}.admin-nav-footer{margin-top:auto;padding:6px 16px}.admin-nav-info{text-align:center}.admin-nav-role-badge{display:flex;justify-content:center}.admin-nav-role-badge .admin-badge,.admin-nav-role-badge .super-admin-badge,.admin-nav-role-badge .user-badge{font-size:10px;padding:4px 8px}@media (max-width:768px){.admin-navigation{box-shadow:2px 0 10px #0000001a;height:calc(100vh - 100px);left:0;position:fixed;top:60px;transform:translateX(-100%);transition:transform .3s ease;width:280px;z-index:999}.admin-navigation.open{transform:translateX(0)}.admin-navigation.collapsed{width:280px}.admin-navigation.collapsed .admin-nav-button{justify-content:flex-start;padding:16px 20px}.admin-navigation.collapsed .admin-nav-label,.admin-navigation.collapsed .admin-nav-quick-action span:not(.admin-nav-icon),.admin-navigation.collapsed .admin-nav-section-title{display:block}}.admin-header{align-items:center;background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;display:flex;height:60px;justify-content:space-between;padding:0 24px;position:relative;z-index:1000}.admin-header-left{align-items:center;display:flex;gap:16px}.admin-sidebar-toggle{background:none;border:none;border-radius:4px;cursor:pointer;padding:8px;transition:background-color .2s ease}.admin-sidebar-toggle:hover{background:#f8f9fa}.hamburger-icon{display:flex;flex-direction:column;gap:3px;width:20px}.hamburger-icon span{background:#495057;border-radius:1px;height:2px;transition:all .3s ease}.admin-header-title h1{color:#212529;font-size:20px;font-weight:600;margin:0}.admin-brand{align-items:center;display:flex;gap:12px}.brand-text{color:#212529;font-size:20px;font-weight:600;margin:0}.welcome-text{color:#6c757d;font-size:16px;font-weight:400;margin:0}.admin-breadcrumb{align-items:center;color:#6c757d;display:flex;font-size:12px;gap:8px;margin-top:2px}.breadcrumb-separator{color:#dee2e6}.admin-header-center{display:flex;flex:1 1;justify-content:center}.admin-header-right{align-items:center;display:flex;gap:16px}.admin-quick-actions{align-items:center;display:flex;gap:8px}.admin-quick-action-btn{align-items:center;background:none;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:12px;gap:6px;padding:8px 12px;transition:all .2s ease}.admin-quick-action-btn:hover{background:#f8f9fa;border-color:#3498db;color:#3498db}.action-label{font-weight:500}.admin-header-right .notification-bell-container{margin:0 8px}.admin-user-menu{position:relative}.admin-user-button{align-items:center;background:none;border:1px solid #dee2e6;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:6px 12px;transition:all .2s ease}.admin-user-button:hover{background:#f8f9fa;border-color:#3498db}.user-avatar{align-items:center;background:linear-gradient(135deg,#3498db,#2980b9);border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.user-info{align-items:flex-start;text-align:left}.user-name{color:#212529;font-size:13px;line-height:1.2}.user-role{color:#6c757d;font-size:11px;line-height:1.2;text-transform:capitalize}.dropdown-arrow{color:#6c757d;font-size:10px;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(180deg)}.admin-user-dropdown{background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 4px 12px #00000026;margin-top:8px;min-width:220px;position:absolute;right:0;top:100%;z-index:1001}.user-dropdown-header{border-bottom:1px solid #e9ecef;padding:16px}.user-dropdown-info strong{color:#212529;display:block;font-size:14px;margin-bottom:4px}.user-dropdown-info span{color:#6c757d;display:block;font-size:12px;margin-bottom:8px}.user-role-badge{display:flex;justify-content:flex-start}.user-dropdown-actions{padding:8px 0}.dropdown-action{align-items:center;background:none;border:none;color:#495057;cursor:pointer;display:flex;font-size:13px;gap:12px;padding:12px 16px;text-align:left;transition:background-color .2s ease;width:100%}.dropdown-action:hover{background:#f8f9fa}.dropdown-action.logout-action{color:#dc3545}.dropdown-action.logout-action:hover{background:#f8d7da}.dropdown-separator{background:#e9ecef;height:1px;margin:8px 0}.admin-overlay{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}@media (max-width:768px){.admin-header{padding:0 16px}.admin-header-title h1{font-size:18px}.admin-breadcrumb,.admin-header-center{display:none}.admin-quick-actions{gap:4px}.admin-quick-action-btn{padding:6px 8px}.action-label,.user-info{display:none}.admin-user-dropdown{min-width:200px;right:-8px}}@media (max-width:480px){.admin-header{padding:0 12px}.admin-header-left{gap:12px}.admin-header-title h1{font-size:16px}.admin-quick-actions{display:none}}.admin-layout{background-color:#f8f9fa;display:grid;grid-template-areas:"header header" "sidebar main" "footer footer";grid-template-columns:280px 1fr;grid-template-rows:60px 1fr 40px;height:100vh;overflow:hidden;transition:grid-template-columns .3s ease}.admin-layout.sidebar-collapsed{grid-template-columns:0 1fr}.admin-layout .admin-header{background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;grid-area:header;z-index:1000}.admin-sidebar{background:#2c3e50;border-right:1px solid #34495e;grid-area:sidebar;overflow:hidden;transition:all .3s ease}.admin-main{grid-area:main;min-height:0;overflow-y:auto;padding:0}.admin-content{height:100%;max-width:100%;overflow:hidden;padding:24px}.admin-content.no-padding{padding:0}.admin-contacts-layout{height:100%}.admin-footer{align-items:center;background:#fff;border-top:1px solid #e9ecef;color:#6c757d;display:flex;font-size:12px;grid-area:footer;padding:0 24px}.admin-footer-content{align-items:center;display:flex;justify-content:space-between;width:100%}.admin-footer-left{align-items:center;display:flex;gap:8px}.admin-footer-separator{color:#dee2e6}.admin-footer-right{align-items:center;display:flex;gap:8px}.super-admin-badge{background:linear-gradient(135deg,#e74c3c,#c0392b)}.admin-badge,.super-admin-badge{border-radius:12px;color:#fff;font-size:10px;font-weight:600;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.admin-badge{background:linear-gradient(135deg,#3498db,#2980b9)}.user-badge{background:linear-gradient(135deg,#95a5a6,#7f8c8d);border-radius:12px;color:#fff;font-size:10px;font-weight:600;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.admin-unauthorized{align-items:center;display:flex;height:100%;justify-content:center;min-height:400px}.unauthorized-content{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:500px;padding:40px;text-align:center}.unauthorized-content h2{color:#e74c3c;font-size:24px;margin-bottom:16px}.unauthorized-content p{color:#6c757d;line-height:1.5;margin-bottom:8px}@media (max-width:768px){.admin-layout{grid-template-areas:"header" "main" "footer";grid-template-columns:1fr;grid-template-rows:60px 1fr 40px}.admin-sidebar{height:calc(100vh - 100px);left:0;position:fixed;top:60px;transform:translateX(-100%);transition:transform .3s ease;width:280px;z-index:999}.admin-layout.sidebar-open .admin-sidebar{transform:translateX(0)}.admin-content{padding:16px}.admin-footer-content{flex-direction:column;gap:4px;text-align:center}.admin-footer-left{justify-content:center}}@media (max-width:480px){.admin-content{padding:12px}.unauthorized-content{margin:16px;padding:24px}.unauthorized-content h2{font-size:20px}}.admin-loading{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:200px}.admin-loading-spinner{animation:spin 1s linear infinite;border:3px solid #e9ecef;border-radius:50%;border-top-color:#3498db;height:40px;width:40px}.admin-loading-text{color:#6c757d;font-size:14px}.admin-error{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:200px;text-align:center}.admin-error-icon{color:#dc3545;font-size:48px}.admin-error-title{color:#212529;font-size:18px;font-weight:600;margin:0}.admin-error-message{color:#6c757d;font-size:14px;margin:0;max-width:400px}.admin-error-actions{display:flex;gap:12px;margin-top:16px}.admin-page-content{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:24px}.admin-page-header{border-bottom:1px solid #e9ecef;margin-bottom:24px;padding:24px 24px 0}.admin-page-title{color:#212529;font-size:24px;font-weight:600;margin:0 0 8px}.admin-page-subtitle{color:#6c757d;font-size:14px;margin:0 0 16px}.admin-page-actions{display:flex;gap:12px;margin-bottom:16px}.admin-action-btn{align-items:center;background:#3498db;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.admin-action-btn:hover{background:#2980b9;transform:translateY(-1px)}.admin-action-btn.secondary{background:#fff;border:1px solid #dee2e6;color:#495057}.admin-action-btn.secondary:hover{background:#f8f9fa;border-color:#3498db;color:#3498db}.admin-action-btn.danger{background:#dc3545}.admin-action-btn.danger:hover{background:#c82333}.admin-page-body{padding:24px}.admin-card-header{padding:16px 20px}.admin-card-title{font-size:16px}.admin-card-body{padding:20px}.admin-stats-grid{grid-gap:20px;gap:20px;margin-bottom:24px}.admin-stat-card{padding:20px}.admin-stat-value{color:#3498db;margin:0 0 8px}.admin-stat-label{margin:0}.admin-stat-change{margin-top:4px}.admin-stat-change.positive{color:#28a745}.admin-stat-change.negative{color:#dc3545}.notification-bell-container{position:relative}.notification-bell-button{background:none;border:none;color:#4b5563;cursor:pointer;font-size:20px;padding:8px;position:relative;transition:color .2s}.notification-bell-button:hover{color:#1f2937}.notification-badge{background-color:#ef4444;border-radius:10px;color:#fff;font-size:11px;font-weight:700;min-width:18px;padding:2px 6px;position:absolute;right:0;text-align:center;top:0}.notification-dropdown{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0000001a;display:flex;flex-direction:column;margin-top:8px;max-height:480px;position:absolute;right:0;top:100%;width:360px;z-index:1000}.notification-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px}.notification-header h3{color:#1f2937;font-size:18px;margin:0}.notification-actions{display:flex;gap:8px}.clear-all-btn,.mark-all-read-btn{background:none;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;font-size:14px;padding:4px 8px;transition:background-color .2s}.clear-all-btn:hover,.mark-all-read-btn:hover{background-color:#eff6ff}.notification-list{flex:1 1;max-height:400px;overflow-y:auto}.notification-empty,.notification-loading{color:#6b7280;padding:48px 16px;text-align:center}.notification-empty .empty-icon{display:block;font-size:48px;margin-bottom:12px;opacity:.5}.notification-empty p{font-size:14px;margin:0}.notification-item{border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;gap:12px;padding:12px 16px;position:relative;transition:background-color .2s}.notification-item:hover{background-color:#f9fafb}.notification-item.unread{background-color:#eff6ff}.notification-item.unread:hover{background-color:#dbeafe}.notification-icon{flex-shrink:0;font-size:20px}.notification-content{flex:1 1;min-width:0}.notification-content h4{color:#1f2937;font-size:14px;font-weight:600;margin:0 0 4px}.notification-content p{color:#4b5563;font-size:14px;line-height:1.4;margin:0 0 4px}.notification-time{color:#9ca3af;font-size:12px}.notification-delete{background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;font-size:20px;line-height:1;opacity:0;padding:4px 8px;position:absolute;right:8px;top:8px;transition:all .2s}.notification-item:hover .notification-delete{opacity:1}.notification-delete:hover{background-color:#fee2e2;color:#dc2626}.cashapp-payment-container{margin:20px 0}.cashapp-payment-btn{background:linear-gradient(135deg,#00d632,#00b82c);border:none;border-radius:8px;box-shadow:0 2px 8px #00d6324d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:16px 20px;transition:all .3s ease;width:100%}.cashapp-payment-btn:hover{background:linear-gradient(135deg,#00b82c,#009e26);box-shadow:0 4px 12px #00d63266;transform:translateY(-1px)}.cashapp-payment-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.cashapp-btn-content{align-items:center;display:flex;gap:12px;justify-content:center}.cashapp-logo{font-size:20px}.cashapp-text{flex:1 1;text-align:center}.cashapp-amount{background:#fff3;border-radius:4px;font-weight:700;padding:4px 8px}.cashapp-description{color:#666;font-size:14px;margin-bottom:0;margin-top:8px;text-align:center}.cashapp-instructions-modal{align-items:center;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.cashapp-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;left:0;position:absolute;right:0;top:0}.cashapp-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.cashapp-modal-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:24px;padding:24px 24px 0}.cashapp-modal-header h3{color:#333;font-size:24px;font-weight:600;margin:0}.cashapp-close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.cashapp-close-btn:hover{background:#f5f5f5;color:#666}.cashapp-modal-body{padding:0 24px 24px}.cashapp-instructions,.cashapp-step{margin-bottom:24px}.cashapp-step{align-items:flex-start;display:flex;gap:16px}.cashapp-step-number{align-items:center;background:#00d632;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:32px;justify-content:center;width:32px}.cashapp-step-content{flex:1 1}.cashapp-step-content p{color:#333;line-height:1.5;margin:0 0 8px}.cashapp-step-content p:last-child{margin-bottom:0}.cashapp-prisoner-id{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;gap:12px;margin:8px 0;padding:12px}.cashapp-prisoner-id code{background:#fff;border:1px solid #ddd;border-radius:4px;color:#00d632;flex:1 1;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:16px;font-weight:600;padding:8px 12px}.cashapp-copy-btn{background:#00d632;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background .2s ease}.cashapp-copy-btn:hover{background:#00b82c}.cashapp-note{color:#666;font-size:14px;font-style:italic}.cashapp-url-display{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-bottom:24px;padding:16px}.cashapp-url-display p{color:#333;font-weight:600;margin:0 0 8px}.cashapp-url{background:#fff;border:1px solid #ddd;border-radius:4px;padding:12px}.cashapp-url code{color:#666;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;word-break:break-all}.cashapp-modal-footer{display:flex;flex-wrap:wrap;gap:12px;padding:0 24px 24px}.cashapp-open-btn{align-items:center;background:#00d632;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:background .2s ease}.cashapp-open-btn:hover{background:#00b82c}.cashapp-confirm-btn{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 24px;transition:background .2s ease}.cashapp-confirm-btn:hover{background:#0056b3}.cashapp-cancel-btn{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:background .2s ease}.cashapp-cancel-btn:hover{background:#545b62}.cashapp-cancel-btn:disabled,.cashapp-confirm-btn:disabled,.cashapp-open-btn:disabled{background:#ccc;cursor:not-allowed}@media (max-width:768px){.cashapp-modal-content{margin:10px;max-height:95vh}.cashapp-modal-body,.cashapp-modal-footer,.cashapp-modal-header{padding-left:16px;padding-right:16px}.cashapp-modal-footer{flex-direction:column}.cashapp-step{gap:12px}.cashapp-step-number{font-size:14px;height:28px;width:28px}.cashapp-prisoner-id{align-items:stretch;flex-direction:column}.cashapp-copy-btn{align-self:flex-start}}.auth-layout{align-items:center;background:linear-gradient(135deg,#1e3a8a,#1e40af 30%,#1f2937 70%,#111827);display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;height:calc(100vh - 102px);justify-content:center;padding:10px}.auth-container{margin:0 auto;max-width:700px;width:100%}.auth-logo{margin-bottom:.25rem;text-align:center}.auth-logo h1{color:#fff;font-size:2rem;font-weight:700;margin:0;text-shadow:0 2px 4px #0000001a}.auth-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1e293bf2;border:1px solid #3b82f633;border-radius:16px;box-shadow:0 20px 40px #0006;margin-bottom:.5rem;overflow:hidden}.auth-header{border-bottom:1px solid #3b82f633;padding:.75rem 2.5rem .5rem;text-align:center}.auth-title{color:#e2e8f0;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.auth-subtitle{color:#94a3b8;font-size:.9rem;line-height:1.4;margin:0}.auth-content{padding:.75rem 2.5rem 1rem}.auth-footer{color:#fffc;font-size:.8rem;text-align:center}.auth-footer p{margin:0}.auth-form{display:flex;flex-direction:column;gap:.5rem}.form-group{gap:.25rem}.form-label{font-weight:500}.form-input,.form-label{color:#e2e8f0;font-size:.9rem}.form-input{background:#1e293bcc;border:2px solid #3b82f64d;border-radius:8px;padding:.5rem;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b98133;outline:none}.form-input::placeholder{color:#94a3b8}.form-input.error{border-color:#e74c3c}.form-input.success{border-color:#27ae60}.form-error{color:#e74c3c}.form-error,.form-success{font-size:.8rem;margin-top:.25rem}.form-success{color:#27ae60}.auth-button{background:linear-gradient(135deg,#10b981,#3b82f6);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;overflow:hidden;padding:.75rem 1.5rem;position:relative;transition:transform .2s ease,box-shadow .2s ease}.auth-button:hover:not(:disabled){box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{cursor:not-allowed;opacity:.6}.auth-button.loading{color:#0000}.auth-button.loading:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.auth-button.secondary{background:#1e293bcc;border:2px solid #10b981;color:#10b981}.auth-button.secondary:hover:not(:disabled){background:#10b981;color:#fff}.auth-divider{align-items:center;color:#94a3b8;display:flex;font-size:.9rem;margin:.5rem 0}.auth-divider:after,.auth-divider:before{background:#3b82f64d;content:"";flex:1 1;height:1px}.auth-divider:before{margin-right:1rem}.auth-divider:after{margin-left:1rem}.auth-link{color:#10b981;font-weight:500;text-decoration:none;transition:color .2s ease}.auth-link:hover{color:#3b82f6;text-decoration:underline}.auth-links{border-top:1px solid #3b82f633;color:#94a3b8;font-size:.9rem;margin-top:.5rem;padding-top:.5rem;text-align:center}.auth-alert{border-radius:8px;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem}.auth-alert.error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.auth-alert.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.auth-alert.info{background:#eff6ff;border:1px solid #bfdbfe;color:#2563eb}.auth-alert.warning{background:#fffbeb;border:1px solid #fed7aa;color:#d97706}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container .form-input{padding-right:3rem}.password-toggle{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:1rem;padding:.25rem;position:absolute;right:.75rem;transition:color .2s ease}.password-toggle:hover:not(:disabled){color:#e2e8f0}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.checkbox-label{align-items:flex-start;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;line-height:1.4}.checkbox-label input[type=checkbox]{flex-shrink:0;margin:.1rem 0 0}.checkbox-text{color:#94a3b8}.checkbox-label:hover .checkbox-text{color:#e2e8f0}.form-actions{flex-direction:column;gap:.5rem}.forgot-password-link{background:none;border:none;cursor:pointer;font-size:.9rem;padding:0;text-align:center}@media (max-width:768px){.auth-layout{padding:15px}.auth-container{max-width:95%}.auth-content{padding:1.5rem 2rem 2rem}.auth-header{padding:1.5rem 2rem 1rem}.auth-logo h1{font-size:1.75rem}.auth-title{font-size:1.35rem}.form-row{gap:1rem;grid-template-columns:1fr}.checkbox-label{font-size:.9rem}}@media (max-width:480px){.auth-content{padding:1rem 1.5rem 1.5rem}.auth-header{padding:1.25rem 1.5rem 1rem}.auth-logo h1{font-size:1.5rem}.auth-title{font-size:1.25rem}.checkbox-label{font-size:.85rem}}.google-login-button{background:#fff;border:2px solid #dadce0;border-radius:8px;color:#3c4043;cursor:pointer;font-size:1rem;font-weight:500;overflow:hidden;padding:.75rem 1rem;position:relative;transition:all .2s ease;width:100%}.google-login-button:hover:not(:disabled){background:#f8f9fa;border-color:#dadce0;box-shadow:0 1px 3px #0000001a}.google-login-button:focus{border-color:#4285f4;box-shadow:0 0 0 3px #4285f41a;outline:none}.google-login-button:active:not(:disabled){background:#f1f3f4;box-shadow:0 1px 2px #0000001a}.google-login-button:disabled{background:#f8f9fa;cursor:not-allowed;opacity:.6}.google-login-button.loading{color:#0000}.google-login-button.loading:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#4285f4;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.google-login-content{align-items:center;display:flex;gap:.75rem;justify-content:center}.google-icon{flex-shrink:0;height:20px;width:20px}.google-login-text{font-weight:500;white-space:nowrap}@media (max-width:480px){.google-login-button{padding:.875rem 1rem}.google-login-content{gap:.5rem}.google-icon{height:18px;width:18px}.google-login-text{font-size:.9rem}}@media (prefers-contrast:high){.google-login-button{border-color:#000;color:#000}.google-login-button:hover:not(:disabled){background:#000;color:#fff}}@media (prefers-reduced-motion:reduce){.google-login-button{transition:none}.google-login-button.loading:after{animation:none}}.password-strength{margin-top:.5rem}.strength-bar{margin-bottom:1rem}.strength-bar-label{align-items:center;display:flex;font-size:.85rem;justify-content:space-between;margin-bottom:.5rem}.strength-text{font-weight:600}.strength-bar-container{border-radius:2px;display:flex;gap:2px;height:4px;overflow:hidden}.strength-bar-segment{background-color:#e1e5e9;flex:1 1;transition:background-color .3s ease}.strength-bar-segment.active{background-color:var(--strength-color)}.strength-requirements{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;padding:.75rem}.requirements-title{color:#495057;font-size:.8rem;font-weight:600;margin-bottom:.5rem}.requirements-list{display:flex;flex-direction:column;gap:.25rem;list-style:none;margin:0;padding:0}.requirements-list li{align-items:center;display:flex;font-size:.75rem;gap:.5rem}.requirement-icon{align-items:center;border-radius:50%;display:flex;font-size:.7rem;font-weight:700;height:14px;justify-content:center;width:14px}.requirements-list li.valid{color:#28a745}.requirements-list li.valid .requirement-icon{background-color:#28a745;color:#fff}.requirements-list li.invalid{color:#6c757d}.requirements-list li.invalid .requirement-icon{background-color:#6c757d;color:#fff}@media (max-width:480px){.strength-bar-label{align-items:flex-start;flex-direction:column;gap:.25rem}.requirements-list{gap:.5rem}.requirements-list li{font-size:.8rem}}.email-verification-message{background:#fff;border:1px solid;border-radius:8px;display:flex;gap:1rem;margin:1rem 0;padding:1.5rem}.email-verification-message.pending{background:#eff6ff;border-color:#3b82f6}.email-verification-message.success{background:#f0fdf4;border-color:#10b981}.email-verification-message.error{background:#fef2f2;border-color:#ef4444}.email-verification-message.resent{background:#f5f3ff;border-color:#8b5cf6}.verification-icon{align-items:flex-start;display:flex;flex-shrink:0;font-size:2rem;padding-top:.25rem}.verification-content{flex:1 1;min-width:0}.verification-title{color:#111827;font-size:1.125rem;font-weight:600;margin:0 0 .5rem}.verification-message{color:#4b5563;line-height:1.5;margin:0 0 1rem}.verification-email{background:#0000000d;border-radius:4px;font-size:.9rem;margin:.75rem 0;padding:.5rem;word-break:break-all}.verification-email strong{color:#374151}.verification-actions{border-top:1px solid #0000001a;margin-top:1rem;padding-top:1rem}.resend-text{color:#6b7280;font-size:.9rem;margin:0 0 .75rem}.resend-button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.5rem 1rem;transition:background-color .2s ease}.resend-button:hover:not(:disabled){background:#2563eb}.resend-button:disabled{background:#9ca3af;cursor:not-allowed}.resend-cooldown{background:#0000000d;border-radius:4px;margin-top:.75rem;padding:.5rem}.resend-cooldown p{color:#6b7280;font-size:.85rem;margin:0;text-align:center}.verification-error{background:#fef2f2;border:1px solid #fecaca;border-radius:4px;margin-top:.75rem;padding:.5rem}.verification-error p{color:#dc2626;font-size:.85rem;margin:0}.email-verification-message.pending .verification-title{color:#1d4ed8}.email-verification-message.success .verification-title{color:#059669}.email-verification-message.error .verification-title{color:#dc2626}.email-verification-message.resent .verification-title{color:#7c3aed}.email-verification-message.success .resend-button{background:#10b981}.email-verification-message.success .resend-button:hover:not(:disabled){background:#059669}.email-verification-message.error .resend-button{background:#ef4444}.email-verification-message.error .resend-button:hover:not(:disabled){background:#dc2626}.email-verification-message.resent .resend-button{background:#8b5cf6}.email-verification-message.resent .resend-button:hover:not(:disabled){background:#7c3aed}@media (max-width:480px){.email-verification-message{flex-direction:column;gap:.75rem;padding:1rem}.verification-icon{align-self:center;font-size:1.5rem}.verification-title{font-size:1rem;text-align:center}.verification-message{font-size:.9rem;text-align:center}.resend-button{padding:.75rem;width:100%}}@media (prefers-contrast:high){.email-verification-message{border-width:2px}.resend-cooldown,.verification-email{background:#0000001a;border:1px solid #0000004d}}.admin-stats-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.admin-stat-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:24px;text-align:center;transition:all .2s ease}.admin-stat-card:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db1a;transform:translateY(-2px)}.admin-stat-value{color:#212529;font-size:32px;font-weight:700;line-height:1;margin-bottom:8px}.admin-stat-label{color:#6c757d;font-size:14px;font-weight:500;letter-spacing:.5px;margin-bottom:8px;text-transform:uppercase}.admin-stat-change{border-radius:4px;display:inline-block;font-size:12px;font-weight:500;padding:4px 8px}.admin-stat-change.positive{background:#d4edda;color:#155724}.admin-stat-change.negative{background:#f8d7da;color:#721c24}.admin-card{background:#fff;border:1px solid #e9ecef;border-radius:8px;margin-bottom:24px;overflow:hidden}.admin-card-header{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:20px 24px}.admin-card-title{color:#212529;font-size:18px;font-weight:600;margin:0}.admin-card-body{padding:24px}.quick-actions-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.quick-action-card{align-items:center;background:#fff;border:1px solid #e9ecef;border-radius:8px;color:inherit;cursor:pointer;display:flex;padding:20px;text-decoration:none;transition:all .2s ease}.quick-action-card:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db1a;transform:translateY(-2px)}.quick-action-icon{flex-shrink:0;font-size:32px;margin-right:16px}.quick-action-content{flex:1 1}.quick-action-title{color:#212529;font-size:16px;font-weight:600;margin:0 0 4px}.quick-action-description{color:#6c757d;font-size:14px;line-height:1.4;margin:0}.quick-action-arrow{color:#3498db;font-size:18px;margin-left:16px;transition:transform .2s ease}.quick-action-card:hover .quick-action-arrow{transform:translateX(4px)}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{align-items:flex-start;border-bottom:1px solid #f8f9fa;display:flex;gap:12px;padding:12px 0}.activity-item:last-child{border-bottom:none}.activity-status{border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.activity-status.success{background:#28a745}.activity-status.info{background:#17a2b8}.activity-status.warning{background:#ffc107}.activity-status.error{background:#dc3545}.activity-content{flex:1 1}.activity-message{color:#212529;font-size:14px;line-height:1.4;margin:0 0 4px}.activity-timestamp{color:#6c757d;font-size:12px}.health-metrics{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.health-metric{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;justify-content:space-between;padding:12px 16px}.health-label{color:#495057;font-size:14px;font-weight:500}.health-value{border-radius:4px;font-size:14px;font-weight:600;padding:4px 8px}.health-value.good{background:#d4edda;color:#155724}.health-value.warning{background:#fff3cd;color:#856404}.health-value.error{background:#f8d7da;color:#721c24}@media (max-width:768px){.quick-actions-grid{grid-template-columns:1fr}.quick-action-card{padding:16px}.quick-action-icon{font-size:28px;margin-right:12px}.quick-action-title{font-size:15px}.quick-action-description{font-size:13px}.health-metrics{grid-template-columns:1fr}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.admin-stats-grid{grid-template-columns:1fr}.quick-action-card{flex-direction:column;padding:20px 16px;text-align:center}.quick-action-icon{margin-bottom:12px;margin-right:0}.quick-action-arrow{margin-left:0;margin-top:12px}.activity-item{align-items:flex-start;flex-direction:column;gap:8px}.activity-status{margin-top:0}}.dashboard-loading{align-items:center;display:flex;justify-content:center;min-height:400px}.dashboard-loading-spinner{animation:spin 1s linear infinite;border:3px solid #e9ecef;border-radius:50%;border-top-color:#3498db;height:40px;width:40px}.dashboard-error{color:#6c757d;padding:40px 20px;text-align:center}.dashboard-error h3{color:#dc3545;margin-bottom:16px}.dashboard-error p{margin-bottom:20px}.retry-button{background:#3498db}.retry-button:hover{background:#2980b9}.contact-multi-selector{background-color:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;height:100%;overflow:hidden}.selector-header{background-color:#fff;border-bottom:1px solid #e9ecef;display:flex;flex-direction:column;gap:12px;padding:16px}.search-input{padding:8px 12px 8px 36px}.search-input:disabled{cursor:not-allowed;opacity:.6}.search-icon{color:#6c757d;font-size:14px;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.selection-controls{align-items:center;display:flex;gap:8px}.select-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.select-button:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd;color:#212529}.select-button:disabled{cursor:not-allowed;opacity:.6}.select-button.selected{background-color:#007bff;border-color:#007bff;color:#fff}.select-button.partial{background-color:#ffc107;border-color:#ffc107;color:#212529}.selection-summary{align-items:center;background-color:#e3f2fd;border-bottom:1px solid #e9ecef;color:#1976d2;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 16px}.selected-count{font-weight:600}.filter-info{color:#6c757d;font-weight:400}.contact-list-container{flex:1 1;max-height:250px;min-height:150px;overflow-y:auto}.no-contacts{color:#6c757d;font-size:14px;font-style:italic;padding:40px 20px;text-align:center}.contact-list{padding:8px 0}.contact-item{background-color:#fff;padding:12px 16px}.contact-item:hover:not(.disabled){background-color:#f8f9fa}.contact-item.selected{border-left:3px solid #007bff}.contact-item.disabled{cursor:not-allowed;opacity:.6}.contact-checkbox{align-items:center;display:flex;margin-right:12px}.contact-checkbox input[type=checkbox]{accent-color:#007bff;cursor:pointer;height:16px;width:16px}.contact-checkbox input[type=checkbox]:disabled{cursor:not-allowed}.contact-avatar{font-size:14px;height:36px;width:36px}.contact-meta{flex-wrap:wrap}.contact-email,.contact-phone{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meta-separator{flex-shrink:0}.message-count{white-space:nowrap}.contact-actions{gap:8px}.contact-list-container::-webkit-scrollbar{width:6px}.contact-list-container::-webkit-scrollbar-track{background:#f1f1f1}.contact-list-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.contact-list-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:768px){.selector-header{gap:8px;padding:12px}.search-input{font-size:13px;padding:7px 10px 7px 32px}.search-icon{font-size:13px;left:10px}.select-button{font-size:12px;padding:5px 10px}.selection-summary{font-size:12px;padding:6px 12px}.contact-item{padding:10px 12px}.contact-avatar{font-size:13px;height:32px;margin-right:10px;width:32px}.contact-name{font-size:13px}.contact-meta{font-size:11px}.contact-email,.contact-phone{max-width:100px}}.contact-item.selected{animation:selectHighlight .3s ease-out}@keyframes selectHighlight{0%{background-color:#007bff;transform:scale(1.02)}to{background-color:#e3f2fd;transform:scale(1)}}.photo-upload-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;height:100%;min-height:400px;padding:20px;width:100%}.photo-upload-modal{background:#000c}.photo-upload-content{background:#fff;border-radius:8px;max-height:90vh;max-width:90vw;overflow:auto;padding:20px}.photo-upload-options{display:flex;flex:1 1;flex-direction:column;gap:15px;height:100%}.photo-drop-zone{align-items:center;background:#fafafa;border:2px dashed #ddd;border-radius:8px;cursor:pointer;display:flex;flex:1 1;justify-content:center;min-height:300px;padding:60px 20px;text-align:center;transition:all .3s ease}.photo-drop-zone.drag-over,.photo-drop-zone:hover{background:#f0f8ff;border-color:#007bff}.drop-zone-content{align-items:center;display:flex;flex-direction:column;gap:10px}.drop-zone-icon{font-size:48px;opacity:.6}.drop-zone-text p{color:#666;margin:0}.drop-zone-hint{font-size:.9em;opacity:.8}.camera-option{text-align:center}.camera-button{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:background-color .3s ease}.camera-button:hover:not(:disabled){background:#218838}.camera-button:disabled{background:#6c757d;cursor:not-allowed}.camera-button.capture{background:#007bff;font-size:18px;margin-right:10px;padding:15px 30px}.camera-button.capture:hover:not(:disabled){background:#0056b3}.camera-button.cancel{background:#6c757d;padding:15px 30px}.camera-button.cancel:hover{background:#545b62}.camera-container{margin-bottom:20px;text-align:center}.camera-video{border-radius:8px;box-shadow:0 2px 10px #0003;max-height:60vh;max-width:100%}.camera-controls{text-align:center}.photo-preview-container{display:flex;flex-direction:column;gap:15px}.photo-preview{text-align:center}.preview-image{border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:300px;max-width:100%}.photo-caption{position:relative}.caption-input{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:14px;min-height:60px;padding:10px;resize:vertical;width:100%}.caption-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.caption-counter{color:#666;font-size:12px;margin-top:5px;text-align:right}.photo-actions{flex-wrap:wrap;gap:10px;justify-content:flex-end}.upload-actions{display:flex;justify-content:flex-end}.send-photo-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .3s ease}.send-photo-button:hover:not(:disabled){background:#0056b3}.send-photo-button:disabled{background:#6c757d;cursor:not-allowed}.change-photo-button{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .3s ease}.change-photo-button:hover:not(:disabled){background:#545b62}.change-photo-button:disabled{cursor:not-allowed;opacity:.6}.cancel-button{background:#dc3545;transition:background-color .3s ease}.cancel-button:hover:not(:disabled){background:#c82333}@media (max-width:600px){.photo-upload-container{padding:15px}.photo-drop-zone{padding:30px 15px}.drop-zone-icon{font-size:36px}.photo-actions{flex-direction:column}.photo-actions button{width:100%}.camera-video{max-height:50vh}}.cropper-content{max-height:95vh;max-width:95vw}.crop-container{margin:20px 0;position:relative}.crop-image-container{display:inline-block;max-height:60vh;max-width:100%;overflow:hidden;position:relative}.crop-image{display:block;max-height:60vh;max-width:100%;-webkit-user-select:none;user-select:none}.crop-overlay{background:#007bff1a;border:2px solid #007bff;box-sizing:border-box;cursor:move;position:absolute}.crop-handle{background:#007bff;border:3px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:16px;position:absolute;width:16px;z-index:10}.crop-handle:hover{background:#0056b3;transform:scale(1.1)}.crop-handle-nw{cursor:nw-resize;left:-8px;top:-8px}.crop-handle-ne{cursor:ne-resize;right:-8px;top:-8px}.crop-handle-sw{bottom:-8px;cursor:sw-resize;left:-8px}.crop-handle-se{bottom:-8px;cursor:se-resize;right:-8px}.crop-controls{margin-top:20px;text-align:center}.crop-button{background:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;margin:0 10px;padding:12px 24px;transition:background-color .3s ease}.crop-button:hover:not(:disabled){background:#0056b3}.crop-button:disabled{background:#6c757d;cursor:not-allowed}.crop-button.apply{background:#28a745}.crop-button.apply:hover:not(:disabled){background:#218838}.crop-button.cancel{background:#6c757d}.crop-button.cancel:hover{background:#545b62}.crop-photo-button{background:#17a2b8;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .3s ease}.crop-photo-button:hover:not(:disabled){background:#138496}.crop-photo-button:disabled{background:#6c757d;cursor:not-allowed}.message-split-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.message-split-modal-content{animation:modalSlideIn .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;height:70vh;max-width:800px;overflow:hidden;width:100%}.modal-header h3{color:#212529;font-size:18px;font-weight:600;margin:0}.close-button:hover{background-color:#e9ecef;color:#212529}.modal-body{display:flex;flex:1 1;flex-direction:column;overflow:hidden;padding:20px 24px}.split-info{align-items:center;background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;color:#856404;display:flex;flex-shrink:0;font-size:14px;font-weight:500;gap:8px;margin-bottom:16px;padding:10px 16px}.split-icon{font-size:16px}.message-tabs{border-bottom:1px solid #e9ecef;display:flex;flex-shrink:0;flex-wrap:wrap;gap:4px;margin-bottom:16px;padding-bottom:8px}.message-tab{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px 6px 0 0;color:#495057;cursor:pointer;display:flex;flex-direction:column;font-size:13px;font-weight:500;gap:2px;min-width:70px;padding:8px 12px;transition:all .2s ease}.message-tab:hover{background-color:#e9ecef;border-color:#adb5bd}.message-tab.active{background-color:#007bff;border-color:#007bff;color:#fff}.tab-chars{font-size:10px;font-weight:400;opacity:.8}.message-preview{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.preview-header{align-items:center;background-color:#e9ecef;border-bottom:1px solid #dee2e6;display:flex;font-size:13px;font-weight:500;justify-content:space-between;padding:12px 16px}.preview-title{color:#495057}.preview-chars{color:#6c757d;font-family:monospace}.preview-content{word-wrap:break-word;background-color:#fff;color:#212529;flex:1 1;font-size:14px;line-height:1.5;overflow-y:auto;padding:16px;white-space:pre-wrap}.modal-footer{background-color:#f8f9fa;border-radius:0 0 12px 12px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;padding:16px 24px}.close-modal-button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s ease}.close-modal-button:hover{background-color:#0056b3}.preview-content::-webkit-scrollbar{width:6px}.preview-content::-webkit-scrollbar-track{background:#f1f1f1}.preview-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.preview-content::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:768px){.message-split-modal-overlay{padding:10px}.message-split-modal-content{border-radius:8px;max-height:90vh}.modal-header{border-radius:8px 8px 0 0;padding:16px 20px}.modal-header h3{font-size:16px}.modal-body{padding:16px 20px}.modal-footer{border-radius:0 0 8px 8px;padding:12px 20px}.split-info{font-size:13px;padding:10px 12px}.message-tabs{gap:2px}.message-tab{font-size:12px;min-width:60px;padding:6px 8px}.tab-chars{font-size:9px}.preview-header{font-size:12px;padding:10px 12px}.preview-content{font-size:13px;padding:12px}}.multi-recipient-modal{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.multi-recipient-content{animation:modalSlideIn .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 10px 30px #0000004d;display:flex;flex-direction:column;max-height:85vh;max-width:800px;overflow:hidden;width:100%}.modal-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.modal-header-left{align-items:center;display:flex;gap:16px}.modal-header h2{color:#212529;font-size:20px;font-weight:600;margin:0}.test-mode-toggle{align-items:center;background-color:#6c757d;border:1px solid #6c757d;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.test-mode-toggle:hover:not(:disabled){background-color:#5a6268;border-color:#545b62}.test-mode-toggle.active{background-color:#ffc107;border-color:#ffc107;color:#212529}.test-mode-toggle.active:hover:not(:disabled){background-color:#e0a800;border-color:#d39e00}.test-mode-toggle:disabled{cursor:not-allowed;opacity:.6}.close-button{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;padding:4px;transition:all .2s ease;width:32px}.close-button:hover:not(:disabled){background-color:#e9ecef;color:#212529}.close-button:disabled{cursor:not-allowed;opacity:.5}.contact-selection-section{border-bottom:1px solid #e9ecef;display:flex;flex:1 1;flex-direction:column;overflow:hidden;padding:16px 24px}.contact-selection-section h3{color:#212529;font-size:16px;font-weight:600;margin:0 0 16px}.message-composition-section{border-bottom:1px solid #e9ecef;padding:16px 24px}.message-composition-section h3{color:#212529;font-size:16px;font-weight:600;margin:0 0 16px}.message-type-selector{display:flex;gap:8px;margin-bottom:16px}.type-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#495057;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:10px 16px;transition:all .2s ease}.type-button:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd;color:#212529}.type-button.active{background-color:#007bff;border-color:#007bff;color:#fff}.type-button:disabled{cursor:not-allowed;opacity:.6}.text-message-area{position:relative}.text-area-footer{align-items:center;display:flex;justify-content:space-between;margin-top:8px}.preview-split-button{align-items:center;background-color:#6f42c1;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:6px 12px;transition:background-color .2s ease;white-space:nowrap}.preview-split-button:hover:not(:disabled){background-color:#5a2d91}.preview-split-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.message-textarea{border:1px solid #dee2e6;border-radius:8px;font-family:inherit;font-size:14px;min-height:100px;padding:12px;resize:vertical;transition:border-color .2s ease;width:100%}.message-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a;outline:none}.message-textarea:disabled{background-color:#f8f9fa;cursor:not-allowed;opacity:.6}.photo-upload-section{border-bottom:1px solid #e9ecef;display:flex;flex:1 1;flex-direction:column;min-height:0;padding:20px 24px}.photo-upload-section h3{color:#212529;flex-shrink:0;font-size:16px;font-weight:600;margin:0 0 16px}.photo-upload-section>div{display:flex;flex:1 1;flex-direction:column;min-height:400px}.send-actions{align-items:center;background-color:#f8f9fa;border-radius:0 0 12px 12px;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.cancel-button{background-color:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.cancel-button:hover:not(:disabled){background-color:#5a6268}.cancel-button:disabled{cursor:not-allowed;opacity:.6}.send-button{border-radius:6px;min-width:120px;padding:10px 20px;transition:all .2s ease}.send-progress-section{border-bottom:1px solid #e9ecef;padding:20px 24px}.send-progress-section h3{color:#212529;font-size:16px;font-weight:600;margin:0 0 16px}.progress-container{display:flex;flex-direction:column;gap:8px}.progress-bar{background-color:#e9ecef;border-radius:6px;height:12px;overflow:hidden;width:100%}.progress-fill{background-color:#007bff;border-radius:6px;height:100%;position:relative;transition:width .3s ease}.progress-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.progress-text{color:#495057;font-size:14px;font-weight:500;text-align:center}.current-contact{color:#6c757d;font-size:13px;font-style:italic;text-align:center}.send-results-section{padding:20px 24px}.send-results-section h3{color:#212529;font-size:16px;font-weight:600;margin:0 0 16px}.results-summary{margin-bottom:20px}.summary-stats{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px}.stat-item{align-items:center;border-radius:6px;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 12px}.stat-item.success{background-color:#d4edda;color:#155724}.stat-item.failed{background-color:#f8d7da;color:#721c24}.stat-item.total{background-color:#e3f2fd;color:#1976d2}.stat-icon{font-size:16px}.stat-label{font-weight:500}.stat-value{font-weight:600}.error-message{border-radius:6px;font-size:14px}.detailed-results h4{color:#495057;font-size:14px;font-weight:600;margin:0 0 12px}.results-list{border:1px solid #e9ecef;border-radius:6px;max-height:200px;overflow-y:auto}.result-item{align-items:center;border-bottom:1px solid #f1f3f4;display:flex;justify-content:space-between;padding:12px}.result-item:last-child{border-bottom:none}.result-item.success{background-color:#f8fff9}.result-item.failed{background-color:#fff8f8}.result-contact{align-items:center;display:flex;flex:1 1;gap:8px}.result-icon{font-size:14px}.result-status{font-size:13px;font-weight:500}.result-status.success{color:#28a745}.result-status.failed{color:#dc3545}.results-actions{align-items:center;border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:16px}.close-button-primary{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.close-button-primary:hover{background-color:#0056b3}.retry-button{background-color:#ffc107;color:#212529;padding:10px 20px;transition:all .2s ease}.retry-button:hover:not(:disabled){background-color:#e0a800}.retry-button:disabled{cursor:not-allowed;opacity:.6}.results-list::-webkit-scrollbar{width:6px}.results-list::-webkit-scrollbar-track{background:#f1f1f1}.results-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.results-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:768px){.multi-recipient-modal{padding:10px}.multi-recipient-content{border-radius:8px;max-height:95vh}.modal-header{border-radius:8px 8px 0 0;gap:12px;padding:16px 20px}.modal-header,.modal-header-left{align-items:stretch;flex-direction:column}.modal-header-left{gap:8px}.modal-header h2{font-size:18px;text-align:center}.test-mode-toggle{font-size:11px;justify-content:center;padding:5px 10px}.contact-selection-section,.message-composition-section,.photo-upload-section,.send-progress-section,.send-results-section{padding:16px 20px}.results-actions,.send-actions{align-items:stretch;flex-direction:column;padding:16px 20px}.results-actions .close-button-primary,.results-actions .retry-button,.send-actions .cancel-button,.send-actions .send-button{margin:0;width:100%}.message-type-selector{flex-direction:column}.type-button{justify-content:center}.summary-stats{flex-direction:column;gap:8px}.stat-item{justify-content:center}.result-item{align-items:flex-start;flex-direction:column;gap:8px}.result-status{align-self:flex-end}}.result-item{animation:resultSlideIn .3s ease-out}@keyframes resultSlideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.contact-list{background-color:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;height:100%}.contact-list-header{align-items:center;background-color:#fff;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px}.header-left,.header-right{align-items:center;display:flex;gap:8px}.contact-list-header h2{color:#212529;font-size:20px;font-weight:600;margin:0}.contact-count{color:#6c757d;font-size:16px;font-weight:500}.multi-send-button{align-items:center;background-color:#28a745;border:1px solid #28a745;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.multi-send-button:hover:not(:disabled){background-color:#218838;border-color:#1e7e34}.multi-send-button:active:not(:disabled){background-color:#1e7e34;transform:translateY(1px)}.multi-send-button:disabled{background-color:#6c757d;border-color:#6c757d;cursor:not-allowed;opacity:.6}.sync-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;display:flex;font-size:16px;font-weight:500;gap:4px;justify-content:center;min-width:40px;padding:8px 10px;transition:all .2s ease}.sync-button:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd;color:#212529}.scroll-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:4px;justify-content:center;min-width:40px;padding:8px 10px;transition:all .2s ease}.scroll-button:hover{background-color:#e9ecef;border-color:#adb5bd;color:#212529}.scroll-button:active,.sync-button:active:not(:disabled){background-color:#dee2e6;transform:translateY(1px)}.sync-button:disabled{opacity:.7}.sync-button.syncing{background-color:#e3f2fd;border-color:#90caf9;color:#1976d2}.sync-icon{font-size:14px;line-height:1}.sync-spinner{animation:spin 1s linear infinite;border:2px solid #e3f2fd;border-radius:50%;border-top-color:#1976d2;height:14px;width:14px}.sync-message{animation:slideDown .3s ease-out;border-bottom:1px solid #e9ecef;font-size:13px;font-weight:500;margin:0;padding:12px 20px}.sync-message.success{background-color:#d4edda;border-left:4px solid #28a745;color:#155724}.sync-message.error{background-color:#f8d7da;border-left:4px solid #dc3545;color:#721c24}.sync-progress{background-color:#f8f9fa;border-bottom:1px solid #e9ecef;color:#6c757d;font-size:12px;font-style:italic;padding:8px 20px}.sync-progress-text{align-items:center;display:flex;gap:8px}.sync-progress-text:before{animation:spin 1s linear infinite;border:2px solid #e9ecef;border-radius:50%;border-top-color:#6c757d;content:"";height:12px;width:12px}.completion-notification{animation:slideInLeft .3s ease-out;background-color:#d4edda;border:1px solid #c3e6cb;border-radius:8px;box-shadow:0 4px 12px #00000026;left:20px;max-width:400px;position:fixed;top:20px;z-index:1000}.completion-content{align-items:flex-start;display:flex;gap:12px;padding:16px}.completion-icon{flex-shrink:0;font-size:24px;margin-top:2px}.completion-details{flex:1 1;min-width:0}.completion-title{color:#155724;font-size:14px;font-weight:600;margin-bottom:4px}.completion-stats{color:#155724;font-size:13px;opacity:.9}.completion-dismiss{align-items:center;background:none;border:none;border-radius:4px;color:#155724;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:24px;justify-content:center;padding:0;transition:background-color .2s ease;width:24px}.completion-dismiss:hover{background-color:#1557241a}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}.sync-progress-enhanced{animation:slideDown .3s ease-out;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;padding:16px 20px}.sync-progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.sync-progress-title{color:#495057;font-size:14px;font-weight:600}.sync-progress-percentage{color:#007bff;font-size:14px;font-weight:600}.sync-progress-bar{background-color:#e9ecef;border-radius:4px;height:8px;margin-bottom:12px;overflow:hidden;width:100%}.sync-progress-fill{background-color:#007bff;border-radius:4px;height:100%;position:relative;transition:width .3s ease}.sync-progress-fill:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.sync-initializing{animation:pulse 1.5s ease-in-out infinite}.sync-progress-details{display:flex;flex-direction:column;gap:4px}.sync-current-contact{color:#495057;font-size:13px;font-weight:500}.sync-message-count{color:#6c757d;font-size:12px;font-style:italic}.contact-list-items{flex:1 1;overflow-y:auto;padding:8px 0}.contact-item{align-items:center;border-bottom:1px solid #f1f3f4;cursor:pointer;display:flex;padding:12px 20px;transition:background-color .2s ease}.contact-item:hover{background-color:#f1f3f4}.contact-item.selected{background-color:#e3f2fd;border-right:3px solid #007bff}.contact-avatar{align-items:center;background-color:#007bff;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:40px;justify-content:center;margin-right:12px;transition:background-color .2s ease;width:40px}.contact-avatar.received-message{background-color:#dc3545}.message-stats-bar{background-color:#f8f9fa;border-bottom:1px solid #e9ecef;gap:16px;justify-content:space-around;padding:12px 20px}.message-stats-bar,.stats-item{align-items:center;display:flex}.stats-item{flex:1 1;flex-direction:column;gap:4px;text-align:center}.stats-label{color:#6c757d;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.stats-value{color:#212529;font-size:16px;font-weight:700}.contact-filters{align-items:center;background-color:#fff;border-bottom:1px solid #e9ecef;display:flex;gap:12px;padding:16px 20px}.search-container{flex:1 1;position:relative}.search-input{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;font-size:14px;padding:8px 12px;transition:all .2s ease}.search-input:focus{background-color:#fff;box-shadow:0 0 0 2px #007bff1a}.filter-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.filter-button:hover{background-color:#e9ecef;border-color:#adb5bd;color:#212529}.filter-button.active{background-color:#007bff;border-color:#007bff;color:#fff}.filter-button.active:hover{background-color:#0056b3;border-color:#0056b3}.contact-info{flex:1 1;min-width:0;overflow:hidden}.contact-name{color:#212529;font-size:14px;font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.booking-code{font-size:11px;font-weight:400;margin-left:6px}.contact-meta{align-items:center;color:#6c757d;display:flex;font-size:12px;gap:6px}.message-count{font-weight:500}.meta-separator{opacity:.5}.last-message-time{white-space:nowrap}.contact-actions{align-items:center;display:flex;flex-shrink:0;gap:4px;margin-left:8px}.contact-badge{background-color:#007bff;border-radius:12px;color:#fff;font-size:11px;font-weight:600;line-height:1.2;min-width:20px;padding:4px 8px;text-align:center}.contact-badge.credit-badge{background-color:#28a745}.contact-badge.cost-badge{border-radius:8px;font-size:9px;font-weight:600;line-height:1.2;min-width:auto;padding:3px 5px;white-space:nowrap}.contact-badge.cost-badge.msg-cost{background-color:#fd7e14}.contact-badge.cost-badge.credit-cost{background-color:#6f42c1}.contact-badge.cost-badge.total-cost{background-color:#ef4444;color:#fff;font-weight:600}.cost-info{color:#6f42c1;cursor:help;font-weight:600}.contact-refresh-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;color:#495057;cursor:pointer;display:flex;flex-shrink:0;font-size:10px;height:20px;justify-content:center;padding:0;transition:all .2s ease;width:20px}.contact-refresh-button:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd;color:#212529}.contact-refresh-button:active:not(:disabled){background-color:#dee2e6;transform:translateY(1px)}.contact-refresh-button:disabled{cursor:not-allowed;opacity:.7}.contact-refresh-button.syncing{background-color:#e3f2fd;border-color:#90caf9;color:#1976d2}.contact-refresh-button.full-sync{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.contact-refresh-button.full-sync:hover:not(:disabled){background-color:#ffeaa7;border-color:#ffdd57;color:#6c5400}.contact-refresh-button.full-sync.syncing{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.contact-delete-button{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;color:#dc3545;cursor:pointer;display:flex;flex-shrink:0;font-size:10px;height:20px;justify-content:center;padding:0;transition:all .2s ease;width:20px}.contact-delete-button:hover:not(:disabled){background-color:#f5c6cb;border-color:#f1aeb5;color:#721c24}.contact-delete-button:active:not(:disabled){background-color:#f1aeb5;transform:translateY(1px)}.contact-delete-button:disabled{cursor:not-allowed;opacity:.7}.contact-delete-button.deleting{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.contact-delete-button.photos-only{background-color:#fff3cd;border-color:#ffeaa7;color:#856404;font-size:8px}.contact-delete-button.photos-only:hover:not(:disabled){background-color:#ffeaa7;border-color:#ffdd57;color:#6c5400}.contact-delete-button.photos-only:active:not(:disabled){background-color:#ffdd57;transform:translateY(1px)}.contact-delete-button.photos-only.deleting{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.contact-toggle-released{align-items:center;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;color:#495057;cursor:pointer;display:flex;flex-shrink:0;font-size:10px;height:20px;justify-content:center;margin-left:8px;padding:0;position:relative;transition:all .2s ease;width:20px}.contact-toggle-released:before{background-color:#dee2e6;bottom:0;content:"";left:-6px;position:absolute;top:0;width:1px}.contact-toggle-released:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd;color:#212529}.contact-toggle-released:active:not(:disabled){background-color:#dee2e6;transform:translateY(1px)}.contact-toggle-released:disabled{cursor:not-allowed;opacity:.7}.contact-toggle-released.toggling{background-color:#fff3cd;border-color:#ffeaa7;color:#856404}.contact-toggle-released.released{background-color:#d1ecf1;border-color:#bee5eb;color:#0c5460}.contact-toggle-released.released:hover:not(:disabled){background-color:#bee5eb;border-color:#86cfda;color:#062c33}.contact-toggle-released.active{background-color:#d4edda;border-color:#c3e6cb;color:#155724}.contact-toggle-released.active:hover:not(:disabled){background-color:#c3e6cb;border-color:#b8daff;color:#0b2e13}.toggle-spinner{animation:spin 1s linear infinite;border:2px solid #fff3cd;border-radius:50%;border-top-color:#856404;height:12px;width:12px}.contact-item.released{background-color:#f8f9fa;opacity:.6}.contact-item.released:hover{background-color:#e9ecef;opacity:.8}.contact-item.released.selected{background-color:#e3f2fd;opacity:.8}.contact-avatar.released{background-color:#6c757d;opacity:.7}.contact-item.released .contact-name{color:#6c757d}.contact-item.released .contact-meta{color:#adb5bd}.released-badge{background-color:#6c757d;border-radius:8px;color:#fff;display:inline-block;font-size:9px;font-weight:600;letter-spacing:.5px;margin-left:6px;padding:2px 6px;text-transform:uppercase}.refresh-spinner{border:2px solid #e3f2fd;border-radius:50%;border-top-color:#1976d2}.delete-spinner,.refresh-spinner{animation:spin 1s linear infinite;height:12px;width:12px}.delete-spinner{border:2px solid #f8d7da;border-radius:50%;border-top-color:#dc3545}.sync-error{color:#dc3545;cursor:help;font-size:12px}.recent-messages-item{background-color:#f8f9fa;border-bottom:2px solid #e9ecef}.recent-messages-item:hover{background-color:#e9ecef}.recent-messages-item.selected{background-color:#e3f2fd;border-right:3px solid #007bff}.recent-messages-avatar{background-color:#28a745;font-size:18px}.contact-list-error{color:#dc3545;padding:20px;text-align:center}.error-message{font-size:12px;margin-top:8px;padding:8px}.contact-list-empty{color:#6c757d;padding:40px 20px;text-align:center}.contact-list-empty p{font-size:14px;margin:0}.contact-list-items::-webkit-scrollbar{width:6px}.contact-list-items::-webkit-scrollbar-track{background:#f1f1f1}.contact-list-items::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.contact-list-items::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:768px){.contact-list-header{align-items:stretch;flex-direction:column;gap:12px;padding:16px}.header-left,.header-right{justify-content:center}.multi-send-button,.sync-button{font-size:12px;padding:6px 10px}.sync-message{font-size:12px;padding:10px 16px}.sync-progress{font-size:11px;padding:6px 16px}.contact-item{padding:10px 16px}.contact-avatar{font-size:14px;height:36px;margin-right:10px;width:36px}.contact-name{font-size:13px}.contact-meta{font-size:11px}.completion-notification{left:10px;max-width:none;right:10px;top:10px}.completion-content{gap:10px;padding:12px}.completion-icon{font-size:20px}.completion-title{font-size:13px}.completion-stats{font-size:12px}.sync-progress-enhanced{padding:12px 16px}.sync-progress-percentage,.sync-progress-title{font-size:13px}.sync-current-contact{font-size:12px}.sync-message-count{font-size:11px}.message-stats-bar{gap:12px;padding:10px 16px}.stats-label{font-size:10px}.stats-value{font-size:14px}.contact-filters{flex-direction:column;gap:8px;padding:12px 16px}.filter-button,.search-input{font-size:13px;padding:7px 10px}.filter-button{align-self:flex-start}}.clickable-photo{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.clickable-photo:hover{box-shadow:0 4px 12px #0003;transform:scale(1.02)}.message-bubble{word-wrap:break-word;display:flex;flex-direction:column;margin:8px 0;max-width:70%}.message-bubble.inbound{align-self:flex-start;margin-right:auto}.message-bubble.outbound{align-self:flex-end;margin-left:auto}.message-content{border-radius:18px;box-shadow:0 1px 2px #0000001a;padding:12px 16px;position:relative}.message-bubble.inbound .message-content{background-color:#f1f3f4;border-bottom-left-radius:4px;color:#202124}.message-bubble.outbound .message-content{background-color:#007bff;border-bottom-right-radius:4px;color:#fff}.message-text{word-wrap:break-word;font-size:14px;line-height:1.4;margin-bottom:4px;white-space:pre-wrap!important}.message-media{display:flex;flex-direction:column}.message-image{border-radius:8px;margin-bottom:8px;max-height:200px;max-width:200px;object-fit:cover}.media-fallback{background-color:#ffffff1a;border-radius:4px;font-size:12px;margin-bottom:8px;padding:8px;text-align:center}.message-meta{gap:4px;justify-content:flex-end;margin-top:4px}.copy-button,.message-meta{align-items:center;display:flex}.copy-button{background:none;border:none;border-radius:4px;cursor:pointer;font-size:12px;height:20px;justify-content:center;min-width:20px;opacity:.6;padding:2px 4px;transition:opacity .2s ease,background-color .2s ease}.copy-button:hover{background-color:#0000001a;opacity:1}.message-bubble.outbound .copy-button:hover{background-color:#fff3}.copy-button:active{transform:scale(.95)}.copy-button[title="Copied!"]{color:#4caf50;font-weight:700;opacity:1}.message-timestamp{font-size:11px;opacity:.7;white-space:nowrap}.message-bubble.inbound .message-timestamp{color:#5f6368}.message-bubble.outbound .message-timestamp{color:#fffc}.message-bubble.outbound.delivery-delivered .message-timestamp,.message-bubble.outbound.delivery-pending .message-timestamp{color:#333333b3}.message-read-status{font-size:10px;opacity:.8}.message-sender{color:#5f6368;font-size:11px;font-weight:500;margin-left:4px;margin-top:2px}.message-contact-info{color:#6c757d;font-size:11px;font-weight:500;margin-bottom:4px;padding:0 4px}.contact-label{background-color:#6c757d1a;border-radius:10px;font-size:10px;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.message-bubble.outbound .contact-label{background-color:#007bff;color:#fff}.message-bubble.inbound .contact-label{background-color:#007bff1a;color:#007bff}@media (max-width:768px){.message-bubble{max-width:85%}.message-content{padding:10px 14px}.message-text{font-size:13px;white-space:pre-wrap!important}.message-image{max-height:150px;max-width:150px}.copy-button{font-size:11px;height:18px;min-width:18px;padding:1px 3px}}.message-bubble{animation:slideIn .3s ease-out}.message-bubble.clickable{transition:transform .2s ease,box-shadow .2s ease}.message-bubble.clickable:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.message-bubble.clickable:hover .message-content{box-shadow:0 2px 6px #0003}.click-hint{color:#666;font-size:12px;font-style:italic;margin-top:4px;opacity:0;transition:opacity .2s ease}.message-bubble.clickable:hover .click-hint{opacity:1}.message-bubble.clickable:active{transform:translateY(0)}.delivery-status{align-items:center;display:flex;font-size:10px;gap:4px;margin-left:8px}.delivery-status .status-icon{font-size:12px}.delivery-status .status-text{font-weight:500;opacity:.8}.delivery-status.pending .status-text{color:#ff9800}.delivery-status.failed .status-text{color:#f44336}.delivery-status .status-icon.delivered-check{align-items:center;background-color:#4caf50;border-radius:50%;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;width:16px}.retry-button{background:none;border-radius:2px;font-size:10px;margin-left:2px;padding:2px}.retry-button:hover{background-color:#f443361a}.message-bubble.outbound.delivery-pending .message-content{animation:pendingPulse 2s infinite;background-color:#fff3e0;border:3px solid #e65100;color:#333}.message-bubble.outbound.delivery-delivered .message-content{background-color:#e3f2fd;border:2px solid #4caf50;color:#333}.message-bubble.outbound.delivery-failed .message-content{border:2px solid #f44336}@keyframes pendingPulse{0%{border-color:#e65100;box-shadow:0 0 0 0 #e6510066}50%{border-color:#ff8f00;box-shadow:0 0 0 4px #e651001a}to{border-color:#e65100;box-shadow:0 0 0 0 #e6510066}}@media (max-width:768px){.delivery-status{font-size:9px;gap:2px}.delivery-status .status-icon{font-size:10px}.retry-button{font-size:9px}.delivery-status .status-icon.delivered-check{font-size:9px;height:14px;width:14px}}.delivery-status[title]{cursor:help}@media (prefers-contrast:high){.message-bubble.outbound.delivery-pending .message-content{background-color:#ffe0b2;border-width:4px}.message-bubble.outbound.delivery-failed .message-content{border-width:3px}.message-bubble.outbound.delivery-delivered .message-content{background-color:#bbdefb;border-width:3px}.delivery-status .status-icon.delivered-check{font-size:11px;height:18px;width:18px}}.photo-modal-backdrop{align-items:center!important;background-color:#000c!important;bottom:0!important;box-sizing:border-box;display:flex!important;height:100vh!important;justify-content:center!important;left:0!important;padding:20px;position:fixed!important;right:0!important;top:0!important;width:100vw!important;z-index:9999!important}.photo-modal-container{background:#fff!important;border-radius:8px;box-shadow:0 4px 20px #0000004d!important;display:flex!important;flex-direction:column!important;max-height:95vh;max-width:95vw;overflow:hidden;position:relative!important;z-index:10001!important}.photo-modal-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:40px;justify-content:center;position:absolute;right:10px;top:10px;transition:background-color .2s;width:40px;z-index:10000}.photo-modal-close:hover{background:#000000e6}.photo-modal-controls{align-items:center;display:flex;gap:8px;left:10px;position:absolute;top:10px;z-index:10000}.zoom-button{align-items:center;background:#000000b3;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;height:36px;justify-content:center;transition:background-color .2s;width:36px}.zoom-button:hover{background:#000000e6}.zoom-level{background:#000000b3;border-radius:4px;color:#fff;font-weight:700;min-width:45px;padding:6px 10px}.photo-modal-content{align-items:center;background:#f5f5f5;display:flex;flex:1 1;justify-content:center;min-height:200px}.photo-modal-image{border-radius:4px;height:auto;max-height:calc(95vh - 80px);max-width:100%;object-fit:contain;width:auto}.photo-modal-error{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:40px}.photo-modal-error-icon{font-size:48px;margin-bottom:16px}.photo-modal-error-text{font-size:16px;text-align:center}.photo-modal-info{align-items:center;background:#f8f9fa;border-top:1px solid #e9ecef;color:#666;display:flex;font-size:14px;justify-content:space-between;padding:12px 16px}.photo-modal-hint{font-size:12px;font-style:italic}@media (max-width:768px){.photo-modal-backdrop{padding:5px}.photo-modal-container{max-height:98vh;max-width:98vw}.photo-modal-image{max-height:calc(98vh - 100px)}.photo-modal-info{flex-direction:column;font-size:12px;gap:8px;text-align:center}.photo-modal-close{font-size:20px;height:36px;width:36px}.photo-modal-controls{gap:6px;left:5px;top:5px}.zoom-button{font-size:12px;height:32px;width:32px}.zoom-level{font-size:11px;min-width:40px;padding:4px 8px}.photo-modal-hint{font-size:10px}}.photo-modal-backdrop{animation:fadeIn .2s ease-out}.photo-modal-container{animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.virtual-message-list-container{height:600px;overflow:hidden;position:relative;width:100%}.virtual-message-list{height:100%!important;width:100%}.virtual-message-list::-webkit-scrollbar{width:6px}.virtual-message-list::-webkit-scrollbar-track{background:#f1f1f1}.virtual-message-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.virtual-message-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.virtual-message-item{display:flex;flex-direction:column;padding:2px 0}.virtual-message-loading{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:center;padding:16px}.loading-more-messages{align-items:center;color:#6c757d;display:flex;font-size:14px;gap:8px}.virtual-message-placeholder{align-items:center;color:#6c757d;display:flex;font-style:italic;justify-content:center;padding:16px}.message-placeholder{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:12px 16px}.virtual-message-list-empty{background-color:#f8f9fa;height:100%}.scroll-to-bottom-btn,.virtual-message-list-empty{align-items:center;display:flex;justify-content:center}.scroll-to-bottom-btn{background-color:#007bff;border:none;border-radius:50%;bottom:16px;box-shadow:0 2px 8px #007bff4d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;height:40px;position:absolute;right:16px;transition:all .2s ease;width:40px;z-index:10}.scroll-to-bottom-btn:hover{background-color:#0056b3;box-shadow:0 4px 12px #007bff66;transform:translateY(-2px)}.scroll-to-bottom-btn:active{transform:translateY(0)}.virtual-message-loading{animation:fadeIn .3s ease-out}.virtual-message-item{transition:opacity .2s ease}.virtual-message-list-container *{will-change:transform}@media (max-width:768px){.scroll-to-bottom-btn{bottom:12px;font-size:16px;height:36px;right:12px;width:36px}.virtual-message-loading{padding:12px}.loading-more-messages{font-size:13px}.empty-icon{font-size:36px;margin-bottom:12px}.empty-state p{font-size:13px}}@media (prefers-contrast:high){.virtual-message-loading{border-bottom:2px solid #000}.scroll-to-bottom-btn{border:2px solid #000}}@media (prefers-reduced-motion:reduce){.virtual-message-loading{animation:none}.scroll-to-bottom-btn,.virtual-message-item{transition:none}.scroll-to-bottom-btn:hover{transform:none}}.credit-manager{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin:16px 0;padding:16px;transition:all .3s ease}.credit-manager.collapsed{margin:2px 0;padding:2px 16px}.credit-display{margin-bottom:16px}.credit-manager.collapsed .credit-display{margin-bottom:0}.credit-header{align-items:center;border-radius:4px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px;transition:all .2s ease}.credit-header:hover{background-color:#f8f9fa}.credit-header.collapsed{margin-bottom:0;padding:2px 8px}.credit-header-left{align-items:center;display:flex;flex:1 1;gap:12px}.credit-header-right{align-items:center;display:flex;gap:8px}.credit-header h4{color:#495057;font-size:16px;font-weight:600;margin:0}.credit-balance-inline{align-items:baseline;display:flex;gap:4px}.credit-amount-inline{color:#28a745;font-size:16px;font-weight:600}.credit-error-inline,.credit-loading-inline,.credit-unavailable-inline{color:#6c757d;font-size:12px;font-style:italic}.credit-error-inline{color:#dc3545}.expand-toggle{background:none;border:none;border-radius:4px;color:#6c757d;padding:4px;transition:background-color .2s ease}.expand-toggle:hover{background-color:#e9ecef;color:#495057}.refresh-credits{background:none;border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:4px;transition:background-color .2s ease}.refresh-credits:hover:not(:disabled){background-color:#e9ecef}.refresh-credits:disabled{cursor:not-allowed;opacity:.5}.credit-balance{align-items:baseline;display:flex;gap:8px}.credit-amount{color:#28a745;font-size:24px;font-weight:700}.credit-label{color:#6c757d;font-size:14px;font-weight:500}.credit-loading,.credit-unavailable{color:#6c757d;font-size:14px;font-style:italic}.credit-error{align-items:center;color:#dc3545;display:flex;font-size:12px;gap:8px}.retry-btn{background-color:#dc3545;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:10px;padding:2px 6px;transition:background-color .2s ease}.retry-btn:hover{background-color:#c82333}.credit-actions{border-top:1px solid #e9ecef;padding-top:16px}.credit-operations-section{margin-bottom:16px}.credit-operations-section h5{color:#495057;font-size:14px;font-weight:600;margin:0 0 12px}.credit-operations-form{display:flex;flex-direction:column;gap:12px}.operation-type-selection{margin-bottom:16px}.operation-type-label{display:block;margin-bottom:8px}.operation-type-options{display:flex;gap:16px}.radio-option{align-items:center;border-radius:4px;cursor:pointer;display:flex;gap:6px;padding:4px 8px;transition:background-color .2s ease}.radio-option:hover{background-color:#f8f9fa}.radio-option input[type=radio]{cursor:pointer;margin:0}.radio-option span{color:#495057;cursor:pointer;font-size:14px;font-weight:500;-webkit-user-select:none;user-select:none}.checkbox-option{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-option input[type=checkbox]{cursor:pointer;margin:0}.checkbox-option span{color:#495057;cursor:pointer;font-size:14px;font-weight:500;-webkit-user-select:none;user-select:none}.operation-type-group{display:flex;gap:16px;margin-bottom:8px}.operation-type-option{align-items:center;border-radius:4px;cursor:pointer;display:flex;gap:6px;padding:4px 8px;transition:background-color .2s ease}.operation-type-option:hover{background-color:#f8f9fa}.operation-type-radio{cursor:pointer;margin:0}.operation-type-label{color:#495057;cursor:pointer;font-size:14px;font-weight:500;-webkit-user-select:none;user-select:none}.operation-type-option.add .operation-type-label{color:#28a745}.operation-type-option.remove .operation-type-label{color:#dc3545}.add-credits-section{margin-bottom:16px}.add-credits-section h5{color:#495057;font-size:14px;font-weight:600;margin:0 0 8px}.add-credits-form{display:flex;flex-direction:column;gap:8px}.credit-amount-input,.credit-description-input{border:1px solid #ced4da;border-radius:4px;font-size:14px;padding:8px 12px;transition:border-color .2s ease}.credit-amount-input:focus,.credit-description-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.credit-amount-input:disabled,.credit-description-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.message-options-group{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;display:flex;flex-direction:column;gap:8px;padding:12px}.send-message-option{align-items:center;cursor:pointer;display:flex;gap:8px}.send-message-checkbox{cursor:pointer;margin:0}.send-message-label{color:#495057;cursor:pointer;font-size:14px;font-weight:500;-webkit-user-select:none;user-select:none}.custom-message-textarea{border:1px solid #ced4da;border-radius:4px;font-family:inherit;font-size:14px;min-height:120px;padding:8px 12px;resize:vertical;transition:border-color .2s ease;width:100%}.custom-message-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.custom-message-textarea:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.custom-message-textarea::placeholder{color:#6c757d;font-style:italic}.custom-message-section{display:flex;flex-direction:column;gap:8px}.custom-message-label{color:#495057;font-size:14px;font-weight:500;margin-bottom:4px}.character-counter{display:flex;justify-content:flex-end;margin-top:4px}.character-count{color:#6c757d;font-size:12px;font-weight:500}.character-count.character-warning{color:#dc3545;font-weight:600}.credit-operation-btn{border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:background-color .2s ease}.credit-operation-btn.add{background-color:#28a745;color:#fff}.credit-operation-btn.add:hover:not(:disabled){background-color:#218838}.credit-operation-btn.remove{background-color:#dc3545;color:#fff}.credit-operation-btn.remove:hover:not(:disabled){background-color:#c82333}.credit-operation-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.add-credits-btn{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:background-color .2s ease}.add-credits-btn:hover:not(:disabled){background-color:#218838}.add-credits-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.remove-credits-section{margin-bottom:16px}.remove-credits-section h5{color:#495057;font-size:14px;font-weight:600;margin:0 0 8px}.remove-credits-form{display:flex;flex-direction:column;gap:8px}.remove-credits-btn{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:background-color .2s ease}.remove-credits-btn:hover:not(:disabled){background-color:#c82333}.remove-credits-btn:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.credit-history-section{border-top:1px solid #e9ecef;padding-top:12px}.show-history-btn{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;padding:8px 12px;transition:background-color .2s ease}.show-history-btn:hover:not(:disabled){background-color:#5a6268}.show-history-btn:disabled{cursor:not-allowed;opacity:.6}.credit-history{border-top:1px solid #e9ecef;margin-top:16px;padding-top:16px}.credit-history h5{color:#495057;font-size:14px;font-weight:600;margin:0 0 12px}.history-loading,.no-transactions{color:#6c757d;font-size:12px;font-style:italic;padding:16px;text-align:center}.transactions-list{background-color:#fff;border:1px solid #e9ecef;border-radius:4px;max-height:200px;overflow-y:auto}.transaction-item{border-bottom:1px solid #f8f9fa;padding:8px 12px}.transaction-item:last-child{border-bottom:none}.transaction-main{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.transaction-amount{font-size:14px;font-weight:600}.transaction-amount.credit{color:#28a745}.transaction-amount.debit{color:#dc3545}.transaction-date{color:#6c757d;font-size:11px}.transaction-description{color:#495057;font-size:12px;font-style:italic}@media (max-width:768px){.credit-manager{margin:12px 0;padding:12px}.credit-header{padding:6px}.credit-header-left{gap:8px}.credit-header-right{gap:6px}.credit-amount-inline,.credit-header h4{font-size:14px}.credit-amount{font-size:20px}.credit-operations-form{gap:10px}.operation-type-group{gap:12px}.operation-type-option{padding:3px 6px}.operation-type-label{font-size:13px}.message-options-group{padding:10px}.send-message-label{font-size:13px}.custom-message-textarea{font-size:13px;min-height:100px;padding:6px 10px}.credit-modal{max-width:95%;width:98%}.credit-operation-btn{font-size:13px;padding:8px 12px}.add-credits-form{gap:6px}.credit-amount-input,.credit-description-input{font-size:13px;padding:6px 10px}.add-credits-btn{font-size:13px;padding:8px 12px}.transactions-list{max-height:150px}.transaction-item{padding:6px 10px}.transaction-main{align-items:flex-start;flex-direction:column;gap:2px}}.transactions-list::-webkit-scrollbar{width:4px}.transactions-list::-webkit-scrollbar-track{background:#f1f1f1}.transactions-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:2px}.transactions-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.credit-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.credit-modal{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-height:85vh;max-width:800px;overflow-y:auto;position:relative;width:95%}.credit-modal-header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.credit-modal-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.credit-modal-close{background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;font-size:20px;padding:4px;transition:all .2s ease}.credit-modal-close:hover{background-color:#e9ecef;color:#333}.credit-modal-content{padding:24px}.credit-balance-section{background-color:#f8f9fa;border-radius:8px;margin-bottom:32px;padding:20px;text-align:center}.credit-balance-section .credit-balance{align-items:center;display:flex;gap:8px;justify-content:center}.credit-balance-section .credit-amount{color:#28a745;font-size:32px;font-weight:700}.credit-balance-section .credit-label{color:#6c757d;font-size:18px}.credit-header.collapsed .expand-toggle{font-size:14px}.chat-window{background-color:#fff;display:flex;flex-direction:column;height:100%}.chat-window-empty{align-items:center;background-color:#f8f9fa;display:flex;height:100%;justify-content:center}.empty-state{color:#6c757d;max-width:300px}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state h3{color:#495057;font-size:18px;font-weight:500;margin:0 0 8px}.empty-state p{font-size:14px;line-height:1.4;margin:0}.chat-header{align-items:center;background-color:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;padding:16px 20px}.chat-contact-info{align-items:center;display:flex;flex:1 1;min-width:0}.chat-avatar{align-items:center;background-color:#007bff;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:600;height:48px;justify-content:center;margin-right:12px;width:48px}.chat-contact-details{flex:1 1;min-width:0}.chat-contact-name{color:#212529;font-size:16px;font-weight:600;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-contact-meta{color:#6c757d;font-size:12px;margin:0}.booking-code{color:#6f42c1;font-size:14px;font-weight:500}.chat-contact-extended-info{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}.contact-detail{align-items:center;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;display:flex;font-size:11px;gap:4px;padding:2px 6px}.detail-label{color:#495057;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#212529;font-weight:500}.chat-credits-info{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;margin-left:16px}.credits-display{align-items:baseline;display:flex;gap:4px}.credits-amount{color:#28a745;font-size:18px;font-weight:700}.credits-label{color:#6c757d;font-size:11px;font-weight:500;text-transform:uppercase}.credits-loading,.credits-unavailable{color:#6c757d;font-size:11px;font-style:italic}.chat-messages{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:16px 20px}.load-more-container{margin-bottom:16px;text-align:center}.load-more-button{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:20px;color:#495057;cursor:pointer;font-size:12px;padding:8px 16px;transition:all .2s ease}.load-more-button:hover:not(:disabled){background-color:#e9ecef;border-color:#adb5bd}.load-more-button:disabled{cursor:not-allowed;opacity:.6}.messages-list{display:flex;flex-direction:column;gap:4px}.chat-error{color:#dc3545;padding:20px;text-align:center}.chat-error .error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;font-size:12px;margin:8px 0;padding:8px}.retry-button{background-color:#dc3545;border-radius:4px;font-size:12px;margin-top:8px;padding:8px 16px}.retry-button:hover{background-color:#c82333}.chat-empty{color:#6c757d;padding:40px 20px;text-align:center}.chat-empty p{font-size:14px;margin:0}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:#f1f1f1}.chat-messages::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#a8a8a8}@media (max-width:768px){.chat-header{align-items:flex-start;flex-direction:column;gap:8px;padding:12px 16px}.chat-contact-info{width:100%}.chat-credits-info{align-self:flex-end;margin-left:0}.credits-amount{font-size:16px}.credits-label{font-size:10px}.chat-avatar{font-size:16px;height:40px;margin-right:10px;width:40px}.chat-contact-name{font-size:15px}.chat-contact-extended-info{gap:8px;margin-top:6px}.contact-detail{font-size:10px;padding:1px 4px}.chat-messages{padding:12px 16px}.empty-state{padding:0 20px}.empty-icon{font-size:36px}.empty-state h3{font-size:16px}.empty-state p{font-size:13px}}.chat-messages{scroll-behavior:smooth}.chat-messages.loading{position:relative}.chat-messages.loading:after{align-items:center;background-color:#fffc;bottom:0;content:"";display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.message-input-container{background-color:#fff;border-top:1px solid #e9ecef;padding:16px 20px}.selected-recipient{background-color:#e3f2fd;border:1px solid #2196f3;border-radius:8px;font-size:14px;justify-content:space-between;margin-bottom:12px;padding:8px 12px}.clear-recipient,.selected-recipient{align-items:center;color:#1976d2;display:flex}.clear-recipient{background:none;border:none;border-radius:50%;cursor:pointer;font-size:16px;height:20px;justify-content:center;margin-left:8px;padding:0;transition:background-color .2s ease;width:20px}.clear-recipient:hover{background-color:#1976d21a}.message-input-area{align-items:flex-end;display:flex;gap:12px}.message-actions{align-items:flex-end;display:flex;gap:8px}.textarea-container{flex:1 1;position:relative}.message-input{border:1px solid #dee2e6;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;max-height:120px;min-height:44px;padding:12px;resize:vertical;transition:border-color .2s ease;width:100%}.message-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.message-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.message-input::placeholder{color:#6c757d}.character-counter{background-color:#ffffffe6;border-radius:4px;bottom:8px;color:#6c757d;font-size:12px;padding:2px 4px;pointer-events:none;position:absolute;right:12px;transition:color .2s ease}.character-counter.over-limit{color:#dc3545;font-weight:500}.send-button{background-color:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;height:fit-content;padding:12px 20px;transition:background-color .2s ease;white-space:nowrap}.send-button:hover:not(:disabled){background-color:#0056b3}.send-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.preview-button{align-items:center;background-color:#6f42c1;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;height:fit-content;padding:12px 16px;transition:background-color .2s ease;white-space:nowrap}.preview-button:hover:not(:disabled){background-color:#5a2d91}.preview-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.photo-button{align-items:center;background-color:#28a745;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;height:fit-content;justify-content:center;min-width:44px;padding:12px;transition:background-color .2s ease;white-space:nowrap}.photo-button:hover:not(:disabled){background-color:#218838}.photo-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.photo-upload-modal{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.photo-upload-modal-content{max-height:90vh;max-width:600px;overflow:auto;position:relative;width:100%}.photo-upload-progress{align-items:center;background:#ffffffe6;border-radius:8px;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.upload-spinner{animation:spin 1s linear infinite;font-size:24px;margin-bottom:10px}.photo-upload-progress p{color:#495057;font-size:16px;font-weight:500;margin:0}@media (max-width:768px){.message-input-container{padding:12px 16px}.message-input-area{gap:8px}.message-input{font-size:16px;padding:10px}.character-counter{font-size:11px;margin-top:3px}.send-button{font-size:13px;padding:10px 16px}.photo-button{font-size:14px;min-width:40px;padding:10px}.message-actions{gap:6px}.selected-recipient{font-size:13px;margin-bottom:10px;padding:6px 10px}}.status-indicator{align-items:center;border:1px solid;border-radius:.5rem;display:inline-flex;font-weight:500;gap:.375rem;transition:all .2s ease-in-out}.status-indicator__icon{align-items:center;display:flex;flex-shrink:0;justify-content:center}.status-indicator__text{font-size:inherit;white-space:nowrap}.status-indicator--small{font-size:.75rem;gap:.25rem;padding:.25rem .5rem}.status-indicator--small .status-indicator__icon{font-size:.875rem}.status-indicator--medium{font-size:.875rem;gap:.375rem;padding:.375rem .75rem}.status-indicator--medium .status-indicator__icon{font-size:1rem}.status-indicator--large{font-size:1rem;gap:.5rem;padding:.5rem 1rem}.status-indicator--large .status-indicator__icon{font-size:1.25rem}.status-indicator:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.status-indicator:not(:has(.status-indicator__text)){aspect-ratio:1;border-radius:50%;justify-content:center;padding:.375rem}.status-indicator--small:not(:has(.status-indicator__text)){padding:.25rem}.status-indicator--large:not(:has(.status-indicator__text)){padding:.5rem}.status-indicator{cursor:default}.status-indicator:focus{outline:2px solid #3b82f6;outline-offset:2px}@keyframes statusChange{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.status-indicator.status-changed{animation:statusChange .3s ease-in-out}@media (max-width:768px){.status-indicator--medium{font-size:.75rem;padding:.25rem .5rem}.status-indicator--large{font-size:.875rem;padding:.375rem .75rem}}.preview-modal__overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.preview-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:1rem;box-shadow:0 25px 50px #00000040;display:flex;flex-direction:column;max-height:90vh;max-width:800px;position:relative;width:100%}.preview-modal--loading{pointer-events:none}.preview-modal__loading-overlay{align-items:center;background:#ffffffe6;border-radius:1rem;bottom:0;color:#3b82f6;display:flex;flex-direction:column;font-weight:500;gap:1rem;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.spinner{border:3px solid #e5e7eb;border-top-color:#3b82f6;height:2rem;width:2rem}.preview-modal__header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:1.5rem 2rem}.preview-modal__title{align-items:center;display:flex;gap:1rem}.preview-modal__title h2{color:#374151;font-size:1.5rem;font-weight:600;margin:0}.preview-modal__close{align-items:center;background:none;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;height:2.5rem;justify-content:center;padding:.5rem;transition:all .2s ease-in-out;width:2.5rem}.preview-modal__close:hover:not(:disabled){background-color:#f3f4f6;color:#374151}.preview-modal__close:disabled{cursor:not-allowed;opacity:.5}.preview-modal__content{flex:1 1;overflow-y:auto;padding:2rem}.preview-modal__metadata{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;margin-bottom:2rem;padding:1.5rem}.preview-modal__meta-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.preview-modal__meta-item{display:flex;flex-direction:column;gap:.25rem}.preview-modal__meta-item label{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.preview-modal__meta-item span{color:#374151;font-size:.875rem;font-weight:500}.preview-modal__section{margin-bottom:2rem}.preview-modal__section h3{border-bottom:2px solid #e5e7eb;color:#374151;font-size:1.125rem;font-weight:600;margin:0 0 1rem;padding-bottom:.5rem}.preview-modal__content-text{word-wrap:break-word;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;color:#374151;font-size:.875rem;line-height:1.6;padding:1.5rem;white-space:pre-wrap}.preview-modal__image-container{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden}.preview-modal__image{display:block;height:auto;max-height:400px;object-fit:contain;width:100%}.preview-modal__image-caption{background-color:#fff;border-top:1px solid #e5e7eb;color:#374151;font-size:.875rem;padding:1rem}.preview-modal__image-loading{align-items:center;background-color:#f9fafb;color:#6b7280;display:flex;flex-direction:column;font-size:.875rem;justify-content:center;padding:3rem}.preview-modal__image-loading .spinner{margin-bottom:1rem}.preview-modal__no-image{align-items:center;background-color:#f9fafb;border:2px dashed #d1d5db;border-radius:.75rem;color:#6b7280;display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.preview-modal__no-image span{display:block;font-size:1.5rem;margin-bottom:.5rem}.preview-modal__no-image p{font-size:.875rem;line-height:1.4;margin:0}.preview-modal__multi-message{display:flex;flex-direction:column;gap:1rem}.preview-modal__message{border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden}.preview-modal__message-header{background-color:#f3f4f6;border-bottom:1px solid #e5e7eb;padding:.75rem 1rem}.preview-modal__message-role{color:#374151;font-size:.875rem;font-weight:600}.preview-modal__message-content{word-wrap:break-word;color:#374151;font-size:.875rem;line-height:1.6;padding:1rem;white-space:pre-wrap}.preview-modal__ai-response{background-color:#f0f9ff;border:1px solid #bae6fd;border-left:4px solid #3b82f6;border-radius:.75rem;padding:1.5rem}.preview-modal__response-content{word-wrap:break-word;color:#374151;font-size:.875rem;line-height:1.6;margin-bottom:.5rem;white-space:pre-wrap}.preview-modal__response-meta{color:#6b7280;font-size:.75rem;font-style:italic}.preview-modal__no-response{background-color:#f9fafb;border:2px dashed #d1d5db;border-radius:.75rem;color:#6b7280;padding:2rem;text-align:center}.preview-modal__no-response p{font-size:.875rem;margin:0 0 1rem}.preview-modal__help-text{color:#9ca3af!important;font-size:.75rem!important;font-style:italic;margin:.5rem 0 0!important}.preview-modal__admin-notes{word-wrap:break-word;background-color:#fefce8;border:1px solid #fde047;border-left:4px solid #eab308;border-radius:.75rem;color:#374151;font-size:.875rem;line-height:1.6;padding:1.5rem;white-space:pre-wrap}.preview-modal__footer{align-items:center;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:.75rem;justify-content:flex-end;padding:1.5rem 2rem}.preview-modal__actions{align-items:center;display:flex;gap:.75rem;margin-right:auto}.btn{background:#fff;border:1px solid;border-radius:.375rem;font-size:.875rem;gap:.375rem}.btn:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.btn:disabled{box-shadow:none;opacity:.5;transform:none}.btn--approve{border-color:#059669;color:#059669}.btn--approve:hover:not(:disabled){background-color:#059669;color:#fff}.btn--reject{border-color:#dc2626;color:#dc2626}.btn--reject:hover:not(:disabled){background-color:#dc2626;color:#fff}.btn--send{border-color:#7c3aed;color:#7c3aed}.btn--send:hover:not(:disabled){background-color:#7c3aed;color:#fff}.btn--preview{border-color:#0891b2;color:#0891b2}.btn--preview:hover:not(:disabled){background-color:#0891b2;color:#fff}.btn--secondary{background-color:#f9fafb;border-color:#d1d5db;color:#6b7280}.btn--secondary:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}@media (max-width:768px){.preview-modal{margin:.5rem;max-height:95vh}.preview-modal__content,.preview-modal__footer,.preview-modal__header{padding:1rem}.preview-modal__meta-grid{grid-template-columns:1fr}.preview-modal__footer{align-items:stretch;flex-direction:column}.preview-modal__actions{flex-wrap:wrap;justify-content:center;margin-right:0}}@media (max-width:480px){.preview-modal__overlay{padding:0}.preview-modal{border-radius:0;margin:0;max-height:100vh}.preview-modal__title{align-items:flex-start;flex-direction:column;gap:.5rem}.preview-modal__actions{flex-direction:column}}.preview-modal__query-edit{margin-top:8px}.preview-modal__query-textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;margin-top:4px;min-height:80px;padding:8px;resize:vertical;width:100%}.preview-modal__query-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.preview-modal__query-actions{display:flex;gap:8px;margin-top:8px}.btn--small{border-radius:3px;font-size:12px}.btn--edit{background-color:#f8f9fa;border:1px solid #dee2e6;color:#495057}.btn--edit:hover{background-color:#e9ecef;border-color:#adb5bd}.btn--primary{background-color:#007bff;border:1px solid #007bff;color:#fff}.btn--primary:hover{background-color:#0056b3;border-color:#0056b3}.preview-modal__editable-response{margin-bottom:1rem}.preview-modal__response-textarea{background-color:#f9fafb;border:1px solid #d1d5db;border-radius:.5rem;font-family:inherit;font-size:.875rem;line-height:1.6;min-height:120px;padding:1rem;resize:vertical;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out;width:100%}.preview-modal__response-textarea:focus{background-color:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.preview-modal__response-actions{align-items:center;display:flex;gap:.75rem;margin-top:.75rem}.btn--generate{background-color:#fff;border-color:#059669;color:#059669}.btn--generate:hover:not(:disabled){background-color:#059669;color:#fff}.btn--generate:disabled{cursor:not-allowed;opacity:.6}.preview-modal__final-messages{border-top:2px solid #e5e7eb;margin-top:2rem;padding-top:2rem}.preview-modal__final-messages h4{align-items:center;color:#374151;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.preview-modal__final-messages-list{display:flex;flex-direction:column;gap:1rem}.preview-modal__final-message{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;overflow:hidden}.preview-modal__final-message-header{align-items:center;background-color:#f3f4f6;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:.75rem 1rem}.preview-modal__final-message-label{color:#374151;font-size:.875rem;font-weight:600}.preview-modal__final-message-count{background-color:#e5e7eb;border-radius:.25rem;color:#6b7280;font-size:.75rem;padding:.25rem .5rem}.preview-modal__final-message-content{word-wrap:break-word;background-color:#fafafa;color:#374151;font-size:.875rem;line-height:1.6;padding:1rem;white-space:pre-wrap}.preview-modal__no-final-messages{background-color:#f9fafb;border:2px dashed #d1d5db;border-radius:.5rem;color:#6b7280;padding:2rem;text-align:center}.preview-modal__no-final-messages p{font-size:.875rem;margin:0}.preview-modal__final-messages-loading{align-items:center;color:#6b7280;display:flex;font-size:.875rem;justify-content:center;padding:2rem}.preview-modal__final-messages-loading .spinner{border-width:2px;height:1.25rem;margin-right:.75rem;width:1.25rem}.preview-modal__final-messages-error{background-color:#fef2f2;border:1px solid #fecaca;border-radius:.5rem;color:#dc2626;font-size:.875rem;padding:1rem}.preview-modal__char-count{color:#6b7280;font-size:.75rem;margin-top:.25rem}.preview-modal__char-count--warning{color:#d97706}.preview-modal__char-count--error{color:#dc2626}.job-status-modal__overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.job-status-modal__content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.job-status-modal__header{align-items:center;background-color:#f8f9fa;border-bottom:1px solid #e9ecef;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.job-status-modal__header h2{color:#333;font-size:1.25rem;font-weight:600;margin:0}.job-status-modal__controls{align-items:center;display:flex;gap:12px}.job-status-modal__auto-refresh{align-items:center;color:#666;cursor:pointer;display:flex;font-size:.875rem;gap:6px}.job-status-modal__auto-refresh input[type=checkbox]{margin:0}.job-status-modal__refresh-btn{align-items:center;background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:4px;padding:6px 12px;transition:background-color .2s}.job-status-modal__refresh-btn:hover:not(:disabled){background:#0056b3}.job-status-modal__refresh-btn:disabled{cursor:not-allowed;opacity:.6}.job-status-modal__reset-btn{align-items:center;background:#ffc107;border:none;border-radius:4px;color:#212529;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:4px;padding:6px 12px;transition:background-color .2s}.job-status-modal__reset-btn:hover:not(:disabled){background:#e0a800}.job-status-modal__reset-btn:disabled{cursor:not-allowed;opacity:.6}.job-status-modal__close-btn{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:1.5rem;padding:4px;transition:background-color .2s}.job-status-modal__close-btn:hover{background:#e9ecef}.job-status-modal__body{padding:24px}.job-status-modal__loading{color:#666;font-style:italic;padding:40px;text-align:center}.job-status-modal__error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:20px;padding:12px 16px}.job-status-modal__section{margin-bottom:24px}.job-status-modal__section:last-child{margin-bottom:0}.job-status-modal__section h3{border-bottom:2px solid #e9ecef;color:#333;font-size:1.1rem;font-weight:600;margin:0 0 12px;padding-bottom:6px}.job-status-modal__info-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.job-status-modal__info-item{display:flex;flex-direction:column;gap:4px}.job-status-modal__info-item label{color:#555;font-size:.875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.job-status-modal__info-item span{color:#333;font-size:.95rem;word-break:break-word}.job-status-modal__status-badge{border-radius:4px;color:#fff;display:inline-block;font-size:.875rem;font-weight:500;padding:4px 8px;text-transform:capitalize}.job-status-modal__error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;font-family:Courier New,monospace;font-size:.875rem;padding:12px 16px;white-space:pre-wrap;word-break:break-word}.job-status-modal__logs{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;max-height:300px;overflow-y:auto;padding:12px}.job-status-modal__log-entry{color:#333;font-family:Courier New,monospace;font-size:.8rem;line-height:1.4;margin-bottom:4px;word-break:break-all}.job-status-modal__log-entry:last-child{margin-bottom:0}.job-status-modal__no-logs{color:#666;font-style:italic;padding:20px;text-align:center}.status-badge{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.status-badge--pending{background-color:#ffc107;color:#212529}.status-badge--approved_waiting{background-color:#17a2b8;color:#fff}.status-badge--sent{background-color:#007bff;color:#fff}.status-badge--completed{background-color:#28a745;color:#fff}.status-badge--failed,.status-badge--rejected{background-color:#dc3545;color:#fff}.status-badge--cancelled,.status-badge--unknown{background-color:#6c757d;color:#fff}.job-status-modal__info-item:has(.status-badge){background-color:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;padding:8px}@media (max-width:768px){.job-status-modal__overlay{padding:10px}.job-status-modal__content{max-height:95vh}.job-status-modal__header{align-items:stretch;flex-direction:column;gap:12px;padding:16px 20px}.job-status-modal__controls{justify-content:space-between}.job-status-modal__body{padding:20px}.job-status-modal__info-grid{grid-template-columns:1fr}.job-status-modal__header h2{font-size:1.1rem;text-align:center}}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.job-status-modal__refresh-btn:disabled{animation:pulse 1.5s infinite}.delete-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.delete-modal{animation:modalSlideIn .2s ease-out;background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-height:80vh;max-width:500px;overflow-y:auto;padding:0;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.delete-modal__header{align-items:center;background-color:#fff5f5;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem}.delete-modal__header h3{align-items:center;color:#dc3545;display:flex;font-size:1.25rem;gap:.5rem;margin:0}.delete-modal__close{align-items:center;background:none;border:none;border-radius:4px;color:#6c757d;cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:background-color .2s;width:30px}.delete-modal__close:hover:not(:disabled){background-color:#f8f9fa;color:#495057}.delete-modal__close:disabled{cursor:not-allowed;opacity:.5}.delete-modal__content{padding:1.5rem}.delete-modal__content>p{color:#495057;font-size:1rem;margin:0 0 1.5rem}.delete-modal__request-info{background-color:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;margin:1rem 0;padding:1rem}.request-info-item{font-size:.9rem;margin-bottom:.5rem}.request-info-item strong{margin-right:.5rem}.query-preview{background-color:#fff;border:1px solid #dee2e6;border-radius:3px;color:#495057;font-family:monospace;font-size:.85rem;margin-top:.25rem;padding:.5rem;word-break:break-word}.delete-modal__warning{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;margin:1rem 0;padding:.75rem}.delete-modal__warning p{align-items:flex-start;color:#856404;display:flex;font-size:.9rem;gap:.5rem;margin:0}.delete-modal__actions{background-color:#f8f9fa;border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.delete-modal__actions .btn{min-width:120px}.btn--danger{background-color:#dc3545;border-color:#dc3545;color:#fff}.btn--danger:hover:not(:disabled){background-color:#c82333;border-color:#bd2130}.btn--danger:disabled{cursor:not-allowed;opacity:.65}.btn--danger:disabled,.btn--secondary{background-color:#6c757d;border-color:#6c757d}.btn--secondary{color:#fff}.btn--secondary:hover:not(:disabled){background-color:#5a6268;border-color:#545b62}.btn--secondary:disabled{cursor:not-allowed;opacity:.65}.btn{font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.btn:focus{box-shadow:0 0 0 .2rem #007bff40;outline:0}@media (max-width:576px){.delete-modal{margin:1rem;width:95%}.delete-modal__actions,.delete-modal__content,.delete-modal__header{padding:1rem}.delete-modal__actions{flex-direction:column}.delete-modal__actions .btn{width:100%}}.reset-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.reset-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.reset-modal__header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:20px 24px 16px}.reset-modal__header h3{align-items:center;color:#333;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0}.reset-modal__close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:20px;height:28px;justify-content:center;padding:4px;transition:all .2s ease;width:28px}.reset-modal__close:hover:not(:disabled){background-color:#e9ecef;color:#333}.reset-modal__close:disabled{cursor:not-allowed;opacity:.5}.reset-modal__content{padding:24px}.reset-modal__content>p{color:#495057;font-size:16px;font-weight:500;margin:0 0 20px}.reset-modal__request-info{background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-bottom:24px;padding:16px}.request-info-item{display:flex;font-size:14px;margin-bottom:8px}.request-info-item:last-child{margin-bottom:0}.request-info-item strong{color:#495057;margin-right:8px;min-width:80px}.query-preview{color:#666;font-style:italic;line-height:1.4;margin-top:4px}.reset-modal__options{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.reset-option{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:16px;transition:all .2s ease}.reset-option:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff1a}.reset-option__button{align-items:center;border-radius:6px;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;margin-bottom:8px;padding:12px 16px;transition:all .2s ease;width:100%}.reset-option__button:hover:not(:disabled){box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.reset-option__button:active:not(:disabled){transform:translateY(0)}.reset-option__button:disabled{cursor:not-allowed;opacity:.6;transform:none}.reset-option__description{color:#666;font-size:13px;line-height:1.4;text-align:center}.reset-modal__warning{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;color:#856404;font-size:14px;line-height:1.4;padding:16px}.reset-modal__warning p{margin:0}.reset-modal__warning strong{color:#533f03}.reset-option .btn--primary{background-color:#007bff;border-color:#007bff;color:#fff}.reset-option .btn--primary:hover:not(:disabled){background-color:#0056b3;border-color:#0056b3}.reset-option .btn--success{background-color:#28a745;border-color:#28a745;color:#fff}.reset-option .btn--success:hover:not(:disabled){background-color:#1e7e34;border-color:#1e7e34}.reset-option .btn--secondary{background-color:#6c757d;border-color:#6c757d;color:#fff}.reset-option .btn--secondary:hover:not(:disabled){background-color:#545b62;border-color:#545b62}@media (max-width:768px){.reset-modal-overlay{padding:10px}.reset-modal{margin:0;max-width:100%}.reset-modal__header{padding:16px 20px 12px}.reset-modal__header h3{font-size:16px}.reset-modal__content{padding:20px}.reset-modal__request-info{padding:12px}.request-info-item{flex-direction:column;gap:4px}.request-info-item strong{margin-right:0;min-width:auto}.reset-option{padding:12px}.reset-option__button{font-size:13px;padding:10px 12px}.reset-option__description{font-size:12px}.reset-modal__warning{font-size:13px;padding:12px}}@media (max-width:480px){.reset-modal__content>p,.reset-modal__header h3{font-size:15px}.reset-option__button{font-size:12px;padding:8px 10px}}.ai-request-modal-backdrop{align-items:center;background-color:#000c;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.ai-request-modal{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;height:100%;max-height:90vh;max-width:90vw;overflow:hidden;width:100%}.ai-request-modal__header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px}.ai-request-modal__title{color:#333;font-size:18px;font-weight:600;margin:0}.ai-request-modal__close{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:28px;font-weight:300;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.ai-request-modal__close:hover{background-color:#f0f0f0;color:#333}.ai-request-modal__content{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.modal-content__image-container{align-items:center;background:#f8f9fa;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:20px}.modal-content__image{border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:100%;max-width:100%;object-fit:contain}.modal-content__mixed-container{display:flex;flex:1 1;flex-direction:column;gap:20px;overflow:hidden;padding:20px}.modal-content__query-section{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;flex-shrink:0;padding:16px}.modal-section-title{color:#495057;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.modal-query-text{word-wrap:break-word;color:#333;font-size:15px;line-height:1.5;white-space:pre-wrap}.modal-content__image-section{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.modal-image-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:12px}.modal-zoom-controls{background:#f8f9fa;border-radius:6px;gap:8px;padding:4px}.modal-zoom-controls,.zoom-btn{align-items:center;border:1px solid #dee2e6;display:flex}.zoom-btn{background:#fff;border-radius:4px;color:#495057;cursor:pointer;font-size:16px;font-weight:600;height:32px;justify-content:center;transition:all .2s ease;width:32px}.zoom-btn:hover{background:#e9ecef;border-color:#adb5bd}.zoom-reset{font-size:14px}.zoom-level{color:#6c757d;font-size:12px;font-weight:600;min-width:40px;text-align:center}.modal-image-wrapper{align-items:flex-start;background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;box-sizing:border-box;display:flex;flex:1 1;justify-content:center;min-height:300px;overflow:auto;padding:20px}.modal-content__response-section{background:#fff;border:1px solid #dee2e6;border-radius:8px}.modal-content__response-section,.modal-content__text-container{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.modal-content__text{word-wrap:break-word;background:#fff;color:#333;flex:1 1;font-size:15px;line-height:1.6;overflow-y:auto;padding:16px;white-space:pre-wrap}.modal-error,.modal-loading,.modal-placeholder{align-items:center;color:#666;display:flex;font-size:16px;height:200px;justify-content:center;width:100%}.modal-loading{color:#007bff}.modal-error{color:#dc3545}.modal-placeholder{color:#999;font-style:italic}@media (max-width:768px){.ai-request-modal-backdrop{padding:10px}.ai-request-modal{max-height:95vh;max-width:95vw}.ai-request-modal__header{padding:16px 20px}.ai-request-modal__title{font-size:16px}.modal-content__mixed-container{gap:16px;padding:16px}.modal-content__query-section{padding:12px}.modal-section-title{font-size:13px}.modal-query-text{font-size:14px}.modal-content__text{font-size:14px;padding:12px}.modal-image-header{align-items:flex-start;flex-direction:column;gap:8px}.zoom-btn{font-size:14px;height:28px;width:28px}.zoom-level{font-size:11px;min-width:35px}}@media (max-width:480px){.ai-request-modal-backdrop{padding:5px}.ai-request-modal{max-height:98vh;max-width:98vw}.ai-request-modal__header{padding:12px 16px}.modal-content__mixed-container{padding:12px}.modal-zoom-controls{gap:6px;padding:3px}.zoom-btn{font-size:12px;height:24px;width:24px}}@media (max-width:768px){.ai-request-modal-backdrop{padding:10px}.ai-request-modal{max-height:95vh;max-width:95vw}.ai-request-modal__header{padding:16px 20px}.ai-request-modal__title{font-size:16px}.modal-content__text{font-size:14px;padding:20px}.modal-content__image-container{padding:16px}}@media (max-width:480px){.ai-request-modal-backdrop{padding:5px}.ai-request-modal{max-height:98vh;max-width:98vw}.ai-request-modal__header{padding:12px 16px}.modal-content__text{padding:16px}.modal-content__image-container{padding:12px}}.admin-ai-requests-card-view{display:flex;flex-direction:column;height:100%;width:100%}.admin-ai-requests-card-view__header{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 1px 2px #0000001a;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.card-view-header__controls{align-items:center;display:flex;gap:12px}.select-all-control{align-items:center;cursor:pointer;display:flex;gap:8px;-webkit-user-select:none;user-select:none}.select-all-checkbox{cursor:pointer;margin:0}.select-all-label{color:#333;cursor:pointer;font-size:14px;font-weight:500}.card-view-header__info{align-items:center;display:flex;gap:12px}.results-count{color:#666;font-size:13px;font-weight:500}.admin-ai-requests-card-view__loading{align-items:center;color:#666;display:flex;font-size:16px;justify-content:center;padding:60px 20px}.admin-ai-requests-card-view__loading .spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:24px;margin-right:12px;width:24px}.admin-ai-requests-card-view__error{background-color:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px;margin:16px;padding:16px;text-align:center}.admin-ai-requests-card-view__empty{align-items:center;display:flex;justify-content:center;padding:60px 20px}.empty-state{max-width:400px;text-align:center}.empty-state__icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state__title{color:#333;font-size:18px;font-weight:600;margin-bottom:8px}.empty-state__description{color:#666;font-size:14px;line-height:1.5}.admin-ai-requests-card-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:0;width:100%}.ai-request-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;height:300px;overflow:hidden;transition:all .2s ease;width:100%}.ai-request-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.ai-request-card--selected{background-color:#f8f9fa;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.ai-request-card--loading{opacity:.7;pointer-events:none}.ai-request-card__header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.ai-request-card__header:hover{background-color:#007bff1a}.ai-request-card__header--pending{background:#fef3c7;border-bottom-color:#fbbf24}.ai-request-card__header--approved_waiting{background:#dbeafe;border-bottom-color:#3b82f6}.ai-request-card__header--sent{background:#ede9fe;border-bottom-color:#8b5cf6}.ai-request-card__header--completed{background:#d1fae5;border-bottom-color:#10b981}.ai-request-card__header--rejected{background:#fee2e2;border-bottom-color:#ef4444}.ai-request-card__header--failed{background:#fecaca;border-bottom-color:#dc2626}.ai-request-card__header--image_preview{background:#e0e7ff;border-bottom-color:#6366f1}.ai-request-card__header--approved_waiting .ai-request-card__id,.ai-request-card__header--completed .ai-request-card__id,.ai-request-card__header--failed .ai-request-card__id,.ai-request-card__header--image_preview .ai-request-card__id,.ai-request-card__header--pending .ai-request-card__id,.ai-request-card__header--rejected .ai-request-card__id,.ai-request-card__header--sent .ai-request-card__id{color:#1f2937;font-weight:700}.ai-request-card__header--approved_waiting .ai-request-card__menu-button,.ai-request-card__header--completed .ai-request-card__menu-button,.ai-request-card__header--failed .ai-request-card__menu-button,.ai-request-card__header--image_preview .ai-request-card__menu-button,.ai-request-card__header--pending .ai-request-card__menu-button,.ai-request-card__header--rejected .ai-request-card__menu-button,.ai-request-card__header--sent .ai-request-card__menu-button{color:#374151}.ai-request-card__header--approved_waiting .ai-request-card__menu-button:hover,.ai-request-card__header--completed .ai-request-card__menu-button:hover,.ai-request-card__header--failed .ai-request-card__menu-button:hover,.ai-request-card__header--image_preview .ai-request-card__menu-button:hover,.ai-request-card__header--pending .ai-request-card__menu-button:hover,.ai-request-card__header--rejected .ai-request-card__menu-button:hover,.ai-request-card__header--sent .ai-request-card__menu-button:hover{background-color:#0000001a;color:#111827}.ai-request-card__details-toggle{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:4px 8px;transition:all .2s ease}.ai-request-card__details-toggle:hover{background-color:#0000001a;color:#333}.ai-request-card__header--approved_waiting .ai-request-card__details-toggle,.ai-request-card__header--completed .ai-request-card__details-toggle,.ai-request-card__header--failed .ai-request-card__details-toggle,.ai-request-card__header--image_preview .ai-request-card__details-toggle,.ai-request-card__header--pending .ai-request-card__details-toggle,.ai-request-card__header--rejected .ai-request-card__details-toggle,.ai-request-card__header--sent .ai-request-card__details-toggle{color:#374151}.ai-request-card__header--approved_waiting .ai-request-card__details-toggle:hover,.ai-request-card__header--completed .ai-request-card__details-toggle:hover,.ai-request-card__header--failed .ai-request-card__details-toggle:hover,.ai-request-card__header--image_preview .ai-request-card__details-toggle:hover,.ai-request-card__header--pending .ai-request-card__details-toggle:hover,.ai-request-card__header--rejected .ai-request-card__details-toggle:hover,.ai-request-card__header--sent .ai-request-card__details-toggle:hover{background-color:#0000001a;color:#111827}.ai-request-card__header-left{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.ai-request-card__checkbox{cursor:pointer;flex-shrink:0;margin:0}.ai-request-card__id{color:#007bff;flex-shrink:0;font-size:14px;font-weight:600}.ai-request-card__contact-name{color:#666;flex:1 1;font-size:12px;font-weight:500;margin-left:4px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-request-card__header-right{align-items:center;display:flex;gap:8px}.ai-request-card__menu-button{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:16px;padding:4px;transition:all .2s ease}.ai-request-card__menu-button:hover{background-color:#e9ecef;color:#333}.ai-request-card__main-content{cursor:pointer;display:flex;flex:1 1;flex-direction:column;overflow:hidden;position:relative;transition:background-color .2s ease}.ai-request-card__main-content:hover{background-color:#00000005}.ai-request-card__response-content{display:flex;flex:1 1;flex-direction:column;height:100%;width:100%}.ai-request-card__details{animation:slideDown .2s ease-out;background:#f8f9fa;border-bottom:1px solid #e9ecef;border-top:1px solid #e9ecef;padding:16px}.ai-request-card__details .ai-request-card__user-info{margin-bottom:12px}.ai-request-card__details .ai-request-card__service-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.ai-request-card__details .ai-request-card__query{margin-bottom:12px}.ai-request-card__details .query-label{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.ai-request-card__details .query-text{color:#333;font-size:13px;line-height:1.4;white-space:pre-wrap;word-break:break-word}.ai-request-card__details .ai-request-card__dates{display:flex;flex-direction:column;gap:4px}.ai-request-card__preview-container{flex:0 0 150px;overflow:hidden;position:relative}.ai-request-card__preview{align-items:center;display:flex;flex:1 1;height:100%;justify-content:center;overflow:hidden;position:relative;width:100%}.ai-request-card__preview--image{background:#f8f9fa;flex:1 1;height:100%}.ai-request-card__preview--text{background:#fff;flex:1 1;height:100%;padding:0}.ai-request-card__preview--loading{background:#f8f9fa;flex:1 1;height:100%}.ai-request-card__preview--query{background:linear-gradient(135deg,#f8f9fa,#e9ecef);flex:1 1;height:100%;padding:16px;position:relative}.ai-request-card__preview--empty{background:#f8f9fa;border:2px dashed #dee2e6;flex:1 1;height:100%}.ai-request-card__preview--error{flex:1 1;height:100%}.preview-image{display:block;height:100%;object-fit:contain;width:100%}.preview-text{box-sizing:border-box;display:flex;flex-direction:column;height:100%;overflow:hidden;padding:16px;width:100%}.preview-text p{word-wrap:break-word;-webkit-line-clamp:8;-webkit-box-orient:vertical;color:#333;display:-webkit-box;flex:1 1;font-size:14px;line-height:1.4;margin:0;overflow:hidden;white-space:pre-wrap}.preview-read-more{color:#007bff;cursor:pointer;font-size:12px;font-weight:500;margin-top:8px}.preview-read-more:hover{text-decoration:underline}.preview-loading{align-items:center;color:#666;display:flex;flex-direction:column;font-size:13px;gap:8px;justify-content:center}.preview-loading .spinner{animation:spin 1s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:20px;width:20px}.preview-query{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.preview-query p{color:#666;font-size:13px;font-style:italic;line-height:1.4;margin:0;opacity:.7;text-align:center}.preview-query-overlay{background:#000000b3;border-radius:4px;bottom:8px;color:#fff;font-size:11px;font-weight:500;padding:4px 8px;position:absolute;right:8px}.preview-placeholder{color:#999;font-style:italic;height:100%;width:100%}.preview-error,.preview-placeholder{align-items:center;display:flex;font-size:13px;justify-content:center}.preview-error{color:#dc2626;flex-direction:column;gap:8px;text-align:center}.ai-request-card__preview--error{background:#fef2f2;border:2px dashed #fca5a5}.ai-request-card__content{display:flex;flex:1 1;flex-direction:column;gap:12px;padding:16px}.ai-request-card__user-info{display:flex;flex-direction:column;gap:4px}.user-name{font-size:14px;font-weight:600}.user-details{display:flex;gap:12px}.booking-code,.user-details,.user-id{color:#666;font-size:12px}.ai-request-card__service-info{align-items:center;display:flex;gap:8px;justify-content:space-between}.service-type .type-badge{background:#e9ecef;border-radius:12px;color:#495057;font-size:11px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.ai-request-card__query{flex:1 1}.query-text{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;font-size:13px;line-height:1.4}.ai-request-card__dates{display:flex;flex-direction:column;gap:4px;margin-top:auto}.date-item{align-items:center;display:flex;font-size:11px;justify-content:space-between}.date-label{color:#666;font-weight:500}.date-value{color:#333}.ai-request-card__footer{align-items:center;background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;flex-shrink:0;justify-content:space-between;padding:12px 16px}.ai-request-card__service-type{flex:1 1}.service-type-badge{background:#e9ecef;border:1px solid #dee2e6;border-radius:12px;color:#495057;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.ai-request-card__actions{display:flex;flex-shrink:0;flex-wrap:wrap;gap:4px;justify-content:center}.admin-ai-requests-card-view__overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.overlay-content{align-items:center;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:column;gap:12px;padding:24px}.overlay-content .spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:24px;width:24px}@media (min-width:1200px){.admin-ai-requests-card-grid{gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));padding:0}}@media (max-width:1199px){.admin-ai-requests-card-grid{gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:0}.ai-request-card{min-height:380px}.ai-request-card__preview-container{flex:0 0 140px}.ai-request-card__preview{height:140px}}@media (max-width:767px){.admin-ai-requests-card-grid{gap:12px;grid-template-columns:1fr;padding:0}.ai-request-card{min-height:350px}.ai-request-card__preview-container{flex:0 0 120px}.ai-request-card__preview{height:120px}.ai-request-card__content{gap:10px;padding:12px}.ai-request-card__actions{gap:3px;padding:10px 12px}.ai-request-card__header{padding:10px 12px}.admin-ai-requests-card-view__header{align-items:stretch;flex-direction:column;gap:8px;padding:10px 12px}.card-view-header__controls,.card-view-header__info{justify-content:center}.ai-request-card__actions .btn--small.btn--icon{font-size:12px!important;height:24px!important;max-width:24px!important;min-width:24px!important;width:24px!important}}@media (max-width:480px){.ai-request-card__preview-container{flex:0 0 100px}.ai-request-card__preview{height:100px}.ai-request-card{min-height:320px}.user-details{flex-direction:column;gap:2px}.ai-request-card__service-info{gap:6px}.ai-request-card__service-info,.date-item{align-items:flex-start;flex-direction:column}.date-item{gap:2px}}.ai-response-content{-webkit-line-clamp:8;-webkit-box-orient:vertical;background:#fff;border-radius:4px;box-sizing:border-box;color:#333;display:-webkit-box;font-size:14px;height:100%;line-height:1.6;overflow:hidden;padding:16px;white-space:pre-wrap;width:100%;word-break:break-word}.ai-request-card__response-content .ai-request-card__preview--text{height:100%;min-height:200px}.ai-request-card__response-content .preview-text{display:flex;flex-direction:column;height:100%}@media (prefers-contrast:high){.ai-request-card{border-width:2px}.ai-request-card--selected{border-width:3px}.preview-text p,.query-text{color:#000}}@media (prefers-reduced-motion:reduce){.ai-request-card{transition:none}.ai-request-card:hover{transform:none}.spinner{animation:none}.spinner:after{content:"⏳";display:block;font-size:16px}}.admin-ai-requests-table{box-sizing:border-box;display:flex;flex-direction:column;height:100%;max-width:100%;overflow:hidden;padding:5px;width:100%}.admin-ai-requests-table__header{margin-bottom:5px}.header-content{align-items:flex-start;display:flex;gap:20px;justify-content:space-between}.header-text h1{color:#333;font-size:20px;margin:0 0 4px}.header-text p{color:#666;font-size:13px;margin:0}.header-controls{flex-shrink:0}.auto-run-toggle{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;gap:8px;padding:8px 12px}.auto-run-label{color:#333;font-size:14px;font-weight:500}.status-text{font-size:12px}.status-text.enabled{color:#28a745}.status-text.disabled{color:#dc3545}.auto-run-error{align-items:center;background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;display:flex;font-size:12px;justify-content:space-between;margin-top:8px;padding:6px 10px}.auto-run-error button{background:none;border:none;color:#c33;cursor:pointer;font-size:14px;margin-left:8px;padding:0}.admin-ai-requests-table__error{align-items:center;background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;display:flex;justify-content:space-between;margin-bottom:10px;padding:8px 12px}.admin-ai-requests-table__error button{background:none;border:none;color:#c33;cursor:pointer;font-size:16px;margin-left:10px;padding:0}.toggle-switch{display:inline-block;height:20px;position:relative;width:40px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#ccc;border-radius:20px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:14px;left:3px;position:absolute;transition:.3s;width:14px}.toggle-switch input:checked+.toggle-slider{background-color:#28a745}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 1px #28a745}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(20px)}.toggle-switch input:disabled+.toggle-slider{cursor:not-allowed;opacity:.6}.admin-ai-requests-table__loading{align-items:center;color:#666;display:flex;justify-content:center;padding:40px}.spinner{border:2px solid #f3f3f3;border-top-color:#007bff;height:20px;margin-right:10px;width:20px}.admin-ai-requests-table__stats{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:5px}.stats-card{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;flex-direction:row;gap:8px;height:40px;justify-content:space-between;min-width:120px;padding:6px 12px;text-align:center}.stats-card__value{color:#333;font-size:20px;font-weight:700}.stats-card__label{color:#666;font-size:11px;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.stats-card--refresh{background:#f8f9fa;border-color:#007bff;cursor:pointer;transition:all .2s ease}.stats-card--refresh:hover{background:#e3f2fd;border-color:#0056b3;transform:translateY(-1px)}.refresh-button{align-items:center;background:none;border:none;color:inherit;cursor:pointer;display:flex;flex-direction:row;gap:8px;height:100%;justify-content:space-between;padding:0;width:100%}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.refresh-icon{font-size:16px;transition:transform .3s ease}.refresh-button:not(:disabled):hover .refresh-icon{transform:rotate(180deg)}.refresh-label{color:#007bff;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}.refresh-button:disabled .refresh-label{color:#6c757d}.admin-ai-requests-table__filters{align-items:center;display:flex;flex-wrap:nowrap;gap:12px;margin:0}.filter-group{align-items:center;flex-direction:row;gap:6px}.filter-group label{color:#666;font-size:12px;margin:0;white-space:nowrap}.filter-group select{background:#fff;border:1px solid #ddd;border-radius:3px;font-size:12px;height:28px;min-width:100px;padding:4px 8px}.filter-group--search{min-width:250px;position:relative}.search-input{background:#fff;border:1px solid #ddd;border-radius:3px;box-sizing:border-box;font-size:12px;height:28px;margin:0!important;min-width:250px;padding:4px 24px 4px 8px!important;text-indent:0!important;width:100%}.search-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.search-input::placeholder{color:#999;font-style:italic}.search-clear{align-items:center;border-radius:2px;color:#666;display:flex;font-size:12px;height:14px;justify-content:center;padding:0;right:6px;transition:all .2s ease;width:14px}.search-clear:hover{background-color:#e9ecef;color:#333}.ai-services-filter,.filter-group--ai-services{min-width:200px;position:relative}.ai-services-filter{background:#fff;border:1px solid #ddd;border-radius:4px}.ai-services-filter__header{align-items:center;background:#fff;border-radius:4px;cursor:pointer;display:flex;font-size:13px;justify-content:space-between;min-height:32px;padding:6px 10px}.ai-services-filter__header:hover{background-color:#f8f9fa}.ai-services-filter__count{color:#333;font-weight:500}.ai-services-filter__clear{align-items:center;background:none;border:none;border-radius:2px;color:#666;cursor:pointer;display:flex;font-size:14px;height:16px;justify-content:center;margin-left:8px;padding:0;width:16px}.ai-services-filter__clear:hover{background-color:#e9ecef;color:#333}.ai-services-filter__options{background:#fff;border:1px solid #ddd;border-radius:0 0 4px 4px;border-top:none;box-shadow:0 2px 8px #0000001a;display:none;left:0;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.ai-services-filter:focus-within .ai-services-filter__options,.ai-services-filter:hover .ai-services-filter__options{display:block}.ai-service-option{align-items:center;border-bottom:1px solid #f0f0f0;cursor:pointer;display:flex;font-size:13px;padding:8px 12px;transition:background-color .2s ease}.ai-service-option:last-child{border-bottom:none}.ai-service-option:hover{background-color:#f8f9fa}.ai-service-option input[type=checkbox]{cursor:pointer;margin-right:8px}.ai-service-option__label{cursor:pointer;flex:1 1;-webkit-user-select:none;user-select:none}.filter-actions{gap:12px}.filter-actions,.view-toggle{align-items:center;display:flex}.view-toggle{gap:8px}.view-toggle label{color:#374151;font-size:14px;font-weight:500;margin:0}.view-toggle__buttons{border:1px solid #d1d5db;border-radius:6px;display:flex;gap:0;overflow:hidden}.view-toggle__buttons .btn{border:none;border-radius:0;border-right:1px solid #d1d5db;font-size:16px;line-height:1;margin:0;padding:6px 10px;transition:all .2s ease}.view-toggle__buttons .btn:last-child{border-right:none}.view-toggle__buttons .btn--primary{background-color:#3b82f6;border-color:#3b82f6;color:#fff}.view-toggle__buttons .btn--outline{background-color:#fff;border-color:#0000;color:#6b7280}.view-toggle__buttons .btn--outline:hover{background-color:#f9fafb;color:#374151}.admin-ai-requests-table__bulk-actions{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:5px;padding:6px 10px}.bulk-actions__count{color:#495057;font-weight:500}.bulk-actions__buttons{display:flex;flex-wrap:wrap;gap:8px}.admin-ai-requests-table__container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:100%;overflow-x:auto;overflow-y:visible;position:relative;scrollbar-color:#94a3b8 #e2e8f0;scrollbar-width:auto;width:100%}.admin-ai-requests-table__container::-webkit-scrollbar{background:#f8fafc;height:12px}.admin-ai-requests-table__container::-webkit-scrollbar-track{background:#e2e8f0;border-radius:6px;margin:0 4px}.admin-ai-requests-table__container::-webkit-scrollbar-thumb{background:#94a3b8;border:2px solid #e2e8f0;border-radius:6px}.admin-ai-requests-table__container::-webkit-scrollbar-thumb:hover{background:#64748b}.admin-ai-requests-table__container::-webkit-scrollbar-corner{background:#f8fafc}.admin-ai-requests-table__table{border-collapse:collapse;font-size:14px;min-width:1200px;width:100%}.admin-ai-requests-table__table th{background:#f8f9fa;border-bottom:2px solid #e9ecef;color:#495057;font-weight:600;padding:12px 8px;text-align:left;white-space:nowrap}.admin-ai-requests-table__table td{border-bottom:1px solid #e9ecef;padding:12px 8px;vertical-align:middle}.admin-ai-requests-table__table tbody tr{cursor:pointer}.admin-ai-requests-table__table tbody tr:hover{background-color:#f8f9fa}.admin-ai-requests-table__table tbody tr.selected{background-color:#e3f2fd}.admin-ai-requests-table__table tbody tr.selected:hover{background-color:#bbdefb}.checkbox-column{text-align:center;width:40px}.id-column{color:#007bff;font-weight:500;width:80px}.user-column{width:150px}.user-info{display:flex;flex-direction:column;gap:2px}.user-name{color:#333;font-weight:500}.user-id{color:#666;font-size:12px}.status-column{width:120px}.type-column{width:100px}.type-badge{background:#e9ecef;border-radius:12px;color:#495057;font-size:12px;font-weight:500;padding:4px 8px}.query-column{max-width:300px;min-width:200px}.query-text{color:#333;cursor:help;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.date-column{color:#666;font-size:12px;width:140px}.actions-column{width:280px}.no-data{color:#666;font-style:italic;padding:40px;text-align:center}.btn{justify-content:center;padding:6px 12px;white-space:nowrap}.btn--small{font-size:11px;padding:4px 8px}.btn--icon.btn--primary{background-color:#3b82f6;color:#fff!important}.btn--icon.btn--secondary{background-color:#6b7280;color:#fff!important}.btn--icon.btn--success{background-color:#10b981;color:#fff!important}.btn--icon.btn--info{background-color:#06b6d4;color:#fff!important}.btn--icon.btn--outline{background-color:#f1f5f9;color:#475569!important}.btn--icon.btn--warning{background-color:#f59e0b;color:#fff!important}.btn--icon.btn--danger{background-color:#ef4444;color:#fff!important}.btn--icon.btn--danger,.btn--icon.btn--info,.btn--icon.btn--primary,.btn--icon.btn--secondary,.btn--icon.btn--success,.btn--icon.btn--warning{filter:brightness(0) invert(1)}.btn--icon.btn--outline{filter:none}.btn--icon{filter:none!important}.btn--icon.btn--danger,.btn--icon.btn--info,.btn--icon.btn--primary,.btn--icon.btn--secondary,.btn--icon.btn--success,.btn--icon.btn--warning{text-shadow:0 0 2px #00000080}.btn:not(.btn--icon).btn--primary{background-color:#4f46e5;border-color:#4f46e5;color:#fff}.btn:not(.btn--icon).btn--primary:hover:not(:disabled){background-color:#4338ca;border-color:#4338ca}.btn:not(.btn--icon).btn--secondary{background-color:#64748b;border-color:#64748b;color:#fff}.btn:not(.btn--icon).btn--secondary:hover:not(:disabled){background-color:#475569;border-color:#475569}.btn:not(.btn--icon).btn--success{background-color:#10b981;border-color:#10b981;color:#fff}.btn:not(.btn--icon).btn--success:hover:not(:disabled){background-color:#059669;border-color:#059669}.btn:not(.btn--icon).btn--info{background-color:#0ea5e9;border-color:#0ea5e9;color:#fff}.btn:not(.btn--icon).btn--info:hover:not(:disabled){background-color:#0284c7;border-color:#0284c7}.btn:not(.btn--icon).btn--outline{background-color:#f8fafc;border-color:#e2e8f0;color:#64748b}.btn:not(.btn--icon).btn--outline:hover:not(:disabled){background-color:#e2e8f0;border-color:#cbd5e1;color:#475569}@media (min-width:1200px){.admin-ai-requests-table__stats{justify-content:flex-start;max-width:100%}.stats-card{flex:0 0 auto;min-width:110px}}@media (max-width:1200px){.admin-ai-requests-table__filters{align-items:stretch;flex-direction:column}.filter-group{align-items:center;flex-direction:row;justify-content:space-between}.filter-group select{min-width:200px}}@media (max-width:768px){.admin-ai-requests-table{padding:5px}.admin-ai-requests-table__stats{justify-content:center}.stats-card{min-width:100px;padding:12px}.admin-ai-requests-table__table{font-size:12px;min-width:800px}.admin-ai-requests-table__table td,.admin-ai-requests-table__table th{padding:8px 4px}.query-column{max-width:120px;min-width:100px}.action-buttons{flex-direction:row;flex-wrap:nowrap;gap:2px}.btn--small{font-size:10px;padding:6px 8px}.btn--small.btn--icon{font-size:12px!important;height:24px!important;max-width:24px!important;min-width:24px!important;width:24px!important}.actions-column{min-width:160px;width:160px}.action-buttons{gap:3px}.admin-ai-requests-table__container::-webkit-scrollbar{height:16px}.admin-ai-requests-table__container::-webkit-scrollbar-thumb{background:#64748b}}.admin-ai-requests__worker-management{background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 1px 2px #0000001a;margin-bottom:5px;padding:8px}.worker-management__header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:10px;padding-bottom:8px}.worker-management__header h3{color:#333;font-size:16px;font-weight:600;margin:0}.worker-management__error{align-items:center;background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px}.worker-management__error button{background:none;border:none;color:#c33;cursor:pointer;font-size:16px;margin-left:10px;padding:0}.worker-management__loading{align-items:center;color:#666;display:flex;justify-content:center;padding:20px}.worker-management__empty{color:#666;font-style:italic;padding:20px;text-align:center}.worker-management__controls{align-items:center;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;gap:15px;margin:15px 0;padding:10px}.scale-workers-control{align-items:center;display:flex;gap:8px}.scale-workers-control label{color:#495057;font-weight:500;margin:0}.scale-workers-control select{background-color:#fff;border:1px solid #ced4da;border-radius:4px;font-size:14px;min-width:120px;padding:4px 8px}.scale-workers-control select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.scale-workers-control select:disabled{background-color:#e9ecef;color:#6c757d;cursor:not-allowed}.worker-status__summary{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px}.status-item{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;flex-direction:column;min-width:100px;padding:12px}.status-label{color:#666;font-size:12px;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}.status-value{color:#333;font-size:20px;font-weight:700}.status-value--success{color:#28a745}.status-value--error{color:#dc3545}.worker-status__details h4{color:#333;font-size:16px;margin:0 0 12px}.workers-list{display:flex;flex-direction:column;gap:8px}.worker-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;justify-content:space-between;padding:12px}.worker-item--running{background:#f8fff9;border-color:#28a745}.worker-item--failed{background:#fff8f8;border-color:#dc3545}.worker-item--stopped{background:#f8f9fa;border-color:#6c757d}.worker-info{align-items:center;display:flex;flex:1 1;gap:12px}.worker-id{color:#333;font-weight:600}.worker-status{border-radius:12px;font-size:12px;font-weight:500;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.worker-status--running{background:#d4edda;color:#155724}.worker-status--failed{background:#f8d7da;color:#721c24}.worker-status--stopped{background:#e2e3e5;color:#383d41}.worker-request{color:#666;font-size:12px;font-style:italic}.btn:not(.btn--icon).btn--danger{background-color:#ef4444;border-color:#ef4444;color:#fff}.btn:not(.btn--icon).btn--danger:hover:not(:disabled){background-color:#dc2626;border-color:#dc2626}@media (max-width:768px){.worker-status__summary{justify-content:center}.worker-item{align-items:stretch;flex-direction:column;gap:8px}.worker-info{justify-content:space-between}}.btn--small.btn--danger{border-color:#dc2626;color:#dc2626;font-size:.75rem;padding:.25rem .5rem}.btn--small.btn--danger:hover:not(:disabled){background-color:#dc2626;color:#fff}.btn--small.btn--danger:disabled{background-color:#6c757d;border-color:#6c757d;cursor:not-allowed;opacity:.65}.btn--icon{align-items:center!important;border:1px solid #0000!important;border-radius:4px!important;box-shadow:0 1px 2px #0000001a;display:flex!important;flex-shrink:0!important;justify-content:center!important;line-height:1!important;padding:0!important;text-align:center!important;transition:all .2s ease;vertical-align:middle!important}.btn--icon,.btn--small.btn--icon{font-size:14px!important;height:28px!important;max-width:28px!important;min-width:28px!important;width:28px!important}.btn--icon:hover:not(:disabled){opacity:1;transform:scale(1.1)}.btn--icon:active:not(:disabled){transform:scale(.95)}.actions-column{min-width:180px;width:180px}.action-buttons{flex-wrap:nowrap;gap:4px;justify-content:flex-start}.btn--warning{background-color:#f59e0b;border-color:#f59e0b;color:#fff}.btn--warning:hover:not(:disabled){background-color:#d97706;border-color:#d97706;color:#fff}.admin-ai-requests-table__pagination{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin:10px 0;padding:12px 16px}.pagination-info{align-items:center;color:#666;display:flex;font-size:14px;gap:16px}.items-per-page{gap:8px}.items-per-page label{color:#666;font-size:13px;font-weight:500;margin:0}.items-per-page select{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:13px;min-width:80px;padding:4px 8px}.pagination-controls{gap:4px}.page-numbers{align-items:center;display:flex;gap:2px;margin:0 8px}.page-numbers .btn{align-items:center;display:flex;font-size:13px;font-weight:500;height:32px;justify-content:center;min-width:32px;padding:0}.page-numbers .btn--primary{background-color:#007bff;border-color:#007bff;color:#fff}.page-numbers .btn--outline{background-color:#fff;border-color:#ddd;color:#666}.page-numbers .btn--outline:hover:not(:disabled){background-color:#f8f9fa;border-color:#adb5bd;color:#495057}.page-numbers .btn:disabled{background-color:#f8f9fa;border-color:#e9ecef;color:#adb5bd;cursor:not-allowed}@media (max-width:768px){.admin-ai-requests-table__pagination{align-items:stretch;flex-direction:column;gap:12px}.pagination-info{flex-wrap:wrap;gap:8px;justify-content:space-between}.pagination-controls{justify-content:center}.page-numbers{margin:0 4px}.page-numbers .btn{font-size:12px;height:28px;min-width:28px}}@media (max-width:480px){.pagination-info{align-items:center;flex-direction:column;text-align:center}.items-per-page{justify-content:center}}.admin-system-prompts{margin:0 auto;max-width:1200px;padding:20px}.admin-system-prompts.loading{color:#666;font-size:18px;padding:40px;text-align:center}.header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:15px}.header h2{color:#333;font-size:28px;margin:0}.btn{display:inline-block;font-size:14px;padding:8px 16px;text-align:center;text-decoration:none;transition:all .2s ease}.btn-primary{background-color:#007bff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-secondary{background-color:#6c757d}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover:not(:disabled){background-color:#117a8b}.btn-danger{background-color:#dc3545}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-sm{font-size:12px;padding:4px 8px}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:20px;padding:12px;position:relative}.close-btn{color:#721c24;font-size:18px;height:20px;position:absolute;right:12px;top:8px;width:20px}.close-btn:hover{background-color:#0000001a;border-radius:50%}.prompt-form{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-bottom:30px;padding:25px}.prompt-form h3{color:#333;font-size:20px;margin:0 0 20px}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:600;margin-bottom:5px}.form-group input,.form-group textarea{border:1px solid #ced4da;border-radius:4px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.form-group textarea{font-family:Courier New,monospace;min-height:120px;resize:vertical;.variable-help{background-color:#e8f4fd;border:1px solid #bee5eb;border-radius:6px;margin-top:15px;padding:20px}.variable-help h4{color:#0c5460;font-size:16px;font-weight:600;margin:0 0 15px}.variable-help h5{color:#0c5460;font-size:14px;font-weight:600;margin:0 0 10px}.variable-list{margin-bottom:0}.variable-section{margin-bottom:20px}.variable-section:last-child{margin-bottom:0}.variable-section ul{margin:0 0 15px;padding-left:20px}.variable-section li{color:#495057;font-size:14px;line-height:1.4;margin-bottom:8px}.variable-section code{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;color:#e83e8c;font-family:Courier New,monospace;font-size:13px;font-weight:600;padding:2px 6px}.example-template{background-color:#fff;border:1px solid #dee2e6;border-radius:4px;padding:15px}.example-template strong{color:#0c5460;display:block;font-size:14px;margin-bottom:10px}.example-template pre{word-wrap:break-word;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:3px;color:#495057;font-family:Courier New,monospace;font-size:12px;line-height:1.4;margin:0;overflow-x:auto;padding:10px;white-space:pre-wrap}}.checkbox-group,.checkbox-group label{align-items:center;display:flex}.checkbox-group label{cursor:pointer;margin-bottom:0}.checkbox-group input[type=checkbox]{margin-right:8px;width:auto}.form-actions{display:flex;gap:10px;margin-top:25px}.test-result{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:8px;margin-bottom:30px;padding:20px;position:relative}.test-result h3{color:#155724;font-size:18px;margin:0 0 15px}.test-content{background-color:#fff;border:1px solid #c3e6cb;border-radius:4px;max-height:300px;overflow-y:auto;padding:15px}.test-content pre{word-wrap:break-word;font-family:Courier New,monospace;font-size:12px;line-height:1.4;margin:0;white-space:pre-wrap}.prompts-list h3{color:#333;font-size:22px;margin:0 0 20px}.no-prompts{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;color:#666;font-size:16px;padding:40px;text-align:center}.prompts-table{background-color:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:hidden;width:100%}.prompts-table table{border-collapse:collapse;width:100%}.prompts-table thead tr{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.prompts-table th{color:#495057;font-size:14px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.prompts-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .15s ease}.prompts-table tbody tr:hover{background-color:#f8f9fa}.prompts-table tbody tr.inactive{background-color:#fafafa;opacity:.7}.prompts-table td{padding:14px 16px;vertical-align:top}.prompt-name{color:#333;font-family:Courier New,monospace;font-size:15px;font-weight:600;margin-bottom:4px}.prompt-description{color:#666;font-size:13px;line-height:1.4;margin:0}.prompt-preview-cell{max-width:400px}.prompt-text-preview{word-wrap:break-word;background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;color:#495057;font-family:Courier New,monospace;font-size:12px;line-height:1.3;max-height:60px;overflow:hidden;padding:8px;position:relative;white-space:pre-wrap}.prompt-text-preview.expanded{max-height:none}.prompt-text-preview .fade-overlay{background:linear-gradient(180deg,#0000,#f8f9fa);bottom:0;height:20px;left:0;pointer-events:none;position:absolute;right:0}.prompt-text-preview.expanded .fade-overlay{display:none}.expand-toggle{color:#007bff;cursor:pointer;display:inline-block;font-size:12px;margin-top:4px}.expand-toggle:hover{text-decoration:underline}.prompt-meta-cell{color:#6c757d;font-size:12px;line-height:1.5}.prompt-actions-cell{white-space:nowrap}.prompt-actions-cell .btn{margin-right:6px}.prompt-actions-cell .btn:last-child{margin-right:0}.variable-info-btn{background-color:#17a2b8;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-top:8px;padding:4px 8px}.variable-info-btn:hover{background-color:#138496}.predefined-variables-modal{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.predefined-variables-content{background-color:#fff;border-radius:8px;max-height:90vh;max-width:800px;overflow-y:auto;padding:30px;position:relative}.predefined-variables-content h3{color:#333;font-size:24px;margin:0 0 20px}.predefined-variables-content .close-btn{position:absolute;right:15px;top:15px}.predefined-sayings{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;margin-top:10px;padding:15px}.predefined-sayings ul{color:#495057;font-size:13px;line-height:1.6;margin:0;padding-left:20px}.predefined-sayings li{margin-bottom:4px}@media (max-width:768px){.prompts-table{display:block;overflow-x:auto}.prompts-table table{min-width:700px}}.status{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 8px;text-transform:uppercase}.status.active{background-color:#d4edda;color:#155724}.status.inactive{background-color:#f8d7da;color:#721c24}.status.clickable{cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.status.clickable:hover{box-shadow:0 2px 4px #0003;transform:scale(1.05)}.status.active.clickable:hover{background-color:#c3e6cb;color:#0f5132}.status.inactive.clickable:hover{background-color:#f5c2c7;color:#58151c}@media (max-width:768px){.admin-system-prompts{padding:15px}.header{align-items:stretch;flex-direction:column;gap:15px}.header h2{font-size:24px}.prompts-grid{grid-template-columns:1fr}.prompt-header{align-items:stretch;gap:10px}.form-actions,.prompt-header{flex-direction:column}.prompt-actions{justify-content:center}}@media (max-width:480px){.admin-system-prompts{padding:10px}.prompt-card,.prompt-form{padding:15px}}.admin-tabs{display:flex;gap:10px;margin:20px 0}.admin-tab{background:#f0f0f0;border:1px solid #ddd;border-radius:5px;color:#333;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.admin-tab:hover{background:#e0e0e0;border-color:#999}.admin-tab.active{background:#007bff;border-color:#0056b3;color:#fff}.category-badge{background:#6c757d;border-radius:12px;color:#fff;display:inline-block;font-size:11px;font-weight:500;margin-left:8px;padding:2px 8px;text-transform:uppercase}@media (max-width:768px){.admin-tabs{flex-wrap:wrap}.admin-tab{flex:1 1;min-width:150px}}.admin-facilities{margin:0 auto;max-width:95vw;padding:20px;width:100%}.admin-facilities-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.admin-facilities-header h2{color:#333;font-size:28px;margin:0}.sync-button{background:#007bff;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px;transition:background-color .2s}.sync-button:hover:not(:disabled){background:#0056b3}.sync-button:disabled{background:#6c757d;cursor:not-allowed}.facilities-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.stat-card h3{color:#666;font-size:14px;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.stat-value{color:#333;font-size:24px}.facilities-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-height:60vh;overflow:hidden;overflow-y:auto}.facilities-table{border-collapse:collapse;width:100%}.facilities-table th{background:#f8f9fa;border-bottom:2px solid #e0e0e0;color:#333;font-size:14px;font-weight:600;padding:15px 12px;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:10}.facilities-table td{border-bottom:1px solid #e0e0e0;padding:12px;vertical-align:middle}.facilities-table th:first-child{width:100px}.facilities-table th:nth-child(2){width:400px}.facilities-table th:nth-child(3),.facilities-table th:nth-child(4),.facilities-table th:nth-child(5){width:120px}.facilities-table th:nth-child(6){width:100px}.facilities-table th:nth-child(7){width:140px}.facilities-table tr:hover{background:#f8f9fa}.facility-name{font-weight:500;max-width:400px;min-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-count{color:#007bff;font-weight:600;margin-right:8px}.view-contacts-btn{background:#28a745;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:4px 8px;transition:background-color .2s}.view-contacts-btn:hover{background:#218838}.actions{white-space:nowrap}.cancel-btn,.edit-btn,.save-btn{border:none;border-radius:4px;cursor:pointer;font-size:12px;margin-right:5px;padding:6px 12px;transition:background-color .2s}.edit-btn{background:#007bff;color:#fff}.edit-btn:hover{background:#0056b3}.save-btn{background:#28a745;color:#fff}.save-btn:hover{background:#218838}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover{background:#545b62}.facilities-table input[type=number]{border:1px solid #ccc;border-radius:3px;font-size:14px;padding:4px 6px;width:80px}.contacts-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.contacts-modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:80vh;max-width:800px;overflow:hidden;width:90%}.contacts-modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.contacts-modal-header h3{color:#333;margin:0}.close-btn{border-radius:50%;color:#666;transition:background-color .2s}.close-btn:hover{background:#e0e0e0}.contacts-modal-content{max-height:60vh;overflow-y:auto;padding:20px}.contacts-table{border-collapse:collapse;width:100%}.contacts-table th{background:#f8f9fa;border-bottom:2px solid #e0e0e0;color:#333;font-size:14px;font-weight:600;padding:10px;text-align:left}.contacts-table td{border-bottom:1px solid #e0e0e0;font-size:14px;padding:10px}.contacts-table tr:hover{background:#f8f9fa}.admin-facilities-error,.admin-facilities-loading{font-size:18px;padding:40px;text-align:center}.admin-facilities-error{background:#f8d7da;border:1px solid #f5c6cb;border-radius:5px;color:#dc3545;margin:20px}@media (max-width:768px){.admin-facilities{padding:10px}.admin-facilities-header{flex-direction:column;gap:15px;text-align:center}.facilities-stats{grid-template-columns:repeat(2,1fr)}.facilities-table-container{overflow-x:auto}.facilities-table{min-width:1200px}.contacts-modal{margin:10px;width:95%}}@media (max-width:480px){.facilities-stats{grid-template-columns:1fr}.stat-card{padding:15px}.facilities-table td,.facilities-table th{font-size:12px;padding:8px 6px}.facility-name{max-width:200px}}.profile-management{background:#fff;display:flex;flex-direction:column;height:calc(100vh - 60px);overflow:hidden}.alert{align-items:center;border:none;border-radius:0;display:flex;flex-shrink:0;font-size:13px;margin:0;padding:8px 16px}.alert-error{background:linear-gradient(90deg,#dc3545,#c82333);color:#fff}.alert-success{background:linear-gradient(90deg,#28a745,#218838);color:#fff}.dashboard-section{background:#fff;border-bottom:1px solid #e9ecef;flex-shrink:0;padding:12px 20px}.dashboard-tabs{align-items:center;display:flex;gap:8px}.dashboard-tab{background:#f5f5f5;border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s;white-space:nowrap}.dashboard-tab:hover{background:#e8e8e8;border-color:#ccc;color:#333}.dashboard-tab.active{background:#06c;border-color:#06c;color:#fff;font-weight:600}.filters-section{background:#fff;border-bottom:1px solid #e9ecef;flex-shrink:0;padding:16px 20px}.filters-row{align-items:center;display:flex;gap:12px}.filter-group{display:flex;flex-direction:column;gap:4px}.filter-group label{color:#6c757d;font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.filter-group input,.filter-group select{background:#fff;border:1px solid #dee2e6;border-radius:4px;color:#495057;font-size:13px;min-width:120px;padding:6px 10px}.filter-group input:focus,.filter-group select:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:none}.profile-content{display:flex;flex:1 1;overflow:hidden}.profile-list{background:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;max-width:500px;min-width:400px;overflow:hidden;width:33.333%}.profile-list h2{background:#fff;border-bottom:1px solid #e9ecef;color:#212529;flex-shrink:0;font-size:18px;font-weight:600;margin:0;padding:16px 20px}.profiles-container{flex:1 1;overflow-x:hidden;overflow-y:auto}.profile-item{align-items:center;background:#fff;border-bottom:1px solid #f1f3f4;cursor:pointer;display:flex;padding:12px 20px;position:relative;transition:background-color .2s ease}.profile-item:hover{background-color:#f1f3f4}.profile-item.selected{background-color:#e3f2fd;border-left:3px solid #007bff;padding-left:17px}.profile-item.gender-male{background:linear-gradient(90deg,#bfdbfe80,#fff)}.profile-item.gender-female{background:linear-gradient(90deg,#f9cfe880,#fff)}.profile-item.gender-male:hover{background:linear-gradient(90deg,#bfdbfeb3,#f1f3f4)}.profile-item.gender-female:hover{background:linear-gradient(90deg,#f9cfe8b3,#f1f3f4)}.profile-item.gender-male.selected{background:linear-gradient(90deg,#bfdbfecc,#e3f2fd)}.profile-item.gender-female.selected{background:linear-gradient(90deg,#f9cfe8cc,#e3f2fd)}.profile-avatar{align-items:center;background-color:#007bff;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:40px;justify-content:center;margin-right:12px;position:relative;width:40px}.profile-item.gender-male .profile-avatar{background-color:#4299e1}.profile-item.gender-female .profile-avatar{background-color:#ed64a6}.active-indicator{align-items:center;border-radius:50%;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;position:absolute;right:12px;top:12px;width:20px}.active-indicator.active-yes{background:#28a745;color:#fff}.active-indicator.active-no{background:#dc3545;color:#fff}.profile-info{flex:1 1;min-width:0}.profile-name-line{align-items:baseline;display:flex;gap:8px;margin-bottom:4px}.profile-name{color:#212529;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-age{color:#6c757d;font-size:13px}.booking-code{color:#6c757d;font-family:monospace;font-size:12px}.profile-facility{align-items:center;color:#6c757d;display:flex;font-size:12px;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.time-indicator{font-size:16px;margin-right:4px}.profile-details{background:#fff;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.details-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.details-header h2{color:#212529;font-size:18px;font-weight:600;margin:0}.details-actions{display:flex;gap:8px}.btn{border:1px solid #0000;border-radius:4px;font-size:12px;font-weight:500;gap:4px;padding:5px 10px;transition:all .2s}.btn-primary{background:#007bff;border-color:#007bff}.btn-primary:hover{background:#0056b3;border-color:#0056b3}.btn-success{border-color:#28a745}.btn-success:hover{border-color:#218838}.btn-danger{border-color:#dc3545}.btn-danger:hover{border-color:#c82333}.btn-warning{border-color:#ffc107}.btn-warning:hover{border-color:#e0a800}.btn-secondary{border-color:#6c757d}.btn-secondary:hover{background:#545b62;border-color:#545b62}.btn-sm{font-size:11px;padding:3px 8px}.profile-tabs{background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;flex-shrink:0;gap:0}.tab-button{background:#0000;border:none;border-bottom:2px solid #0000;color:#6c757d;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.tab-button:hover{background:#e9ecef;color:#495057}.tab-button.active{background:#fff;border-bottom-color:#007bff;color:#007bff}.tab-content{flex:1 1;overflow-y:auto;padding:20px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{color:#6c757d;font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.info-item p,.info-item span{color:#212529;font-size:14px}.info-item.full-width{grid-column:1/-1}.photos-section{display:flex;flex-direction:column;height:100%}.photos-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.photos-header h3{color:#212529;font-size:16px;font-weight:600;margin:0}.photo-actions{display:flex;gap:8px}.photos-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.photo-card{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;overflow:hidden;position:relative}.photo-card img{cursor:pointer;height:150px;object-fit:cover;width:100%}.photo-overlay{position:absolute;right:8px;top:8px}.badge{border-radius:4px;font-size:11px;font-weight:600;padding:2px 6px}.badge-success{background:#28a745;color:#fff}.badge-warning{background:#ffc107;color:#212529}.badge-info{background:#17a2b8;color:#fff}.photo-card .photo-actions{background:linear-gradient(0deg,#000000b3,#0000);bottom:0;display:flex;gap:4px;left:0;opacity:0;padding:8px;position:absolute;right:0;transition:opacity .2s}.photo-card:hover .photo-actions{opacity:1}.activity-section{display:flex;flex-direction:column;gap:16px}.dialog-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.dialog{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:90%}.dialog.photo-dialog{max-width:800px}.dialog-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:16px 20px}.dialog-header h3{color:#212529;font-size:18px;font-weight:600;margin:0}.close-btn{align-items:center;background:none;border:none;color:#6c757d;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.close-btn:hover{color:#212529}.dialog-content{flex:1 1;overflow-y:auto;padding:20px}.dialog-footer{border-top:1px solid #e9ecef;display:flex;gap:8px;justify-content:flex-end;padding:16px 20px}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.form-group{display:flex;flex-direction:column;gap:4px}.form-group.full-width{grid-column:1/-1}.form-group label{color:#6c757d;font-size:12px;font-weight:500}.form-group input,.form-group select,.form-group textarea{border:1px solid #dee2e6;border-radius:4px;color:#495057;font-size:14px;padding:8px 12px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#80bdff;box-shadow:0 0 0 .2rem #007bff40;outline:none}.password-reset-content{display:flex;flex-direction:column;gap:16px}.password-input-group{align-items:center;display:flex;gap:8px}.password-input{flex:1 1;font-family:monospace}.password-hint{color:#6c757d;display:block;font-size:12px;margin-top:4px}.pending-photos-container{flex:1 1;overflow-y:auto;padding:0}.pending-photo-item{align-items:center;background:#fff;border-bottom:1px solid #f1f3f4;display:flex;gap:16px;padding:12px 20px;transition:all .2s}.pending-photo-item:hover{background-color:#f1f3f4}.pending-photo-item .photo-preview{flex-shrink:0}.pending-photo-item .photo-preview img{border:2px solid #dee2e6;border-radius:4px;height:80px;object-fit:cover;width:80px}.pending-photo-item .photo-info{flex:1 1;min-width:0}.pending-photo-item .photo-owner{color:#212529;font-size:14px;font-weight:600;margin-bottom:4px}.pending-photo-item .booking-code{color:#6c757d;font-family:monospace;font-size:12px;font-weight:400}.pending-photo-item .photo-type{color:#6c757d;font-size:12px;margin-bottom:2px}.pending-photo-item .photo-date{color:#868e96;font-size:11px}.pending-photo-item .photo-actions{display:flex;flex-shrink:0;gap:8px}.loading{color:#6c757d;font-size:14px;padding:40px;text-align:center}.profiles-container::-webkit-scrollbar,.tab-content::-webkit-scrollbar{width:8px}.profiles-container::-webkit-scrollbar-track,.tab-content::-webkit-scrollbar-track{background:#f1f3f4}.profiles-container::-webkit-scrollbar-thumb,.tab-content::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.profiles-container::-webkit-scrollbar-thumb:hover,.tab-content::-webkit-scrollbar-thumb:hover{background:#a0aec0}@media (max-width:1200px){.info-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.profile-content{flex-direction:column}.profile-list{height:300px;width:100%}.info-grid{grid-template-columns:1fr}.filters-row{flex-wrap:wrap}}.admin-page-content{padding:0}.admin-page-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;box-shadow:0 4px 6px #0000001a;color:#fff;padding:2rem}.admin-page-title{font-size:2rem;font-weight:700;margin:0 0 .5rem}.admin-page-description{font-size:1.1rem;margin:0;opacity:.9}.admin-page-body{background:#f8f9fa;min-height:calc(100vh - 200px);padding:2rem}.stats-bar{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:1.5rem;text-align:center;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-card.active{background:linear-gradient(135deg,#f8fff9,#e8f5e9);border-color:#28a745}.stat-card.inactive{background:linear-gradient(135deg,#fff8f8,#ffebee);border-color:#dc3545}.stat-value{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-card.active .stat-value{color:#28a745}.stat-card.inactive .stat-value{color:#dc3545}.stat-label{color:#6c757d;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.admin-controls{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding:1.5rem}.search-box{flex:1 1;min-width:300px}.admin-search-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E");background-position:.75rem;background-repeat:no-repeat;background-size:20px;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;padding:.75rem 1rem .75rem 2.5rem;transition:all .3s ease;width:100%}.admin-search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-controls{align-items:center;display:flex;gap:1rem}.admin-select{appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:20px;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;font-size:1rem;padding:.75rem 2.5rem .75rem 1rem;transition:all .3s ease}.admin-select:focus,.admin-select:hover{border-color:#667eea}.admin-select:focus{box-shadow:0 0 0 3px #667eea1a;outline:none}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268;transform:translateY(-1px)}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{background:#5a67d8;transform:translateY(-1px)}.btn-success{background:#28a745;color:#fff}.btn-success:hover{background:#218838;transform:translateY(-1px)}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333;transform:translateY(-1px)}.btn-warning{background:#ffc107;color:#212529}.btn-warning:hover{background:#e0a800;transform:translateY(-1px)}.btn-sm{font-size:.875rem;padding:.5rem 1rem}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.admin-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;overflow:hidden}.admin-table{border-collapse:collapse;width:100%}.admin-table thead{background:#f8f9fa;border-bottom:2px solid #e9ecef}.admin-table th{color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase;white-space:nowrap}.admin-table tbody tr{border-bottom:1px solid #e9ecef;transition:all .2s ease}.admin-table tbody tr:hover{background:#f8f9fa}.admin-table td{padding:1rem;vertical-align:middle;white-space:nowrap}.admin-table-compact td{font-size:.875rem;padding:.5rem .75rem}.admin-table-compact th{font-size:.813rem;padding:.75rem}.admin-table-compact .btn-sm,.admin-table-compact .status-badge{font-size:.75rem;padding:.25rem .5rem}.email-cell,.name-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis}.no-name{color:#6c757d;font-style:italic}.last-charged{font-size:.813rem}.admin-table tbody tr.active-row{background:linear-gradient(90deg,#f8fff9,#0000)}.admin-table tbody tr.inactive-row{background:linear-gradient(90deg,#fff8f8,#0000)}.contact-name{color:#6c757d;font-size:.875rem;margin-top:.25rem}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.813rem;font-weight:600;gap:.375rem;padding:.375rem .75rem}.status-badge:before{border-radius:50%;content:"";display:inline-block;height:8px;width:8px}.status-active{background:#d4edda;color:#155724}.status-active:before{background:#28a745;box-shadow:0 0 0 2px #28a74533}.status-inactive{background:#f8d7da;color:#721c24}.status-inactive:before{background:#dc3545;box-shadow:0 0 0 2px #dc354533}.low-credits{color:#dc3545;font-weight:600}.time-ago{color:#6c757d;font-size:.813rem;margin-top:.125rem}.never-charged{color:#6c757d;font-size:.875rem;font-style:italic}.action-buttons{align-items:center;display:flex;gap:.5rem}.admin-error,.admin-loading{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:4rem 2rem;text-align:center}.admin-error p,.admin-loading p{color:#6c757d;font-size:1.1rem;margin-top:1rem}.no-results{color:#6c757d;font-size:1.1rem;padding:4rem 2rem;text-align:center}@media (max-width:768px){.admin-controls{flex-direction:column}.search-box{min-width:100%}.filter-controls{justify-content:space-between;width:100%}.admin-table-container{overflow-x:auto}.admin-table{min-width:1000px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.admin-controls,.admin-table-container,.stat-card{animation:fadeIn .5s ease-out}.btn-secondary:before{content:"↻";font-size:1.2rem}.btn-success:before{content:"✓"}.btn-danger:before{content:"✕"}.btn-warning:before{content:"↺"}.pagination-controls{align-items:center;background:#fff;border-radius:0 0 12px 12px;border-top:1px solid #e9ecef;display:flex;justify-content:space-between;margin-top:-1px;padding:1rem}.pagination-info{color:#6c757d;font-size:.875rem}.pagination-buttons{align-items:center;display:flex;gap:.5rem}.page-indicator{color:#495057;font-weight:500;padding:0 1rem}.items-per-page{align-items:center;display:flex;gap:.5rem}.items-per-page label{color:#6c757d;font-size:.875rem}.items-per-page .admin-select{font-size:.875rem;padding:.5rem 2rem .5rem .5rem}.search-clear{background:none;border:none;color:#6c757d;cursor:pointer;font-size:1rem;line-height:1;padding:.25rem;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:color .2s ease}.search-clear:hover{color:#495057}.search-box{position:relative}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.type-badge{border-radius:.25rem;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.025em;padding:.25rem .5rem;text-transform:uppercase}.type-inside{background-color:#e0e7ff;border:1px solid #c7d2fe;color:#4338ca}.type-outside{background-color:#fef3c7;border:1px solid #fde68a;color:#92400e}.no-actions{color:#6c757d;font-size:.875rem;font-style:italic}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}.app{background-color:#fff;display:flex;flex-direction:column;height:100vh}.app-header{background-color:#007bff;box-shadow:0 2px 4px #0000001a;color:#fff;gap:20px;padding:12px 20px;z-index:100}.app-header,.app-title{align-items:center;display:flex;justify-content:space-between}.app-title{flex:1 1}.app-navigation{display:flex;gap:8px}.nav-button{align-items:center;background-color:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.nav-button:hover{background-color:#fff3;border-color:#ffffff4d}.nav-button.active{background-color:#ffffffe6;border-color:#ffffffe6;color:#007bff}.nav-button.active:hover{background-color:#fff;color:#0056b3}.app-title h1{font-size:20px;font-weight:600;margin:0}.app-status{align-items:center;display:flex;font-size:12px;gap:6px;opacity:.9}.status-indicator{font-size:10px}.status-text{font-weight:500}.app-main{display:flex;flex:1 1;overflow:hidden}.app-sidebar{background-color:#f8f9fa;border-right:1px solid #e9ecef;display:flex;flex-direction:column;max-width:600px;min-width:480px;width:520px}.app-content,.app-content-full{background-color:#fff;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.app-content-full{width:100%}.admin-container{display:flex;flex:1 1;flex-direction:column;height:100%}.admin-navigation{background-color:#f8f9fa;border-bottom:1px solid #dee2e6;display:flex;gap:10px;padding:15px 20px}.admin-nav-button{align-items:center;background-color:#fff;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.admin-nav-button:hover{background-color:#e9ecef;border-color:#adb5bd;color:#212529}.admin-nav-button.active{background-color:#007bff;border-color:#007bff;color:#fff}.admin-nav-button.active:hover{background-color:#0056b3;border-color:#0056b3}.admin-content{background-color:#fff;flex:1 1;overflow:auto}.app-error,.app-loading{align-items:center;background-color:#f8f9fa;display:flex;height:100vh;justify-content:center}.app-error{padding:20px}.error-content{background-color:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:400px;padding:40px;text-align:center}.error-icon{font-size:48px;margin-bottom:16px}.error-content h2{color:#dc3545;font-size:24px;font-weight:600;margin:0 0 12px}.error-content p{color:#6c757d;line-height:1.5;margin:0 0 16px}.error-details{background-color:#f8f9fa;border-radius:4px;margin:16px 0;padding:16px;text-align:left}.error-details p{font-family:Courier New,monospace;font-size:12px;margin:4px 0}.retry-button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:background-color .2s ease}.retry-button:hover{background-color:#0056b3}.retry-button:active{transform:translateY(1px)}.app-notification{animation:slideDown .3s ease-out;background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;box-shadow:0 2px 8px #00000026;left:50%;padding:8px 16px;position:fixed;top:60px;transform:translateX(-50%);z-index:1000}.notification-content{align-items:center;color:#856404;display:flex;font-size:13px;gap:12px}.notification-content button{background-color:#ffc107;border:none;border-radius:4px;color:#212529;cursor:pointer;font-size:12px;padding:4px 12px;transition:background-color .2s ease}.notification-content button:hover{background-color:#e0a800}@media (max-width:768px){.app-main{flex-direction:column}.app-sidebar{max-height:40vh;max-width:none;min-width:0;min-width:auto;width:100%}.app-content{flex:1 1;min-height:60vh}.app-header{align-items:stretch;flex-direction:column;gap:12px;padding:10px 16px}.app-title{justify-content:center}.app-title h1{font-size:18px}.app-status{font-size:11px}.app-navigation,.nav-button{justify-content:center}.nav-button{flex:1 1;font-size:13px;padding:6px 12px}.error-content{margin:0 10px;padding:30px 20px}.error-content h2{font-size:20px}.app-notification{left:10px;right:10px;top:50px;transform:none}}@media (max-width:480px){.app-sidebar{max-height:35vh}.app-content{min-height:65vh}.app-title{align-items:flex-start;flex-direction:column;gap:4px}.error-content{padding:20px 16px}.error-icon{font-size:36px}.error-content h2{font-size:18px}}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.contact-item:focus,button:focus{outline:2px solid #007bff;outline-offset:2px}@media (prefers-contrast:high){.app-header{border-bottom:2px solid #000}.app-sidebar{border-right:2px solid #000}.contact-item.selected{border-right:4px solid #000}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.chat-messages{scroll-behavior:auto}}
/*# sourceMappingURL=main.17acfd6c.css.map*/