*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,system-ui,-apple-system,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-y-0{top:0;bottom:0}.-bottom-16{bottom:-4rem}.-left-20{left:-5rem}.-right-16{right:-4rem}.-right-8{right:-2rem}.-top-20{top:-5rem}.left-0{left:0}.left-3{left:.75rem}.top-0{top:0}.top-1\/2{top:50%}.top-1\/3{top:33.333333%}.z-10{z-index:10}.z-50{z-index:50}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-top:.5rem;margin-bottom:.5rem}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.mt-1{margin-top:.25rem}.mt-10{margin-top:2.5rem}.mt-2{margin-top:.5rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.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-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-20{height:5rem}.h-24{height:6rem}.h-32{height:8rem}.h-36{height:9rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-56{height:14rem}.h-6{height:1.5rem}.h-72{height:18rem}.h-8{height:2rem}.h-px{height:1px}.min-h-\[60vh\]{min-height:60vh}.min-h-screen{min-height:100vh}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-32{width:8rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-8{width:2rem}.w-auto{width:auto}.w-full{width:100%}.w-px{width:1px}.min-w-0{min-width:0px}.min-w-\[150px\]{min-width:150px}.min-w-\[200px\]{min-width:200px}.max-w-2xl{max-width:42rem}.max-w-7xl{max-width:80rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.border-green-500{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity, 1))}.border-orange-500{--tw-border-opacity: 1;border-color:rgb(249 115 22 / var(--tw-border-opacity, 1))}.border-primary-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity, 1))}.border-purple-500{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.border-white\/30{border-color:#ffffff4d}.border-t-primary-600{--tw-border-opacity: 1;border-top-color:rgb(217 119 6 / var(--tw-border-opacity, 1))}.bg-amber-900\/30{background-color:#78350f4d}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-gray-100{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-green-100{--tw-bg-opacity: 1;background-color:rgb(220 252 231 / var(--tw-bg-opacity, 1))}.bg-green-50{--tw-bg-opacity: 1;background-color:rgb(240 253 244 / var(--tw-bg-opacity, 1))}.bg-orange-50{--tw-bg-opacity: 1;background-color:rgb(255 247 237 / var(--tw-bg-opacity, 1))}.bg-primary-100{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity, 1))}.bg-primary-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-purple-50{--tw-bg-opacity: 1;background-color:rgb(250 245 255 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/10{background-color:#ffffff1a}.bg-white\/20{background-color:#fff3}.bg-white\/30{background-color:#ffffff4d}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-yellow-50{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.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))}.from-amber-400{--tw-gradient-from: #fbbf24 var(--tw-gradient-from-position);--tw-gradient-to: rgb(251 191 36 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-amber-50{--tw-gradient-from: #fffbeb var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 251 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-amber-500{--tw-gradient-from: #f59e0b var(--tw-gradient-from-position);--tw-gradient-to: rgb(245 158 11 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-gray-50{--tw-gradient-from: #f9fafb var(--tw-gradient-from-position);--tw-gradient-to: rgb(249 250 251 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-500{--tw-gradient-from: #22c55e var(--tw-gradient-from-position);--tw-gradient-to: rgb(34 197 94 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-primary-500{--tw-gradient-from: #f59e0b var(--tw-gradient-from-position);--tw-gradient-to: rgb(245 158 11 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-primary-600{--tw-gradient-from: #d97706 var(--tw-gradient-from-position);--tw-gradient-to: rgb(217 119 6 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-500{--tw-gradient-from: #a855f7 var(--tw-gradient-from-position);--tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-yellow-500{--tw-gradient-from: #eab308 var(--tw-gradient-from-position);--tw-gradient-to: rgb(234 179 8 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-white{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #fff var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-amber-50{--tw-gradient-to: #fffbeb var(--tw-gradient-to-position)}.to-amber-600{--tw-gradient-to: #d97706 var(--tw-gradient-to-position)}.to-blue-600{--tw-gradient-to: #2563eb var(--tw-gradient-to-position)}.to-gray-100{--tw-gradient-to: #f3f4f6 var(--tw-gradient-to-position)}.to-green-600{--tw-gradient-to: #16a34a var(--tw-gradient-to-position)}.to-purple-600{--tw-gradient-to: #9333ea var(--tw-gradient-to-position)}.to-yellow-600{--tw-gradient-to: #ca8a04 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}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pl-10{padding-left:2.5rem}.pl-3{padding-left:.75rem}.pl-8{padding-left:2rem}.pr-4{padding-right:1rem}.text-center{text-align:center}.text-right{text-align:right}.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-6xl{font-size:3.75rem;line-height:1}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-none{line-height:1}.tracking-wide{letter-spacing:.025em}.text-amber-100{--tw-text-opacity: 1;color:rgb(254 243 199 / var(--tw-text-opacity, 1))}.text-amber-800{--tw-text-opacity: 1;color:rgb(146 64 14 / var(--tw-text-opacity, 1))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-blue-900{--tw-text-opacity: 1;color:rgb(30 58 138 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-orange-600{--tw-text-opacity: 1;color:rgb(234 88 12 / var(--tw-text-opacity, 1))}.text-primary-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-primary-700{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/70{color:#ffffffb3}.text-white\/80{color:#fffc}.text-white\/90{color:#ffffffe6}.text-yellow-300{--tw-text-opacity: 1;color:rgb(253 224 71 / var(--tw-text-opacity, 1))}.text-yellow-600{--tw-text-opacity: 1;color:rgb(202 138 4 / var(--tw-text-opacity, 1))}.text-yellow-700{--tw-text-opacity: 1;color:rgb(161 98 7 / var(--tw-text-opacity, 1))}.opacity-10{opacity:.1}.opacity-15{opacity:.15}.opacity-20{opacity:.2}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.opacity-90{opacity:.9}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-shadow{transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f9fafb}.hover\:border-primary-300:hover{--tw-border-opacity: 1;border-color:rgb(252 211 77 / var(--tw-border-opacity, 1))}.hover\:bg-amber-50:hover{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.hover\:bg-amber-900\/20:hover{background-color:#78350f33}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-50:hover{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.hover\:bg-red-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/15:hover{background-color:#ffffff26}.hover\:bg-yellow-50:hover{--tw-bg-opacity: 1;background-color:rgb(254 252 232 / var(--tw-bg-opacity, 1))}.hover\:text-gray-700:hover{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.hover\:text-primary-700:hover{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.hover\:shadow-lg:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-primary-500:focus{--tw-border-opacity: 1;border-color:rgb(245 158 11 / var(--tw-border-opacity, 1))}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-primary-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(245 158 11 / var(--tw-ring-opacity, 1))}.group:hover .group-hover\:translate-x-2{--tw-translate-x: .5rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-primary-600{--tw-bg-opacity: 1;background-color:rgb(217 119 6 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-yellow-600{--tw-bg-opacity: 1;background-color:rgb(202 138 4 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}@media (min-width: 640px){.sm\:block{display:block}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width: 768px){.md\:flex{display:flex}.md\:text-5xl{font-size:3rem;line-height:1}}@media (min-width: 1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:w-2\/5{width:40%}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:px-8{padding-left:2rem;padding-right:2rem}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-box{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0000001a;width:100%;max-width:400px}.auth-box h1{text-align:center;margin-bottom:30px;color:#333}.auth-box input{width:100%;padding:12px;border:1px solid #ddd;border-radius:5px;font-size:16px;transition:border-color .3s}.auth-box input:focus{outline:none;border-color:#667eea}.auth-box button{width:100%;padding:12px;margin-top:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;font-size:16px;font-weight:500;cursor:pointer;transition:transform .3s}.auth-box button:hover:not(:disabled){transform:translateY(-2px)}.auth-box p{text-align:center;margin-top:20px;color:#666}.auth-box a{color:#667eea;text-decoration:none;font-weight:500}.auth-box a:hover{text-decoration:underline}.secure-register{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.register-container{background:#fff;border-radius:15px;box-shadow:0 20px 60px #00000026;max-width:600px;width:100%;padding:40px}.register-container h1{color:#333;text-align:center;margin-bottom:30px;font-size:28px}.progress-steps{display:flex;justify-content:space-between;margin-bottom:40px;position:relative}.progress-steps:before{content:"";position:absolute;top:20px;left:50px;right:50px;height:2px;background:#e0e0e0;z-index:0}.step{display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}.step span{width:40px;height:40px;border-radius:50%;background:#e0e0e0;color:#999;display:flex;justify-content:center;align-items:center;font-weight:700;margin-bottom:8px;transition:all .3s}.step.active span{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.step label{font-size:12px;color:#666;text-align:center}.register-form{animation:fadeIn .5s}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:15px;transition:all .3s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.password-strength{margin-top:8px;font-size:12px}.strength-bar{width:100%;height:4px;background:#f0f0f0;border-radius:2px;margin:8px 0;overflow:hidden}.strength-fill{height:100%;transition:width .3s,background-color .3s}.password-strength .feedback{display:block;color:#666;margin-top:4px;font-size:11px}.recaptcha-container{display:flex;justify-content:center;margin:25px 0}.recaptcha-test-box{display:inline-block!important}.recaptcha-test-label{color:#333!important;display:flex!important;align-items:center!important;margin:0!important}.recaptcha-test-label span{color:#333!important;font-weight:400!important}.error{color:#f44;font-size:12px;display:block;margin-top:4px}.error-message{background:#ffebeb;color:#c00;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:20px}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.login-link{text-align:center;margin-top:20px;color:#666;font-size:14px}.login-link a{color:#667eea;text-decoration:none;font-weight:500}.login-link a:hover{text-decoration:underline}.email-verify-section{text-align:center;animation:fadeIn .5s}.verify-icon{font-size:64px;margin-bottom:20px}.email-verify-section h2{color:#333;margin-bottom:15px}.email-verify-section p{color:#666;margin:10px 0;font-size:15px}.email-verify-section strong{color:#333;font-size:16px;display:block;margin:10px 0;background:#f5f5f5;padding:10px;border-radius:8px}.instructions{background:#f0f7ff;padding:15px;border-radius:8px;margin:20px 0;border-left:4px solid #667eea}.verify-actions{display:flex;gap:15px;justify-content:center;margin:30px 0}.continue-btn,.resend-btn{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.continue-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.resend-btn{background:#fff;color:#667eea;border:2px solid #667eea}.continue-btn:hover,.resend-btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}.help-text{font-size:13px;color:#999;margin-top:20px}.id-upload-form{animation:fadeIn .5s}.id-upload-form h2{color:#333;margin-bottom:10px}.id-upload-form>p{color:#666;margin-bottom:25px;font-size:14px}.upload-section{background:#f9f9f9;padding:20px;border-radius:10px;margin-bottom:20px}.upload-group{margin-bottom:20px}.upload-group:last-child{margin-bottom:0}.upload-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.file-upload{position:relative}.file-upload input[type=file]{width:100%;padding:10px;border:2px dashed #ddd;border-radius:8px;background:#fff;cursor:pointer;font-size:14px}.file-upload input[type=file]:hover{border-color:#667eea;background:#f0f7ff}.file-name{display:block;margin-top:8px;color:#4caf50;font-size:13px;font-weight:500}.upload-group small{display:block;margin-top:5px;color:#999;font-size:12px}.id-requirements{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;padding:15px;margin:20px 0}.id-requirements h4{color:#856404;margin:0 0 10px;font-size:14px}.id-requirements ul{margin:0;padding-left:20px;color:#856404;font-size:13px}.id-requirements li{margin:5px 0}.privacy-note{background:#e8f5e9;color:#2e7d32;padding:12px;border-radius:8px;font-size:13px;text-align:center;margin-top:20px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){.register-container{padding:20px}.progress-steps{margin-bottom:30px}.step label{font-size:10px}.verify-actions{flex-direction:column}.continue-btn,.resend-btn{width:100%}}.verify-email-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.verify-card{background:#fff;border-radius:15px;box-shadow:0 20px 60px #00000026;padding:50px;text-align:center;max-width:450px;width:100%;animation:slideIn .5s ease-out}.spinner{width:60px;height:60px;border:5px solid #f3f3f3;border-top:5px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 30px}.success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;font-size:48px;line-height:80px;margin:0 auto 20px;animation:scaleIn .5s ease-out}.error-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#f44,#c00);color:#fff;font-size:48px;line-height:80px;margin:0 auto 20px;animation:scaleIn .5s ease-out}.verify-card h2{color:#333;margin-bottom:15px;font-size:28px;font-weight:600}.verify-card p{color:#666;font-size:16px;line-height:1.6;margin-bottom:15px}.redirect-message{color:#667eea;font-style:italic;margin-top:20px;font-size:14px}.action-buttons{display:flex;gap:15px;justify-content:center;margin-top:30px}.btn-primary,.btn-secondary{padding:12px 30px;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .3s;border:none}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea}.btn-primary:hover,.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea4d}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}@media (max-width: 480px){.verify-card{padding:30px 20px}.action-buttons{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.payment-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.payment-modal{background:#fff;padding:30px;border-radius:10px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.payment-modal h2{color:#333;margin-bottom:20px}.payment-details{background:#f9f9f9;padding:15px;border-radius:8px;margin-bottom:20px}.payment-details p{margin:8px 0;color:#666}.payment-details strong{color:#333}.gcash-section{margin-bottom:20px}.gcash-section h3{color:#333;margin-bottom:15px}.qr-placeholder{width:250px;height:250px;border:2px dashed #ddd;display:flex;flex-direction:column;justify-content:center;align-items:center;margin:0 auto 20px;background:#f9f9f9}.qr-placeholder p{color:#666;margin:5px 0}.qr-note{font-size:12px;color:#999}.gcash-btn{display:block;width:100%;padding:15px;background:#007dff;color:#fff;text-align:center;text-decoration:none;border-radius:5px;font-weight:500;transition:background .3s}.gcash-btn:hover{background:#0056b3}.test-payment{background:#fff3e0;padding:15px;border-radius:8px;margin-top:20px}.test-payment h4{color:#f57c00;margin-bottom:10px;font-size:14px}.simulate-success,.simulate-failure{width:48%;padding:10px;margin:5px 1%;border:none;border-radius:5px;cursor:pointer;font-weight:500}.simulate-success{background:#4caf50;color:#fff}.simulate-failure{background:#f44336;color:#fff}.status-check{text-align:center;color:#666;margin-top:20px;font-size:14px}.payment-success,.payment-failed,.payment-expired{text-align:center;padding:40px 20px}.payment-success h3{color:#4caf50;margin-bottom:10px}.payment-failed h3{color:#f44336;margin-bottom:10px}.payment-expired h3{color:#f57c00;margin-bottom:10px}.close-btn{width:100%;padding:12px;margin-top:20px;background:#666;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background .3s}.close-btn:hover{background:#555}.payment-instructions{background:#f9f9f9;padding:20px;border-radius:8px;margin:20px 0}.payment-instructions h3{color:#333;margin-bottom:15px}.payment-instructions ol{text-align:left;padding-left:20px;color:#666}.payment-instructions li{margin:10px 0}.gcash-number{background:#e8f5e9;padding:10px;border-radius:5px;font-size:18px}.upload-receipt-btn{width:100%;padding:15px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;font-size:16px;font-weight:500;cursor:pointer;transition:transform .3s;margin-top:20px}.upload-receipt-btn:hover{transform:translateY(-2px)}.receipt-upload-form{padding:20px}.receipt-upload-form .form-group{margin-bottom:20px;text-align:left}.receipt-upload-form label{display:block;margin-bottom:8px;color:#333;font-weight:500}.receipt-upload-form input[type=text],.receipt-upload-form input[type=file]{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px}.receipt-upload-form input[type=file]{padding:8px}.file-name{margin-top:5px;color:#666;font-size:12px}.button-group{display:flex;gap:10px;margin-top:20px}.button-group button{flex:1;padding:12px;border:none;border-radius:5px;font-size:16px;cursor:pointer;transition:background .3s}.button-group button[type=submit]{background:#4caf50;color:#fff}.button-group button[type=submit]:hover:not(:disabled){background:#45a049}.button-group button[type=button]{background:#666;color:#fff}.button-group button[type=button]:hover{background:#555}.payment-review{text-align:center;padding:40px 20px}.payment-review h3{color:#ff9800;margin-bottom:15px}.payment-review p{color:#666;margin:10px 0}.payment-rejected{text-align:center;padding:40px 20px}.payment-rejected h3{color:#f44336;margin-bottom:10px}.confirmation-dialog-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1100}.confirmation-dialog{background:#fff;padding:30px;border-radius:12px;max-width:400px;width:90%;box-shadow:0 10px 40px #0000004d}.confirmation-dialog h3{color:#333;margin-bottom:15px;font-size:20px}.confirmation-dialog p{color:#666;margin-bottom:10px;line-height:1.5}.warning-text{color:#f57c00;font-weight:500;margin-bottom:20px}.dialog-buttons{display:flex;gap:10px;margin-top:25px}.dialog-buttons button{flex:1;padding:12px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn-confirm-cancel{background:#f44336;color:#fff}.btn-confirm-cancel:hover:not(:disabled){background:#d32f2f;transform:translateY(-2px)}.btn-confirm-cancel:disabled{opacity:.6;cursor:not-allowed}.btn-keep-booking{background:#4caf50;color:#fff}.btn-keep-booking:hover:not(:disabled){background:#45a049;transform:translateY(-2px)}.btn-keep-booking:disabled{opacity:.6;cursor:not-allowed}.court-booking{min-height:100vh;background:linear-gradient(180deg,#fefce8,#fef9c3,#fef08a);padding:0;margin:0;position:relative}.court-booking:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='104'%3E%3Cpolygon points='30,2 58,19 58,53 30,70 2,53 2,19' fill='none' stroke='%23eab308' stroke-width='0.5' opacity='0.2'/%3E%3Cpolygon points='30,36 58,53 58,87 30,104 2,87 2,53' fill='none' stroke='%23eab308' stroke-width='0.5' opacity='0.2'/%3E%3C/svg%3E");background-size:60px 70px;pointer-events:none;z-index:0}.booking-header{background:linear-gradient(135deg,#eab308,#ca8a04);padding:2.5rem 1.5rem 3rem;text-align:center;position:relative;overflow:visible}.booking-header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:30px;background:#fefce8;clip-path:ellipse(55% 100% at 50% 100%)}.booking-header h1{font-size:2rem;color:#fff;margin:0 0 .5rem;font-weight:700;position:relative;z-index:2;text-shadow:0 2px 8px rgba(0,0,0,.3)}.booking-header p{font-size:1rem;color:#fffffff2;margin:0;position:relative;z-index:2;text-shadow:0 1px 4px rgba(0,0,0,.2)}.floating-hexagons{position:absolute;inset:0;pointer-events:none;z-index:0}.floating-hexagons .hex{position:absolute;background:#ffffff26;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);animation:float-hex 6s ease-in-out infinite}.floating-hexagons .hex:nth-child(1){width:80px;height:92px;top:-20px;left:5%;animation-delay:0s}.floating-hexagons .hex:nth-child(2){width:50px;height:58px;top:50%;left:15%;animation-delay:1s;background:#ffffff1a}.floating-hexagons .hex:nth-child(3){width:70px;height:81px;top:-10px;right:10%;animation-delay:2s}.floating-hexagons .hex:nth-child(4){width:40px;height:46px;bottom:-10px;right:25%;animation-delay:.5s;background:#fff3}.floating-hexagons .hex:nth-child(5){width:60px;height:69px;bottom:-15px;left:30%;animation-delay:1.5s}@keyframes float-hex{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(5deg)}}.booking-container{max-width:1200px;margin:0 auto;padding:2rem;position:relative;z-index:1}.date-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;position:relative;overflow:hidden}.date-section:after{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#eab308,#facc15);border-radius:4px 0 0 4px}.date-section h2{font-size:1.8rem;color:#333;margin:0 0 1.5rem;font-weight:600}.date-picker{width:100%;padding:1rem;font-size:1.1rem;border:2px solid #e0e0e0;border-radius:8px;transition:all .3s}.date-picker:focus{outline:none;border-color:#eab308;box-shadow:0 0 0 3px #eab30826}.courts-section{background:#fff;padding:.75rem 1rem;border-radius:8px;box-shadow:0 2px 8px #0000000f;margin-bottom:1rem;position:sticky;top:10px;z-index:50}.courts-section h2{font-size:.95rem;color:#333;margin:0 0 .5rem;font-weight:600}.courts-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;padding:.5rem}@media (max-width: 768px){.courts-section{padding:.5rem .75rem;position:sticky;top:0}.courts-section h2{font-size:.85rem;margin:0 0 .4rem}.courts-grid{display:flex;overflow-x:auto;gap:.5rem;padding:.25rem 0;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;flex-wrap:nowrap}.courts-grid::-webkit-scrollbar{height:3px}.courts-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.courts-grid::-webkit-scrollbar-thumb{background:#eab308;border-radius:10px}}.court-card{background:#fff;padding:1.25rem 1rem;cursor:pointer;transition:all .3s ease;position:relative;border:2px solid #fef08a;border-radius:12px;text-align:center;min-width:130px}@media (max-width: 768px){.court-card{min-width:90px;flex-shrink:0;padding:.6rem .5rem;scroll-snap-align:start}.court-card h3{font-size:.85rem;margin-bottom:.15rem}.court-card .court-description{font-size:.6rem;margin-bottom:.2rem}.court-card .court-price{font-size:.8rem}}.court-card:hover{border-color:#eab308;background:#fefce8;transform:translateY(-2px);box-shadow:0 4px 12px #eab30840}.court-card.selected{border-color:#ca8a04;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #ca8a0459}.court-card h3{font-size:1rem;margin:0 0 .2rem;font-weight:600;color:#a16207}.court-card.selected h3{color:#fff}.court-description{font-size:.7rem;color:#ca8a04;margin:0 0 .3rem;line-height:1.2}.court-card.selected .court-description{color:#ffffffd9}.court-price{font-size:1rem;font-weight:700;color:#eab308;margin:0}.court-card.selected .court-price{color:#fff}.selected-badge{position:absolute;top:.4rem;right:.4rem;background:#10b981;color:#fff;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700}.time-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;position:relative;overflow:hidden}.time-section:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#facc15,#eab308);border-radius:4px 0 0 4px}.time-section h2{font-size:1.8rem;color:#333;margin:0 0 1.5rem;font-weight:600}@media (max-width: 768px){.time-section{padding:1rem;margin-bottom:1rem}.time-section h2{font-size:1rem;margin:0 0 .75rem}}.no-slots-message{background:linear-gradient(135deg,#fef9c3,#fef08a);padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;text-align:center;border:2px solid #facc15}.no-slots-message p{margin:.5rem 0;font-size:1.1rem;font-weight:600;color:#a16207}.try-other-courts{font-size:1rem!important;color:#ca8a04!important;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}@media (max-width: 768px){.time-slots-grid{grid-template-columns:repeat(4,1fr);gap:.4rem}}.time-slot-card{padding:1.5rem 1rem;border:2px solid #fef08a;border-radius:12px;background:#fefce8;cursor:pointer;transition:all .3s;position:relative;text-align:center;font-weight:600}@media (max-width: 768px){.time-slot-card{padding:.5rem .25rem;border-radius:8px;border-width:1.5px}}.time-slot-card:hover:not(:disabled){border-color:#eab308;background:#fef9c3;transform:translateY(-3px);box-shadow:0 6px 12px #eab30840}.time-slot-card.selected{border-color:#ca8a04;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff}.time-slot-card:disabled{cursor:not-allowed;opacity:.6}.time-slot-card.booked{background:#f5f5f5;border-color:#ddd}.time-slot-card.maintenance{background:#fff3e0;border-color:#ffb74d}.time-slot-card.open_play{background:#e8f5e9;border-color:#81c784}.time-display{font-size:1.3rem;margin-bottom:.5rem}@media (max-width: 768px){.time-display{font-size:.75rem;margin-bottom:0;font-weight:600}}.slot-status-badge{font-size:.75rem;margin-top:.5rem;padding:.25rem .5rem;background:#0000001a;border-radius:4px}@media (max-width: 768px){.slot-status-badge{font-size:.5rem;margin-top:.2rem;padding:.15rem .25rem}}.slot-selected-badge{position:absolute;top:.5rem;right:.5rem;background:#10b981;color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700}@media (max-width: 768px){.slot-selected-badge{top:.2rem;right:.2rem;width:16px;height:16px;font-size:.6rem}}.duration-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem}.duration-section h2{font-size:1.8rem;color:#333;margin:0 0 1.5rem;font-weight:600}.duration-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.duration-card{padding:2rem 1rem;border:2px solid #fef08a;border-radius:12px;background:#fefce8;cursor:pointer;transition:all .3s;position:relative;text-align:center}.duration-card:hover{border-color:#eab308;background:#fef9c3;transform:translateY(-3px);box-shadow:0 6px 12px #eab30840}.duration-card.selected{border-color:#ca8a04;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff}.duration-hours{font-size:3rem;font-weight:700;color:#eab308;margin-bottom:.5rem}.duration-card.selected .duration-hours{color:#fff}.duration-label{font-size:1rem;color:#a16207}.duration-card.selected .duration-label{color:#ffffffe6}.duration-check{position:absolute;top:1rem;right:1rem;background:#10b981;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700}.guest-info-section{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;position:relative;overflow:hidden}.guest-info-section:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#ca8a04,#eab308);border-radius:4px 0 0 4px}.guest-info-section h2{font-size:1.8rem;color:#333;margin:0 0 1.5rem;font-weight:600;position:relative;z-index:1}@media (max-width: 768px){.guest-info-section{padding:1rem;margin-bottom:1rem}.guest-info-section h2{font-size:1rem;margin:0 0 .75rem}}.info-grid{display:grid;gap:1.5rem;position:relative;z-index:1}@media (max-width: 768px){.info-grid{gap:.75rem}}.info-field{display:flex;flex-direction:column;gap:.5rem}@media (max-width: 768px){.info-field{gap:.25rem}}.info-field label{font-size:1rem;font-weight:600;color:#333}@media (max-width: 768px){.info-field label{font-size:.85rem}}.modern-input{padding:1rem;font-size:1rem;border:2px solid #fef08a;border-radius:8px;transition:all .3s;background:#fefce8}@media (max-width: 768px){.modern-input{padding:.65rem .75rem;font-size:.9rem}}.modern-input:focus{outline:none;border-color:#eab308;box-shadow:0 0 0 3px #eab30826;background:#fff}.summary-section{margin-bottom:2rem}@media (max-width: 768px){.summary-section{margin-bottom:.5rem}}.section-title{font-size:1.8rem;color:#333;margin:0 0 1.5rem;font-weight:600;text-align:left}@media (max-width: 768px){.section-title{font-size:1.1rem;margin:0 0 .75rem}}.summary-card{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 10px 30px #0000001a;position:relative;overflow:hidden}@media (max-width: 768px){.summary-card{padding:.75rem;border-radius:10px;display:flex;flex-direction:column}}.summary-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#eab308,#ca8a04);border-radius:4px 0 0 4px}.summary-details{display:grid;gap:1rem;margin-bottom:2rem;position:relative;z-index:1}@media (max-width: 768px){.summary-details{display:flex;flex-direction:column;gap:0;margin-bottom:.5rem;background:#fefce8;border-radius:6px;padding:.4rem}}.summary-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fefce8;border-radius:12px;transition:all .3s}@media (max-width: 768px){.summary-item{flex-direction:row;gap:.4rem;padding:.3rem .4rem;border-radius:0;background:transparent;border-bottom:1px solid #fef08a}.summary-item:last-child{border-bottom:none}.summary-item:hover{transform:none;background:transparent}}.summary-item:hover{background:#fef9c3;transform:translate(5px)}.summary-icon{font-size:1.5rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#fef9c3,#fef08a);border-radius:12px;box-shadow:0 2px 8px #eab30833}@media (max-width: 768px){.summary-icon{font-size:1rem;width:auto;height:auto;background:none;box-shadow:none;border-radius:0;min-width:24px}}.summary-content{flex:1}@media (max-width: 768px){.summary-content{display:flex;align-items:center;gap:.5rem}}.summary-label{font-size:.85rem;color:#a16207;margin-bottom:.25rem;text-transform:uppercase;font-weight:500;letter-spacing:.5px}@media (max-width: 768px){.summary-label{font-size:.7rem;margin-bottom:0;min-width:50px}}.summary-value{font-size:1.1rem;color:#333;font-weight:600}@media (max-width: 768px){.summary-value{font-size:.8rem}}.summary-total{padding:1.5rem;background:linear-gradient(135deg,#eab308,#ca8a04);border-radius:12px;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}@media (max-width: 768px){.summary-total{padding:.75rem 1rem;border-radius:8px;width:100%}}.total-label{font-size:1rem;color:#ffffffe6;font-weight:500;text-transform:uppercase;letter-spacing:1px}@media (max-width: 768px){.total-label{font-size:.8rem}}.total-amount{font-size:2rem;color:#fff;font-weight:700}@media (max-width: 768px){.total-amount{font-size:1.4rem}}.book-now-btn{width:100%;margin-top:2rem;padding:1.25rem 2rem;font-size:1.2rem;font-weight:700;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px #eab30866;position:relative;z-index:1}@media (max-width: 768px){.book-now-btn{margin-top:1rem;padding:.9rem 1.5rem;font-size:1rem;border-radius:8px}}.book-now-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #eab30880;background:linear-gradient(135deg,#ca8a04,#a16207)}.book-now-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width: 768px){.booking-header{padding:1rem}.booking-header h1{font-size:1.3rem}.booking-header p{font-size:.8rem}.date-section{padding:1rem}.date-section h2{font-size:1.2rem;margin:0 0 1rem}.date-picker{font-size:1rem}.duration-grid{grid-template-columns:repeat(2,1fr)}}.grid-section{background:#fff;padding:1.5rem;border-radius:16px;box-shadow:0 10px 30px #0000001a;margin-bottom:2rem;position:relative;overflow:hidden}.grid-section:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,#eab308,#ca8a04);border-radius:4px 0 0 4px}.grid-section h2{font-size:1.5rem;color:#333;margin:0 0 .5rem;font-weight:600}.grid-hint{color:#666;font-size:.9rem;margin:0 0 1.5rem}.loading-grid{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.booking-grid-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -.5rem;padding:0 .5rem}.booking-grid{min-width:100%;border-radius:12px;overflow:hidden;border:2px solid #fef08a}.grid-header{display:flex;background:linear-gradient(135deg,#eab308,#ca8a04);position:sticky;top:0;z-index:10}.grid-corner{min-width:80px;padding:.75rem .5rem;font-weight:600;color:#fff;display:flex;align-items:center;justify-content:center;border-right:1px solid rgba(255,255,255,.3)}.grid-court-header{flex:1;min-width:90px;padding:.75rem .5rem;text-align:center;color:#fff;border-right:1px solid rgba(255,255,255,.3)}.grid-court-header:last-child{border-right:none}.court-name{font-weight:700;font-size:.95rem;margin-bottom:.2rem}.court-rate{font-size:.75rem;opacity:.9}.grid-body{max-height:400px;overflow-y:auto}.grid-row{display:flex;border-bottom:1px solid #fef08a}.grid-row:last-child{border-bottom:none}.grid-time-cell{min-width:80px;padding:.6rem .5rem;font-weight:600;font-size:.8rem;color:#a16207;background:#fefce8;display:flex;align-items:center;justify-content:center;border-right:1px solid #fef08a}.grid-cell{flex:1;min-width:90px;min-height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;border-right:1px solid #fef08a;position:relative}.grid-cell:last-child{border-right:none}.grid-cell.available{background:#fefce8}.grid-cell.available:hover{background:#fef9c3;transform:scale(1.02)}.grid-cell.selected{background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff}.grid-cell.selected:hover{background:linear-gradient(135deg,#ca8a04,#a16207)}.grid-cell.booked{background:#f5f5f5;cursor:not-allowed}.grid-cell.maintenance{background:#fff3e0;cursor:not-allowed}.grid-cell.open_play{background:#e8f5e9;cursor:not-allowed}.grid-cell.loading{background:#f0f0f0;cursor:wait}.cell-check{font-size:1.2rem;font-weight:700}.cell-icon{font-size:.9rem}.grid-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #fef08a}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#666}.legend-box{width:20px;height:20px;border-radius:4px;border:1px solid #ddd}.legend-box.available{background:#fefce8;border-color:#fef08a}.legend-box.selected{background:linear-gradient(135deg,#eab308,#ca8a04);border-color:#ca8a04}.legend-box.booked{background:#f5f5f5;border-color:#ddd}.legend-box.open_play{background:#e8f5e9;border-color:#81c784}.validation-warning{background:#fff3e0;border:2px solid #ffb74d;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;color:#e65100;font-weight:500;font-size:.9rem}.court-subtotal{font-size:.85rem;color:#eab308;font-weight:600;margin-top:.25rem}@media (max-width: 768px){.grid-section{padding:1rem;margin-bottom:1rem}.grid-section h2{font-size:1.1rem;margin:0 0 .3rem}.grid-hint{font-size:.8rem;margin:0 0 1rem}.grid-corner{min-width:60px;padding:.5rem .25rem;font-size:.7rem}.grid-court-header{min-width:70px;padding:.5rem .25rem}.court-name{font-size:.8rem}.court-rate{font-size:.65rem}.grid-body{max-height:350px}.grid-time-cell{min-width:60px;padding:.4rem .25rem;font-size:.7rem}.grid-cell{min-width:70px;min-height:40px}.cell-check{font-size:1rem}.cell-icon{font-size:.75rem}.grid-legend{gap:.75rem;margin-top:.75rem;padding-top:.75rem}.legend-item{font-size:.75rem;gap:.3rem}.legend-box{width:16px;height:16px}.validation-warning{font-size:.8rem;padding:.5rem .75rem}}.open-play{padding:40px;width:100%;margin:0}.open-play h1{color:#333;margin-bottom:15px}.open-play .description{color:#666;margin-bottom:30px;font-size:16px}.date-selector{background:#fff;padding:20px;border-radius:10px;box-shadow:0 5px 15px #0000001a;margin-bottom:30px}.date-selector label{display:block;margin-bottom:10px;font-weight:500;color:#333}.date-selector input{width:200px;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:16px}.sessions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:30px;margin-top:30px}.session-card{background:#fff;padding:30px;border-radius:15px;box-shadow:0 5px 20px #00000014;border:1px solid #f0f0f0;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.session-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-2px)}.session-card h2{color:#333;margin-bottom:15px;font-size:24px;font-weight:600}.session-time{font-size:20px;color:#667eea;font-weight:500;margin-bottom:20px;display:flex;align-items:center;gap:8px}.session-time:before{content:"🕐";font-size:20px}.session-capacity{margin-bottom:20px;width:100%}.capacity-bar{width:100%;height:35px;background:linear-gradient(90deg,#f0f0f0,#e8e8e8);border-radius:20px;overflow:hidden;margin-bottom:10px;position:relative;box-shadow:inset 0 2px 4px #0000000f}.capacity-fill{height:100%;transition:width .3s ease;border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.session-capacity span{color:#333;font-size:16px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:5px}.session-capacity span:before{content:"👥"}.session-price{font-size:24px;color:#333;margin-bottom:25px;font-weight:600;padding:15px;background:linear-gradient(135deg,#f0f4ff,#e8efff);border-radius:10px;width:100%}.session-price:before{content:"💵";margin-right:8px}.join-btn{width:100%;padding:15px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.join-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.session-full{width:100%;padding:15px;background:#f44336;color:#fff;border:none;border-radius:5px;font-size:16px;font-weight:500;cursor:not-allowed;opacity:.8}.my-bookings{padding:40px;width:100%;margin:0}.my-bookings h1{color:#333;margin-bottom:30px}.tabs{display:flex;gap:10px;margin-bottom:30px}.tabs button{padding:12px 24px;background:#fff;color:#666;border:2px solid #ddd;border-radius:5px;cursor:pointer;transition:all .3s}.tabs button.active{background:#667eea;color:#fff;border-color:#667eea}.tabs button:hover:not(.active){border-color:#667eea}.bookings-list,.sessions-list{display:grid;gap:20px}.booking-card,.session-card{background:#fff;padding:20px;border-radius:10px;box-shadow:0 5px 15px #0000001a;display:flex;justify-content:space-between;align-items:center}.booking-info,.session-info{flex:1}.booking-info h3,.session-info h3{color:#333;margin-bottom:10px}.booking-info p,.session-info p{color:#666;margin:5px 0}.status{display:inline-block;padding:5px 15px;border-radius:20px;font-size:12px;font-weight:500;margin-top:10px}.status.pending{background:#fff3e0;color:#f57c00}.status.confirmed{background:#e8f5e9;color:#4caf50}.status.cancelled{background:#ffebee;color:#f44336}.status.expired{background:#f5f5f5;color:#666}.cancel-btn{padding:10px 20px;background:#f44336;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background .3s}.cancel-btn:hover{background:#d32f2f}.admin-dashboard{padding:40px;width:100%;margin:0}.admin-dashboard h1{color:#333;margin-bottom:30px;border-bottom:2px solid #667eea;padding-bottom:10px}.pending-count{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;border-radius:10px;margin-bottom:30px}.pending-count h2{margin:0}.no-pending{background:#fff;padding:40px;text-align:center;border-radius:10px;box-shadow:0 5px 15px #0000001a;color:#666}.payments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:30px}.payment-card{background:#fff;border-radius:10px;box-shadow:0 5px 15px #0000001a;padding:20px;transition:transform .3s}.payment-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #00000026}.payment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #eee}.payment-header h3{color:#333;font-size:16px;margin:0}.amount{font-size:20px;color:#4caf50;font-weight:700}.payment-details{margin-bottom:20px}.payment-details p{margin:8px 0;color:#666;font-size:14px}.payment-details strong{color:#333;margin-right:5px}.receipt-section{margin-bottom:20px}.view-receipt-btn{width:100%;padding:10px;background:#2196f3;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background .3s}.view-receipt-btn:hover{background:#1976d2}.verification-actions{border-top:1px solid #eee;padding-top:15px}.verification-actions textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:5px;font-size:14px;margin-bottom:10px;resize:vertical}.action-buttons{display:flex;gap:10px}.action-buttons button{flex:1;padding:10px;border:none;border-radius:5px;font-weight:500;cursor:pointer;transition:all .3s}.approve-btn{background:#4caf50;color:#fff}.approve-btn:hover:not(:disabled){background:#45a049}.reject-btn{background:#f44336;color:#fff}.reject-btn:hover:not(:disabled){background:#d32f2f}.action-buttons button:disabled{opacity:.5;cursor:not-allowed}.receipt-modal{position:fixed;inset:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.receipt-content{background:#fff;padding:20px;border-radius:10px;max-width:90%;max-height:90vh;overflow:auto}.receipt-content h2{color:#333;margin-bottom:20px}.receipt-content button{margin-top:20px;padding:10px 20px;background:#666;color:#fff;border:none;border-radius:5px;cursor:pointer}.receipt-content button:hover{background:#555}.admin-tabs{display:flex;gap:10px;margin-bottom:25px}.tab-btn{padding:12px 24px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;font-weight:600;font-size:14px;transition:all .2s;display:flex;align-items:center;gap:10px}.tab-btn:hover{border-color:#eab308}.tab-btn.active{background:linear-gradient(135deg,#eab308,#ca8a04);border-color:#eab308;color:#fff}.tab-btn .badge{background:#dc2626;color:#fff;padding:2px 8px;border-radius:12px;font-size:12px}.tab-btn.active .badge{background:#fff;color:#dc2626}.reschedule-card{border-left:4px solid #f59e0b}.reschedule-comparison{display:flex;align-items:center;gap:15px;margin:20px 0;padding:15px;background:#f9fafb;border-radius:8px}.original-booking,.new-booking{flex:1;padding:15px;border-radius:8px}.original-booking{background:#fef2f2;border:1px solid #fecaca}.new-booking{background:#ecfdf5;border:1px solid #a7f3d0}.original-booking h4{color:#dc2626;margin:0 0 10px;font-size:14px}.new-booking h4{color:#059669;margin:0 0 10px;font-size:14px}.reschedule-comparison .arrow{font-size:24px;color:#9ca3af;font-weight:700}.original-booking p,.new-booking p{margin:5px 0;font-size:13px}@media (max-width: 768px){.admin-tabs,.reschedule-comparison{flex-direction:column}.reschedule-comparison .arrow{transform:rotate(90deg)}}.admin-id-verification{min-height:100vh;background:#f5f7fa;padding:20px}.admin-header{background:#fff;border-radius:10px;padding:20px;margin-bottom:30px;box-shadow:0 2px 10px #0000000d}.admin-header h1{color:#333;margin:0 0 20px;font-size:28px}.filter-tabs{display:flex;gap:10px;border-bottom:2px solid #e0e0e0}.filter-tabs button{padding:10px 20px;background:none;border:none;color:#666;font-size:15px;font-weight:500;cursor:pointer;position:relative;transition:all .3s}.filter-tabs button:hover,.filter-tabs button.active{color:#667eea}.filter-tabs button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:#667eea}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.no-users{grid-column:1 / -1;text-align:center;padding:60px;background:#fff;border-radius:10px;color:#999;font-size:16px}.user-card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 10px #0000000d;transition:all .3s}.user-card:hover{box-shadow:0 5px 20px #0000001a}.user-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:15px;border-bottom:1px solid #f0f0f0}.user-header h3{margin:0;color:#333;font-size:18px}.badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.badge-warning{background:#fff3cd;color:#856404}.badge-success{background:#d4edda;color:#155724}.badge-danger{background:#f8d7da;color:#721c24}.badge-secondary{background:#e9ecef;color:#6c757d}.user-info{margin-bottom:20px}.user-info p{margin:8px 0;color:#666;font-size:14px}.user-info strong{color:#444;margin-right:8px}.id-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:15px;margin:20px 0}.image-group{text-align:center}.image-group label{display:block;font-size:12px;color:#666;margin-bottom:5px;font-weight:500}.image-group img{width:100%;max-width:150px;height:100px;-o-object-fit:cover;object-fit:cover;border-radius:8px;border:2px solid #e0e0e0;cursor:pointer;transition:all .3s}.image-group img:hover{border-color:#667eea;transform:scale(1.05)}.face-match{margin:20px 0}.face-match label{display:block;font-size:13px;color:#666;margin-bottom:8px;font-weight:500}.score-bar{position:relative;width:100%;height:20px;background:#f0f0f0;border-radius:10px;overflow:hidden;margin-bottom:5px}.score-fill{height:100%;transition:width .5s ease}.face-match span{font-size:14px;font-weight:600;color:#333}.action-buttons{display:flex;gap:10px;margin-top:20px}.btn-approve,.btn-reject{flex:1;padding:10px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.btn-approve{background:#4caf50;color:#fff}.btn-approve:hover:not(:disabled){background:#45a049;transform:translateY(-2px);box-shadow:0 5px 15px #4caf504d}.btn-reject{background:#f44;color:#fff}.btn-reject:hover:not(:disabled){background:#c00;transform:translateY(-2px);box-shadow:0 5px 15px #ff44444d}.btn-approve:disabled,.btn-reject:disabled{opacity:.6;cursor:not-allowed}.rejection-info{background:#ffebeb;padding:10px;border-radius:8px;margin-top:15px;font-size:13px;color:#c00}.rejection-info strong{display:block;margin-bottom:5px;color:#900}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;border-radius:15px;padding:30px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}.modal-content h2{color:#333;margin:0 0 20px}.modal-content p{color:#666;margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group textarea{width:100%;padding:10px;border:1px solid #ddd;border-radius:8px;font-size:14px;resize:vertical;font-family:inherit}.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-actions{display:flex;gap:15px;margin-top:25px}.btn-confirm-reject,.btn-cancel{flex:1;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.btn-confirm-reject{background:#f44;color:#fff}.btn-confirm-reject:hover:not(:disabled){background:#c00}.btn-confirm-reject:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{background:#f0f0f0;color:#666}.btn-cancel:hover{background:#e0e0e0}.loading-spinner{text-align:center;padding:100px;font-size:18px;color:#666}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.users-grid{grid-template-columns:1fr}.filter-tabs{overflow-x:auto;white-space:nowrap}.id-images{grid-template-columns:1fr}}.accounting-dashboard{padding:20px;max-width:1400px;margin:0 auto}.accounting-header{margin-bottom:30px}.accounting-header h1{font-size:32px;font-weight:700;color:#1f2937;margin-bottom:8px}.financial-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.summary-card{border-radius:16px;padding:24px;color:#fff;display:flex;align-items:center;gap:16px;box-shadow:0 4px 6px -1px #0000001a;transition:transform .2s}.summary-card:hover{transform:translateY(-4px)}.summary-icon{font-size:48px;opacity:.9}.summary-content h3{font-size:14px;font-weight:500;opacity:.9;margin-bottom:8px}.summary-amount{font-size:28px;font-weight:700;margin-bottom:4px}.summary-label{font-size:12px;opacity:.8}.revenue-breakdown{background:#fff;border-radius:12px;padding:24px;margin-bottom:30px;box-shadow:0 1px 3px #0000001a}.revenue-breakdown h3{font-size:18px;font-weight:600;margin-bottom:20px;color:#1f2937}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.breakdown-item{background:#f9fafb;border-radius:8px;padding:16px;text-align:center}.breakdown-label{font-size:14px;color:#6b7280;margin-bottom:8px}.breakdown-amount{font-size:24px;font-weight:700;color:#10b981;margin-bottom:4px}.breakdown-count{font-size:12px;color:#9ca3af}.accounting-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e5e7eb}.tab-btn{padding:12px 24px;background:none;border:none;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.tab-btn:hover{color:#1f2937;background:#f9fafb}.tab-btn.active{color:#667eea;border-bottom-color:#667eea}.tab-content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.revenue-overview{max-width:100%}.overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:16px}.overview-header h2{font-size:24px;font-weight:600;color:#1f2937}.date-range-selector{display:flex;gap:12px;align-items:center}.custom-date-inputs{display:flex;gap:8px;align-items:center}.revenue-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:30px}.stat-card{background:#f9fafb;border-radius:8px;padding:16px;text-align:center}.stat-card h4{font-size:14px;color:#6b7280;margin-bottom:8px}.stat-value{font-size:24px;font-weight:700;color:#1f2937}.revenue-chart{margin-bottom:40px}.revenue-chart h3{font-size:18px;font-weight:600;margin-bottom:20px;color:#1f2937}.chart-container{display:flex;align-items:flex-end;justify-content:space-between;gap:8px;height:300px;padding:20px;background:#f9fafb;border-radius:8px}.chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.chart-bar-container{flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.chart-bar{width:100%;max-width:60px;background:linear-gradient(to top,#10b981,#34d399);border-radius:4px 4px 0 0;position:relative;transition:all .3s;min-height:10px;cursor:pointer}.chart-bar:hover{background:linear-gradient(to top,#059669,#10b981)}.bar-value{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:10px;font-weight:600;color:#1f2937;white-space:nowrap}.chart-label{margin-top:8px;font-size:11px;color:#6b7280;text-align:center;word-break:break-word}.daily-report-table{margin-top:40px}.daily-report-table h3{font-size:18px;font-weight:600;margin-bottom:16px;color:#1f2937}.table-responsive{overflow-x:auto}.report-table{width:100%;border-collapse:collapse;font-size:14px}.report-table th{background:#f9fafb;padding:12px;text-align:left;font-weight:600;color:#1f2937;border-bottom:2px solid #e5e7eb}.report-table td{padding:12px;border-bottom:1px solid #e5e7eb}.report-table tbody tr:hover{background:#f9fafb}.report-table tfoot tr{background:#f3f4f6;font-weight:600}.transaction-list{max-width:100%}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.list-header h2{font-size:24px;font-weight:600;color:#1f2937}.transaction-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px;padding:20px;background:#f9fafb;border-radius:8px}.filter-group{display:flex;flex-direction:column}.filter-group label{font-size:12px;font-weight:500;color:#6b7280;margin-bottom:4px}.transaction-table{width:100%;border-collapse:collapse;font-size:14px}.transaction-table th{background:#f9fafb;padding:12px;text-align:left;font-weight:600;color:#1f2937;border-bottom:2px solid #e5e7eb;white-space:nowrap}.transaction-table td{padding:12px;border-bottom:1px solid #e5e7eb}.transaction-table tbody tr:hover{background:#f9fafb}.transaction-type-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500;background:#e0e7ff;color:#4f46e5}.expense-manager{max-width:100%}.expense-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.expense-form-card{background:#f9fafb;border-radius:8px;padding:24px;margin-bottom:24px}.expense-form-card h3{font-size:18px;font-weight:600;margin-bottom:20px;color:#1f2937}.expense-form .form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:16px}.expense-form .form-group{margin-bottom:16px}.expense-form .form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:6px}.form-actions{display:flex;gap:12px;margin-top:20px}.expense-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px;padding:20px;background:#f9fafb;border-radius:8px}.expense-summary{background:#fef3c7;border-radius:8px;padding:16px;margin-bottom:24px;text-align:center}.expense-summary h4{font-size:14px;color:#92400e;margin-bottom:8px}.expense-list{display:grid;gap:16px}.expense-card{display:flex;align-items:center;gap:16px;background:#f9fafb;border-radius:8px;padding:16px;transition:all .2s}.expense-card:hover{background:#f3f4f6;box-shadow:0 2px 4px #0000000d}.expense-icon{font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px}.expense-details{flex:1}.expense-details h4{font-size:16px;font-weight:600;color:#1f2937;margin-bottom:8px}.expense-meta{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:8px}.expense-date,.expense-payment{font-size:12px;color:#6b7280}.expense-notes{font-size:13px;color:#6b7280;margin-top:8px}.expense-creator{font-size:11px;color:#9ca3af;margin-top:4px}.expense-amount{font-size:20px;font-weight:700;color:#ef4444}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding:20px}.pagination-info{font-size:14px;color:#6b7280}.empty-state{text-align:center;padding:60px 20px;color:#9ca3af}.loading-state{text-align:center;padding:60px 20px;color:#6b7280;font-size:16px}@media (max-width: 768px){.accounting-dashboard{padding:12px}.financial-summary-grid{grid-template-columns:1fr}.summary-card{padding:16px}.accounting-tabs{overflow-x:auto;flex-wrap:nowrap}.tab-btn{white-space:nowrap;padding:10px 16px}.overview-header{flex-direction:column;align-items:flex-start}.transaction-filters,.expense-filters{grid-template-columns:1fr}.chart-container{height:200px;padding:10px}.bar-value{font-size:8px}.expense-card{flex-direction:column;text-align:center}}.public-nav{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 15px #f59e0b4d;position:sticky;top:0;z-index:100}.nav-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:#fff;font-size:1.5rem;font-weight:700;transition:transform .2s}.logo:hover{transform:scale(1.05)}.logo-icon{font-size:2rem}.logo-img{height:40px;width:auto;border-radius:8px}.logo-text{font-family:Inter,sans-serif}.nav-links{display:flex;gap:1rem;align-items:center}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:.5rem;font-weight:500;transition:all .2s}.nav-link:hover{background:#fff3}.nav-link-secondary{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:.5rem;border:2px solid white;font-weight:500;transition:all .2s}.nav-link-secondary:hover{background:#fff;color:#667eea}@media (max-width: 768px){.nav-container{flex-direction:column;gap:1rem}.nav-links{flex-wrap:wrap;justify-content:center}}.user-profile{width:100%;margin:0;padding:2rem;min-height:calc(100vh - 72px);background:linear-gradient(180deg,#f9fafb,#fff)}.profile-header{margin-bottom:2rem}.profile-header h1{font-size:2rem;color:#111827;margin-bottom:.5rem}.profile-header p{color:#6b7280;font-size:1rem}.message{padding:1rem;border-radius:.5rem;margin-bottom:1.5rem;font-weight:500}.message.success{background:#d1fae5;color:#065f46;border:1px solid #10b981}.message.error{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.profile-content{max-width:1200px;margin:0 auto}.profile-section{background:#fff;border-radius:1rem;padding:2rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.5rem;color:#111827;margin:0}.btn-edit{padding:.5rem 1rem;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-edit:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.profile-form,.password-form{display:flex;flex-direction:column;gap:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.form-group input{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;transition:all .2s;background:#fff;color:#111827}.form-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-group input:disabled{background:#f9fafb;cursor:not-allowed}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-cancel{padding:.75rem 1.5rem;background:#e5e7eb;color:#374151;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-cancel:hover{background:#d1d5db}.btn-save,.btn-change-password{padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#22c55e);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-save:hover,.btn-change-password:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-save:disabled,.btn-change-password:disabled{opacity:.5;cursor:not-allowed;transform:none}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.stat-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:.75rem;transition:all .3s}.stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:.75rem;box-shadow:0 2px 8px #0000000d}.stat-value{font-size:1.5rem;font-weight:700;color:#111827;line-height:1;margin-bottom:.25rem}.verification-status{display:flex;flex-direction:column;gap:1rem}.status-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f9fafb;border-radius:.5rem}.status-label{font-weight:600;color:#374151}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:600}.status-badge.unverified{background:#fee2e2;color:#991b1b}.danger-zone{border:2px solid #fee2e2;background:#fff5f5}.danger-zone h2{color:#dc2626}.danger-actions{display:flex;flex-direction:column;gap:1rem}.danger-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border-radius:.5rem;border:1px solid #fee2e2}.danger-item h3{font-size:1.125rem;color:#111827;margin-bottom:.25rem}.danger-item p{font-size:.875rem;color:#6b7280;margin:0}.btn-deactivate{padding:.5rem 1rem;background:#f97316;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-deactivate:hover{background:#ea580c;transform:translateY(-2px)}.btn-delete{padding:.5rem 1rem;background:#dc2626;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-delete:hover{background:#b91c1c;transform:translateY(-2px)}@media (max-width: 768px){.form-row,.stats-grid{grid-template-columns:1fr}.danger-item{flex-direction:column;gap:1rem;text-align:center}.danger-item button{width:100%}}.booking-history{width:100%;margin:0;padding:2rem;min-height:calc(100vh - 72px);background:linear-gradient(180deg,#f9fafb,#fff)}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.history-header h1{font-size:2rem;color:#111827;margin:0}.btn-export{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#10b981,#22c55e);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-export:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;gap:1rem;transition:all .3s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px #0000001a}.stat-icon{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:.75rem}.stat-content{flex:1}.stat-value{font-size:1.75rem;font-weight:700;color:#111827;line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.filters-section{background:#fff;border-radius:1rem;padding:1.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.filters-row{display:flex;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;align-items:center}.filters-row:last-child{margin-bottom:0}.search-box{flex:1;min-width:300px}.search-box input{width:100%;padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;transition:all .2s}.search-box input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.date-filters{display:flex;align-items:center;gap:.5rem}.date-filters input{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;transition:all .2s}.date-filters input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.date-filters span{color:#6b7280;font-weight:500}.filter-select{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;font-size:1rem;background:#fff;cursor:pointer;transition:all .2s;min-width:150px}.filter-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.btn-clear-filters{padding:.75rem 1.5rem;background:#e5e7eb;color:#374151;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-clear-filters:hover{background:#d1d5db;transform:translateY(-2px)}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:#fff;padding:.5rem;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.tabs button{flex:1;padding:.75rem 1.5rem;background:transparent;color:#6b7280;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.tabs button:hover{background:#f3f4f6}.tabs button.active{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}.results-info{padding:.75rem 1rem;background:#fff;border-radius:.5rem;margin-bottom:1rem;color:#6b7280;font-size:.875rem;text-align:right}.bookings-list{display:flex;flex-direction:column;gap:1rem}.booking-card-enhanced{background:#fff;border-radius:1rem;box-shadow:0 1px 3px #0000001a;display:flex;align-items:stretch;transition:all .3s;overflow:hidden}.booking-card-enhanced:hover{transform:translate(4px);box-shadow:0 4px 12px #00000026}.booking-badge{width:80px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0}.booking-details{flex:1;padding:1.5rem}.booking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.booking-header h3{font-size:1.25rem;color:#111827;margin:0}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.pending{background:#fed7aa;color:#92400e}.status-badge.verified{background:#d1fae5;color:#065f46}.status-badge.cancelled{background:#fee2e2;color:#991b1b}.status-badge.expired{background:#e5e7eb;color:#374151}.booking-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem}.info-item{display:flex;gap:.5rem}.info-label{font-size:.875rem;color:#6b7280;font-weight:500}.info-value{font-size:.875rem;color:#111827;font-weight:600}.info-value.amount{color:#10b981;font-size:1rem}.booking-description{color:#6b7280;font-size:.875rem;margin:0}.booking-actions{display:flex;flex-direction:column;justify-content:center;gap:.5rem;padding:1rem;background:#f9fafb;border-left:1px solid #e5e7eb}.btn-action{padding:.5rem 1rem;border:none;border-radius:.5rem;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;text-align:center}.btn-cancel,.btn-leave{background:#ef4444;color:#fff}.btn-cancel:hover,.btn-leave:hover{background:#dc2626;transform:translateY(-2px)}.btn-view{background:#e5e7eb;color:#374151}.btn-view:hover{background:#d1d5db;transform:translateY(-2px)}.no-results{background:#fff;border-radius:1rem;padding:3rem;text-align:center;box-shadow:0 1px 3px #0000001a}.no-results p{color:#6b7280;margin-bottom:1.5rem;font-size:1.125rem}.no-results button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.no-results button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding:1rem;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.pagination-btn{padding:.5rem 1rem;background:#e5e7eb;color:#374151;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:#d1d5db;transform:translateY(-2px)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-numbers{display:flex;gap:.5rem}.pagination-number{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;color:#374151;border:2px solid #e5e7eb;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.pagination-number:hover{border-color:#2563eb;color:#2563eb}.pagination-number.active{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-color:transparent}.loading{display:flex;justify-content:center;align-items:center;min-height:60vh;font-size:1.125rem;color:#6b7280}@media (max-width: 768px){.booking-history{padding:1rem}.history-header{flex-direction:column;gap:1rem;align-items:stretch}.stats-cards{grid-template-columns:1fr}.filters-row{flex-direction:column}.search-box{min-width:100%}.date-filters{width:100%;flex-direction:column}.date-filters input{width:100%}.tabs,.booking-card-enhanced{flex-direction:column}.booking-badge{width:100%;height:60px}.booking-actions{flex-direction:row;border-left:none;border-top:1px solid #e5e7eb}.pagination-numbers{display:none}}.calendar-view{display:flex;gap:2rem;padding:2rem;width:100%;margin:0;min-height:calc(100vh - 72px);background:linear-gradient(180deg,#f9fafb,#fff)}.calendar-container{flex:1;background:#fff;border-radius:1rem;padding:2rem;box-shadow:0 1px 3px #0000001a}.calendar-container h1{font-size:2rem;color:#111827;margin-bottom:1.5rem}.calendar-header{margin-bottom:2rem}.header-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.month-navigation{display:flex;align-items:center;gap:1rem}.month-navigation button{width:40px;height:40px;border:none;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-radius:.5rem;font-size:1.25rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.month-navigation button:hover{transform:scale(1.1);box-shadow:0 4px 12px #2563eb4d}.month-navigation h2{font-size:1.5rem;color:#111827;min-width:200px;text-align:center;margin:0}.header-actions{display:flex;gap:1rem;align-items:center}.btn-today{padding:.5rem 1rem;background:#10b981;color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-today:hover{background:#059669;transform:translateY(-2px)}.court-filter{padding:.5rem 1rem;border:2px solid #e5e7eb;border-radius:.5rem;background:#fff;font-size:1rem;cursor:pointer;transition:all .2s}.court-filter:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.view-mode-toggle{display:flex;background:#f3f4f6;border-radius:.5rem;padding:.25rem}.view-mode-toggle button{padding:.5rem 1rem;background:transparent;border:none;color:#6b7280;font-weight:600;cursor:pointer;border-radius:.375rem;transition:all .2s}.view-mode-toggle button:hover{background:#ffffff80}.view-mode-toggle button.active{background:#fff;color:#2563eb;box-shadow:0 1px 3px #0000001a}.legend{display:flex;gap:1.5rem;flex-wrap:wrap;padding:1rem;background:#f9fafb;border-radius:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.legend-color{width:20px;height:20px;border-radius:.25rem;border:1px solid rgba(0,0,0,.1)}.legend-color.available{background:#10b981}.legend-color.partial{background:#f59e0b}.legend-color.booked{background:#ef4444}.legend-color.user-booking{background:#3b82f6}.days-of-week{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:.5rem}.day-header{padding:1rem;text-align:center;font-weight:600;color:#6b7280;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.calendar-body{border:1px solid #e5e7eb;border-radius:.75rem;overflow:hidden}.calendar-row{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-cell{min-height:100px;border:1px solid #f3f4f6;padding:.5rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}.calendar-cell:hover{background:#f9fafb;z-index:1;box-shadow:0 0 0 2px #2563eb}.calendar-cell.disabled{background:#fafafa;color:#d1d5db;cursor:default}.calendar-cell.disabled:hover{background:#fafafa;box-shadow:none}.calendar-cell.today{background:#fef3c7;font-weight:600}.calendar-cell.today .date-number{color:#f59e0b}.calendar-cell.selected{background:#eff6ff;box-shadow:inset 0 0 0 2px #2563eb}.calendar-cell.past{background:#f9fafb;color:#9ca3af;cursor:default}.calendar-cell.past:hover{box-shadow:none}.calendar-cell.high-availability{background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.calendar-cell.partial-availability{background:linear-gradient(135deg,#fed7aa,#fbbf24)}.calendar-cell.low-availability{background:linear-gradient(135deg,#fed7aa,#fb923c)}.calendar-cell.fully-booked{background:linear-gradient(135deg,#fee2e2,#fca5a5)}.calendar-cell.user-booking{background:linear-gradient(135deg,#dbeafe,#93c5fd)}.calendar-cell.no-data{background:#f9fafb}.cell-content{display:flex;flex-direction:column;height:100%}.date-number{font-size:1rem;font-weight:600;color:#374151;margin-bottom:.5rem}.availability-info{display:flex;align-items:center;justify-content:space-between;margin-top:auto}.slots-count{font-size:.75rem;font-weight:600;padding:.25rem .5rem;background:#fffc;border-radius:.25rem;color:#374151}.no-slots{font-size:.75rem;color:#9ca3af}.booking-indicator{font-size:1rem}.availability-bar{position:absolute;bottom:0;left:0;height:4px;background:#10b981;transition:width .3s}.date-details-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:1rem;width:90%;max-width:800px;max-height:90vh;overflow:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.modal-header h3{font-size:1.5rem;color:#111827;margin:0}.modal-header button{width:40px;height:40px;border:none;background:#f3f4f6;border-radius:.5rem;font-size:1.5rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-header button:hover{background:#e5e7eb}.modal-body{padding:1.5rem}.court-details{margin-bottom:2rem}.court-details h4{font-size:1.25rem;color:#111827;margin-bottom:.5rem}.court-description{color:#6b7280;margin-bottom:1rem}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.time-slot-item{padding:.75rem;border:2px solid #e5e7eb;border-radius:.5rem;display:flex;flex-direction:column;align-items:center;transition:all .2s}.time-slot-item.available{background:#d1fae5;border-color:#10b981;cursor:pointer}.time-slot-item.available:hover{background:#a7f3d0;transform:translateY(-2px)}.time-slot-item.booked{background:#fee2e2;border-color:#ef4444;opacity:.7}.slot-time{font-weight:600;color:#111827;margin-bottom:.25rem}.slot-price{font-size:.875rem;color:#059669;margin-bottom:.5rem}.btn-quick-book{padding:.25rem .75rem;background:#10b981;color:#fff;border:none;border-radius:.25rem;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-quick-book:hover{background:#059669}.slot-status{font-size:.75rem;color:#991b1b;font-weight:600}.modal-footer{padding:1.5rem;border-top:1px solid #e5e7eb}.btn-view-all{width:100%;padding:1rem;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-view-all:hover{transform:translateY(-2px);box-shadow:0 4px 12px #2563eb4d}.calendar-sidebar{width:300px;display:flex;flex-direction:column;gap:1.5rem}.quick-stats{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.quick-stats h3{font-size:1.25rem;color:#111827;margin-bottom:1rem}.stat-item{display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid #f3f4f6}.stat-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.stat-label{color:#6b7280;font-size:.875rem}.stat-value{font-weight:600;color:#111827}.quick-actions{display:flex;flex-direction:column;gap:1rem}.btn-book-now,.btn-view-bookings{padding:1rem;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.btn-book-now{background:linear-gradient(135deg,#10b981,#22c55e);color:#fff}.btn-book-now:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.btn-view-bookings{background:#fff;color:#2563eb;border:2px solid #2563eb}.btn-view-bookings:hover{background:#eff6ff;transform:translateY(-2px)}.calendar-loading{display:flex;justify-content:center;align-items:center;min-height:60vh;font-size:1.125rem;color:#6b7280}.week-view{display:grid;grid-template-columns:repeat(7,1fr);gap:1rem;margin-top:1rem}.week-day{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;overflow:hidden}.week-day-header{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);padding:1rem;text-align:center;border-bottom:1px solid #e5e7eb}.week-day-header h4{margin:0;color:#111827;font-size:1rem}.week-day-header p{margin:.25rem 0 0;color:#6b7280;font-size:.875rem}.week-day-content{padding:1rem;min-height:300px}.day-view{padding:2rem}.day-view h3{font-size:1.5rem;color:#111827;margin-bottom:1.5rem}@media (max-width: 1024px){.calendar-view{flex-direction:column}.calendar-sidebar{width:100%;flex-direction:row}.quick-stats,.quick-actions{flex:1}}@media (max-width: 768px){.calendar-view,.calendar-container{padding:1rem}.header-controls{flex-direction:column;gap:1rem}.header-actions{flex-wrap:wrap;width:100%}.month-navigation h2{font-size:1.25rem}.calendar-cell{min-height:80px;padding:.25rem}.days-of-week{display:none}.calendar-sidebar{flex-direction:column}.week-view{grid-template-columns:1fr}.time-slots-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.reschedule-container{max-width:800px;margin:0 auto;padding:20px}.reschedule-header{text-align:center;margin-bottom:30px}.reschedule-header h1{color:#eab308;margin-bottom:10px}.reschedule-header p{color:#666}.progress-steps{display:flex;align-items:center;justify-content:center;margin-bottom:30px;padding:20px}.step{display:flex;flex-direction:column;align-items:center;opacity:.5}.step.active{opacity:1}.step.completed .step-number{background:#10b981}.step-number{width:40px;height:40px;border-radius:50%;background:#ddd;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;margin-bottom:8px}.step.active .step-number{background:#eab308}.step-label{font-size:12px;color:#666;text-align:center}.step-line{width:60px;height:3px;background:#ddd;margin:0 10px 20px}.error-message{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:15px;border-radius:10px;margin-bottom:20px;display:flex;align-items:center;gap:10px}.step-content{background:#fff;border-radius:15px;padding:30px;box-shadow:0 4px 20px #0000001a}.lookup-form{max-width:400px;margin:0 auto}.lookup-form .form-group{margin-bottom:20px}.lookup-form label{display:block;margin-bottom:8px;font-weight:600;color:#333}.lookup-form input{width:100%;padding:15px;border:2px solid #e5e7eb;border-radius:10px;font-size:16px;text-transform:uppercase;letter-spacing:1px}.lookup-form input:focus{outline:none;border-color:#eab308}.lookup-form small{display:block;margin-top:8px;color:#666;font-size:12px}.lookup-form button{width:100%;padding:15px;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.lookup-form button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #eab30866}.lookup-form button:disabled{opacity:.6;cursor:not-allowed}.info-box{background:#fefce8;border:1px solid #fef08a;border-radius:10px;padding:20px;margin-top:30px}.info-box h4{margin:0 0 15px;color:#854d0e}.info-box ul{margin:0;padding-left:20px;color:#a16207}.info-box li{margin-bottom:8px}.current-booking{background:#f0f9ff;border:2px solid #0ea5e9;border-radius:10px;padding:20px;margin-bottom:25px}.current-booking h3{margin:0 0 15px;color:#0369a1}.booking-details{display:flex;flex-wrap:wrap;gap:15px}.booking-item{background:#fff;padding:15px;border-radius:8px;flex:1;min-width:150px}.booking-item p{margin:5px 0;font-size:14px}.new-slot-selection h3{color:#eab308;margin-bottom:20px}.selection-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:25px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:10px;font-weight:600;color:#333}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#eab308}.court-buttons{display:flex;gap:10px;flex-wrap:wrap}.court-btn{padding:12px 20px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;font-weight:500;transition:all .2s}.court-btn:hover{border-color:#eab308}.court-btn.selected{background:#eab308;border-color:#eab308;color:#fff}.time-slots{margin-bottom:25px}.time-slots label{display:block;margin-bottom:15px;font-weight:600;color:#333}.slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px}.slot-btn{padding:12px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;font-size:13px;transition:all .2s}.slot-btn:hover:not(:disabled){border-color:#eab308}.slot-btn.selected{background:#eab308;border-color:#eab308;color:#fff}.slot-btn.unavailable{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;text-decoration:line-through}.new-booking-summary{background:#ecfdf5;border:2px solid #10b981;border-radius:10px;padding:20px;margin-bottom:25px}.new-booking-summary h4{margin:0 0 15px;color:#059669}.new-booking-summary p{margin:8px 0}.button-group{display:flex;gap:15px;margin-top:25px}.back-btn{flex:1;padding:15px;background:#e5e7eb;color:#374151;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.back-btn:hover{background:#d1d5db}.submit-btn{flex:2;padding:15px;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #eab30866}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.success-content{text-align:center}.success-icon{font-size:60px;margin-bottom:20px}.success-content h2{color:#10b981;margin-bottom:10px}.confirmation-details{background:#f0fdf4;border:2px solid #10b981;border-radius:10px;padding:20px;margin:25px 0;text-align:left}.confirmation-details p{margin:10px 0}.status-pending{background:#fef3c7;color:#92400e;padding:4px 12px;border-radius:20px;font-size:14px;font-weight:600}.success-content button{padding:15px 40px;background:linear-gradient(135deg,#eab308,#ca8a04);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;margin-top:20px}@media (max-width: 600px){.progress-steps{padding:10px}.step-line{width:30px}.step-label{font-size:10px}.selection-grid{grid-template-columns:1fr}.button-group{flex-direction:column}.back-btn,.submit-btn{flex:1}}
