*,: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:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}[type=text],input:where(:not([type])),[type=email],[type=url],[type=password],[type=number],[type=date],[type=datetime-local],[type=month],[type=search],[type=tel],[type=time],[type=week],[multiple],textarea,select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow: 0 0 #0000}[type=text]:focus,input:where(:not([type])):focus,[type=email]:focus,[type=url]:focus,[type=password]:focus,[type=number]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=month]:focus,[type=search]:focus,[type=tel]:focus,[type=time]:focus,[type=week]:focus,[multiple]:focus,textarea:focus,select:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}input::-moz-placeholder,textarea::-moz-placeholder{color:#6b7280;opacity:1}input::placeholder,textarea::placeholder{color:#6b7280;opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-date-and-time-value{min-height:1.5em;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-top:0;padding-bottom:0}select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}[multiple],[size]:where(select:not([size="1"])){background-image:initial;background-position:initial;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}[type=checkbox],[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow: 0 0 #0000}[type=checkbox]{border-radius:0}[type=radio]{border-radius:100%}[type=checkbox]:focus,[type=radio]:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 2px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}[type=checkbox]:checked,[type=radio]:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}[type=checkbox]:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e")}@media(forced-colors:active){[type=checkbox]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=radio]:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e")}@media(forced-colors:active){[type=radio]:checked{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:checked:hover,[type=checkbox]:checked:focus,[type=radio]:checked:hover,[type=radio]:checked:focus{border-color:transparent;background-color:currentColor}[type=checkbox]:indeterminate{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}@media(forced-colors:active){[type=checkbox]:indeterminate{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}}[type=checkbox]:indeterminate:hover,[type=checkbox]:indeterminate:focus{border-color:transparent;background-color:currentColor}[type=file]{background:unset;border-color:inherit;border-width:0;border-radius:0;padding:0;font-size:unset;line-height:inherit}[type=file]:focus{outline:1px solid ButtonText;outline:1px auto -webkit-focus-ring-color}:root{--font-size: 16px;--background: 204 33% 97%;--foreground: 207 38% 17%;--card: 0 0% 100%;--card-foreground: 207 38% 17%;--popover: 0 0% 100%;--popover-foreground: 207 38% 17%;--primary: 217 91% 60%;--primary-foreground: 0 0% 100%;--secondary: 201 94% 94%;--secondary-foreground: 202 89% 28%;--muted: 210 40% 96%;--muted-foreground: 215 16% 47%;--accent: 214 95% 93%;--accent-foreground: 224 76% 40%;--destructive: 0 72% 51%;--destructive-foreground: 0 0% 100%;--success: 160 84% 39%;--success-foreground: 0 0% 100%;--warning: 38 92% 50%;--warning-foreground: 0 0% 100%;--border: 214 32% 91%;--input: 214 32% 91%;--input-background: 0 0% 100%;--switch-background: 215 20% 65%;--ring: 217 91% 60%;--radius: .5rem;--chart-1: 217 91% 60%;--chart-2: 160 84% 39%;--chart-3: 263 70% 50%;--chart-4: 38 92% 50%;--chart-5: 0 84% 60%}*{border-color:hsl(var(--border))}body{background-color:hsl(var(--background));color:hsl(var(--foreground));font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1{scroll-margin:5rem;font-size:2.25rem;line-height:2.5rem;font-weight:800;letter-spacing:-.025em}@media(min-width:1024px){h1{font-size:3rem;line-height:1}}h2{scroll-margin:5rem;font-size:1.875rem;line-height:2.25rem;font-weight:600;letter-spacing:-.025em}h3{scroll-margin:5rem;font-size:1.5rem;line-height:2rem;font-weight:600;letter-spacing:-.025em}h4{scroll-margin:5rem;font-size:1.25rem;line-height:1.75rem;font-weight:600;letter-spacing:-.025em}p{line-height:1.75rem}.form-input,.form-textarea,.form-select,.form-multiselect{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border-color:#6b7280;border-width:1px;border-radius:0;padding:.5rem .75rem;font-size:1rem;line-height:1.5rem;--tw-shadow: 0 0 #0000}.form-input:focus,.form-textarea:focus,.form-select:focus,.form-multiselect:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset: var(--tw-empty, );--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: #2563eb;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);border-color:#2563eb}.form-input::-moz-placeholder,.form-textarea::-moz-placeholder{color:#6b7280;opacity:1}.form-input::placeholder,.form-textarea::placeholder{color:#6b7280;opacity:1}.form-input::-webkit-datetime-edit-fields-wrapper{padding:0}.form-input::-webkit-date-and-time-value{min-height:1.5em;text-align:inherit}.form-input::-webkit-datetime-edit{display:inline-flex}.form-input::-webkit-datetime-edit,.form-input::-webkit-datetime-edit-year-field,.form-input::-webkit-datetime-edit-month-field,.form-input::-webkit-datetime-edit-day-field,.form-input::-webkit-datetime-edit-hour-field,.form-input::-webkit-datetime-edit-minute-field,.form-input::-webkit-datetime-edit-second-field,.form-input::-webkit-datetime-edit-millisecond-field,.form-input::-webkit-datetime-edit-meridiem-field{padding-top:0;padding-bottom:0}.form-select{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;-webkit-print-color-adjust:exact;print-color-adjust:exact}.form-select:where([size]:not([size="1"])){background-image:initial;background-position:initial;background-repeat:unset;background-size:initial;padding-right:.75rem;-webkit-print-color-adjust:unset;print-color-adjust:unset}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.inset-4{inset:1rem}.inset-x-0{left:0;right:0}.inset-y-0{top:0;bottom:0}.inset-y-16{top:4rem;bottom:4rem}.-bottom-1\.5{bottom:-.375rem}.-left-1\.5{left:-.375rem}.-right-1\.5{right:-.375rem}.-top-1\.5{top:-.375rem}.-top-3{top:-.75rem}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.left-2{left:.5rem}.left-3{left:.75rem}.right-0{right:0}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-3{top:.75rem}.top-4{top:1rem}.top-full{top:100%}.z-10{z-index:10}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.z-\[10000\]{z-index:10000}.z-\[9999\]{z-index:9999}.m-0{margin:0}.-mx-1{margin-left:-.25rem;margin-right:-.25rem}.-mx-8{margin-left:-2rem;margin-right:-2rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-2{margin-top:.5rem;margin-bottom:.5rem}.-mt-4{margin-top:-1rem}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-1{margin-left:.25rem}.ml-14{margin-left:3.5rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.ml-6{margin-left:1.5rem}.ml-8{margin-left:2rem}.ml-auto{margin-left:auto}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-4{margin-right:1rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.aspect-video{aspect-ratio:16 / 9}.size-4{width:1rem;height:1rem}.size-9{width:2.25rem;height:2.25rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-2\.5{height:.625rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-auto{height:auto}.h-full{height:100%}.h-px{height:1px}.h-screen{height:100vh}.max-h-32{max-height:8rem}.max-h-96{max-height:24rem}.max-h-\[400px\]{max-height:400px}.max-h-\[500px\]{max-height:500px}.max-h-\[70vh\]{max-height:70vh}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.max-h-full{max-height:100%}.min-h-0{min-height:0px}.min-h-\[400px\]{min-height:400px}.min-h-\[48px\]{min-height:48px}.min-h-\[50vh\]{min-height:50vh}.min-h-\[60vh\]{min-height:60vh}.min-h-\[calc\(100vh-73px\)\]{min-height:calc(100vh - 73px)}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-2\.5{width:.625rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-3\/4{width:75%}.w-32{width:8rem}.w-4{width:1rem}.w-40{width:10rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-80{width:20rem}.w-\[1px\]{width:1px}.w-\[280px\]{width:280px}.w-\[90vw\]{width:90vw}.w-\[95vw\]{width:95vw}.w-\[calc\(100vw-32px\)\]{width:calc(100vw - 32px)}.w-auto{width:auto}.w-full{width:100%}.w-px{width:1px}.min-w-0{min-width:0px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.min-w-full{min-width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[140px\]{max-width:140px}.max-w-\[150px\]{max-width:150px}.max-w-\[180px\]{max-width:180px}.max-w-\[200px\]{max-width:200px}.max-w-\[95vw\]{max-width:95vw}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.max-w-none{max-width:none}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -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))}.-translate-x-full{--tw-translate-x: -100%;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))}.-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))}.translate-x-0{--tw-translate-x: 0px;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))}.translate-x-5{--tw-translate-x: 1.25rem;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))}.translate-x-full{--tw-translate-x: 100%;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))}.rotate-180{--tw-rotate: 180deg;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))}.rotate-45{--tw-rotate: 45deg;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-105{--tw-scale-x: 1.05;--tw-scale-y: 1.05;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 pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.touch-none{touch-action:none}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize-none{resize:none}.resize{resize:both}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0px}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-12{gap:3rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.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-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * 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))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-border>:not([hidden])~:not([hidden]){border-color:hsl(var(--border))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(229 231 235 / var(--tw-divide-opacity, 1))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-\[4px\]{border-radius:4px}.rounded-\[inherit\]{border-radius:inherit}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-xl{border-top-left-radius:.75rem;border-top-right-radius:.75rem}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l{border-left-width:1px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-none{border-style:none}.border-amber-200{--tw-border-opacity: 1;border-color:rgb(253 230 138 / var(--tw-border-opacity, 1))}.border-blue-200{--tw-border-opacity: 1;border-color:rgb(191 219 254 / var(--tw-border-opacity, 1))}.border-blue-600{--tw-border-opacity: 1;border-color:rgb(37 99 235 / var(--tw-border-opacity, 1))}.border-border{border-color:hsl(var(--border))}.border-chart-2{border-color:hsl(var(--chart-2))}.border-chart-3{border-color:hsl(var(--chart-3))}.border-chart-4{border-color:hsl(var(--chart-4))}.border-destructive{border-color:hsl(var(--destructive))}.border-destructive\/30{border-color:hsl(var(--destructive) / .3)}.border-gray-100{--tw-border-opacity: 1;border-color:rgb(243 244 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-gray-800{--tw-border-opacity: 1;border-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-green-200{--tw-border-opacity: 1;border-color:rgb(187 247 208 / var(--tw-border-opacity, 1))}.border-input{border-color:hsl(var(--input))}.border-primary{border-color:hsl(var(--primary))}.border-primary\/20{border-color:hsl(var(--primary) / .2)}.border-primary\/30{border-color:hsl(var(--primary) / .3)}.border-primary\/50{border-color:hsl(var(--primary) / .5)}.border-red-200{--tw-border-opacity: 1;border-color:rgb(254 202 202 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.border-white\/20{border-color:#fff3}.border-white\/30{border-color:#ffffff4d}.border-l-transparent{border-left-color:transparent}.border-l-yellow-500{--tw-border-opacity: 1;border-left-color:rgb(234 179 8 / var(--tw-border-opacity, 1))}.border-t-primary{border-top-color:hsl(var(--primary))}.border-t-transparent{border-top-color:transparent}.border-t-white{--tw-border-opacity: 1;border-top-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.bg-accent{background-color:hsl(var(--accent))}.bg-amber-100{--tw-bg-opacity: 1;background-color:rgb(254 243 199 / var(--tw-bg-opacity, 1))}.bg-amber-50{--tw-bg-opacity: 1;background-color:rgb(255 251 235 / var(--tw-bg-opacity, 1))}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-background{background-color:hsl(var(--background))}.bg-background\/80{background-color:hsl(var(--background) / .8)}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-black\/50{background-color:#00000080}.bg-blue-100{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.bg-blue-50{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-border{background-color:hsl(var(--border))}.bg-card{background-color:hsl(var(--card))}.bg-chart-2{background-color:hsl(var(--chart-2))}.bg-chart-2\/10{background-color:hsl(var(--chart-2) / .1)}.bg-chart-2\/5{background-color:hsl(var(--chart-2) / .05)}.bg-chart-3{background-color:hsl(var(--chart-3))}.bg-chart-3\/5{background-color:hsl(var(--chart-3) / .05)}.bg-chart-4{background-color:hsl(var(--chart-4))}.bg-chart-4\/5{background-color:hsl(var(--chart-4) / .05)}.bg-destructive{background-color:hsl(var(--destructive))}.bg-destructive\/10{background-color:hsl(var(--destructive) / .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-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-gray-400{--tw-bg-opacity: 1;background-color:rgb(156 163 175 / var(--tw-bg-opacity, 1))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity, 1))}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / 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-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-input{background-color:hsl(var(--input))}.bg-muted{background-color:hsl(var(--muted))}.bg-muted\/20{background-color:hsl(var(--muted) / .2)}.bg-muted\/30{background-color:hsl(var(--muted) / .3)}.bg-muted\/50{background-color:hsl(var(--muted) / .5)}.bg-pink-500{--tw-bg-opacity: 1;background-color:rgb(236 72 153 / var(--tw-bg-opacity, 1))}.bg-popover{background-color:hsl(var(--popover))}.bg-primary{background-color:hsl(var(--primary))}.bg-primary\/10{background-color:hsl(var(--primary) / .1)}.bg-primary\/20{background-color:hsl(var(--primary) / .2)}.bg-primary\/5{background-color:hsl(var(--primary) / .05)}.bg-primary\/50{background-color:hsl(var(--primary) / .5)}.bg-red-100{--tw-bg-opacity: 1;background-color:rgb(254 226 226 / var(--tw-bg-opacity, 1))}.bg-red-50{--tw-bg-opacity: 1;background-color:rgb(254 242 242 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity, 1))}.bg-secondary{background-color:hsl(var(--secondary))}.bg-secondary\/20{background-color:hsl(var(--secondary) / .2)}.bg-secondary\/30{background-color:hsl(var(--secondary) / .3)}.bg-transparent{background-color:transparent}.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\/80{background-color:#fffc}.bg-yellow-100{--tw-bg-opacity: 1;background-color:rgb(254 249 195 / var(--tw-bg-opacity, 1))}.bg-yellow-50\/50{background-color:#fefce880}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity, 1))}.bg-opacity-50{--tw-bg-opacity: .5}.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-blue-100{--tw-gradient-from: #dbeafe var(--tw-gradient-from-position);--tw-gradient-to: rgb(219 234 254 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-50{--tw-gradient-from: #eff6ff var(--tw-gradient-from-position);--tw-gradient-to: rgb(239 246 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from: #2563eb var(--tw-gradient-from-position);--tw-gradient-to: rgb(37 99 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-primary\/10{--tw-gradient-from: hsl(var(--primary) / .1) var(--tw-gradient-from-position);--tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-primary\/5{--tw-gradient-from: hsl(var(--primary) / .05) var(--tw-gradient-from-position);--tw-gradient-to: hsl(var(--primary) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-secondary\/30{--tw-gradient-from: hsl(var(--secondary) / .3) var(--tw-gradient-from-position);--tw-gradient-to: hsl(var(--secondary) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-background{--tw-gradient-to: hsl(var(--background) / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), hsl(var(--background)) var(--tw-gradient-via-position), 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-blue-100{--tw-gradient-to: #dbeafe var(--tw-gradient-to-position)}.to-blue-50{--tw-gradient-to: #eff6ff var(--tw-gradient-to-position)}.to-blue-700{--tw-gradient-to: #1d4ed8 var(--tw-gradient-to-position)}.to-indigo-50{--tw-gradient-to: #eef2ff var(--tw-gradient-to-position)}.to-primary\/5{--tw-gradient-to: hsl(var(--primary) / .05) var(--tw-gradient-to-position)}.to-secondary\/30{--tw-gradient-to: hsl(var(--secondary) / .3) var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.bg-cover{background-size:cover}.bg-center{background-position:center}.bg-no-repeat{background-repeat:no-repeat}.object-contain{-o-object-fit:contain;object-fit:contain}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-\[1px\]{padding:1px}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-12{padding-bottom:3rem}.pb-16{padding-bottom:4rem}.pb-2{padding-bottom:.5rem}.pb-4{padding-bottom:1rem}.pb-6{padding-bottom:1.5rem}.pb-8{padding-bottom:2rem}.pl-10{padding-left:2.5rem}.pl-2{padding-left:.5rem}.pl-8{padding-left:2rem}.pr-2{padding-right:.5rem}.pr-4{padding-right:1rem}.pr-6{padding-right:1.5rem}.pt-0{padding-top:0}.pt-12{padding-top:3rem}.pt-2{padding-top:.5rem}.pt-20{padding-top:5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.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-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-wider{letter-spacing:.05em}.text-amber-600{--tw-text-opacity: 1;color:rgb(217 119 6 / var(--tw-text-opacity, 1))}.text-amber-700{--tw-text-opacity: 1;color:rgb(180 83 9 / var(--tw-text-opacity, 1))}.text-amber-900{--tw-text-opacity: 1;color:rgb(120 53 15 / var(--tw-text-opacity, 1))}.text-blue-100{--tw-text-opacity: 1;color:rgb(219 234 254 / var(--tw-text-opacity, 1))}.text-blue-200{--tw-text-opacity: 1;color:rgb(191 219 254 / var(--tw-text-opacity, 1))}.text-blue-50{--tw-text-opacity: 1;color:rgb(239 246 255 / var(--tw-text-opacity, 1))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity, 1))}.text-blue-700{--tw-text-opacity: 1;color:rgb(29 78 216 / var(--tw-text-opacity, 1))}.text-blue-800{--tw-text-opacity: 1;color:rgb(30 64 175 / var(--tw-text-opacity, 1))}.text-blue-900{--tw-text-opacity: 1;color:rgb(30 58 138 / var(--tw-text-opacity, 1))}.text-card-foreground{color:hsl(var(--card-foreground))}.text-chart-2{color:hsl(var(--chart-2))}.text-current{color:currentColor}.text-destructive{color:hsl(var(--destructive))}.text-destructive-foreground{color:hsl(var(--destructive-foreground))}.text-foreground{color:hsl(var(--foreground))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / 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-500{--tw-text-opacity: 1;color:rgb(34 197 94 / var(--tw-text-opacity, 1))}.text-green-600{--tw-text-opacity: 1;color:rgb(22 163 74 / var(--tw-text-opacity, 1))}.text-green-700{--tw-text-opacity: 1;color:rgb(21 128 61 / var(--tw-text-opacity, 1))}.text-green-800{--tw-text-opacity: 1;color:rgb(22 101 52 / var(--tw-text-opacity, 1))}.text-green-900{--tw-text-opacity: 1;color:rgb(20 83 45 / var(--tw-text-opacity, 1))}.text-muted-foreground{color:hsl(var(--muted-foreground))}.text-orange-600{--tw-text-opacity: 1;color:rgb(234 88 12 / var(--tw-text-opacity, 1))}.text-popover-foreground{color:hsl(var(--popover-foreground))}.text-primary{color:hsl(var(--primary))}.text-primary-foreground{color:hsl(var(--primary-foreground))}.text-primary-foreground\/80{color:hsl(var(--primary-foreground) / .8)}.text-purple-600{--tw-text-opacity: 1;color:rgb(147 51 234 / var(--tw-text-opacity, 1))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity, 1))}.text-red-600{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.text-red-700{--tw-text-opacity: 1;color:rgb(185 28 28 / var(--tw-text-opacity, 1))}.text-red-800{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.text-secondary-foreground{color:hsl(var(--secondary-foreground))}.text-slate-600{--tw-text-opacity: 1;color:rgb(71 85 105 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/80{color:#fffc}.text-yellow-200{--tw-text-opacity: 1;color:rgb(254 240 138 / var(--tw-text-opacity, 1))}.text-yellow-500{--tw-text-opacity: 1;color:rgb(234 179 8 / var(--tw-text-opacity, 1))}.text-yellow-600{--tw-text-opacity: 1;color:rgb(202 138 4 / var(--tw-text-opacity, 1))}.underline-offset-4{text-underline-offset:4px}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-20{opacity:.2}.opacity-50{opacity:.5}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.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)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--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(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-chart-2\/50{--tw-ring-color: hsl(var(--chart-2) / .5)}.ring-chart-4\/50{--tw-ring-color: hsl(var(--chart-4) / .5)}.ring-primary\/20{--tw-ring-color: hsl(var(--primary) / .2)}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.grayscale{--tw-grayscale: grayscale(100%);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)}.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-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-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-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.animate-fade-in{animation:fadeIn .2s ease-out}.animate-slide-in-from-bottom{animation:slideInFromBottom .3s ease-out}.animate-slide-in-from-top{animation:slideInFromTop .3s ease-out}.animate-slide-in-from-left{animation:slideInFromLeft .3s ease-out}.animate-slide-in-from-right{animation:slideInFromRight .3s ease-out}.animate-in{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}.slide-in-from-top-2{animation:slideInFromTopSmall .2s ease-out}@media(max-width:768px){body{font-size:14px}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem}h5{font-size:1rem}h6{font-size:.9rem}button{min-height:44px;min-width:44px}input,textarea,select{font-size:16px}}@media(max-width:480px){body{font-size:13px}h1{font-size:1.5rem}h2{font-size:1.35rem}h3{font-size:1.15rem}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInFromBottom{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInFromTop{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInFromTopSmall{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.file\:border-0::file-selector-button{border-width:0px}.file\:bg-transparent::file-selector-button{background-color:transparent}.file\:text-sm::file-selector-button{font-size:.875rem;line-height:1.25rem}.file\:font-medium::file-selector-button{font-weight:500}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.hover\:border-chart-2:hover{border-color:hsl(var(--chart-2))}.hover\:border-chart-4:hover{border-color:hsl(var(--chart-4))}.hover\:border-primary:hover{border-color:hsl(var(--primary))}.hover\:border-primary\/50:hover{border-color:hsl(var(--primary) / .5)}.hover\:bg-accent:hover{background-color:hsl(var(--accent))}.hover\:bg-background:hover{background-color:hsl(var(--background))}.hover\:bg-blue-100:hover{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-50:hover{--tw-bg-opacity: 1;background-color:rgb(239 246 255 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity, 1))}.hover\:bg-destructive\/80:hover{background-color:hsl(var(--destructive) / .8)}.hover\:bg-destructive\/90:hover{background-color:hsl(var(--destructive) / .9)}.hover\:bg-gray-100:hover{--tw-bg-opacity: 1;background-color:rgb(243 244 246 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-400:hover{--tw-bg-opacity: 1;background-color:rgb(156 163 175 / 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-muted:hover{background-color:hsl(var(--muted))}.hover\:bg-muted\/30:hover{background-color:hsl(var(--muted) / .3)}.hover\:bg-muted\/50:hover{background-color:hsl(var(--muted) / .5)}.hover\:bg-muted\/80:hover{background-color:hsl(var(--muted) / .8)}.hover\:bg-primary\/10:hover{background-color:hsl(var(--primary) / .1)}.hover\:bg-primary\/20:hover{background-color:hsl(var(--primary) / .2)}.hover\:bg-primary\/80:hover{background-color:hsl(var(--primary) / .8)}.hover\:bg-primary\/90:hover{background-color:hsl(var(--primary) / .9)}.hover\:bg-red-700:hover{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity, 1))}.hover\:bg-secondary\/80:hover{background-color:hsl(var(--secondary) / .8)}.hover\:bg-white\/20:hover{background-color:#fff3}.hover\:text-accent-foreground:hover{color:hsl(var(--accent-foreground))}.hover\:text-destructive:hover{color:hsl(var(--destructive))}.hover\:text-foreground:hover{color:hsl(var(--foreground))}.hover\:text-gray-900:hover{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.hover\:text-primary:hover{color:hsl(var(--primary))}.hover\:text-red-800:hover{--tw-text-opacity: 1;color:rgb(153 27 27 / var(--tw-text-opacity, 1))}.hover\:text-slate-900:hover{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{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)}.hover\:shadow-md:hover{--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)}.focus\:border-transparent:focus{border-color:transparent}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-0: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(0px + 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-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity, 1))}.focus\:ring-primary:focus{--tw-ring-color: hsl(var(--primary))}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus-visible\:border-ring:focus-visible{border-color:hsl(var(--ring))}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(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-visible\:ring-\[3px\]:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color: hsl(var(--ring) / .5)}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:scale-105{--tw-scale-x: 1.05;--tw-scale-y: 1.05;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\:scale-110{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.group:hover .group-hover\:text-primary{color:hsl(var(--primary))}.group:hover .group-hover\:opacity-100{opacity:1}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-left:.625rem;padding-right:.625rem}.has-\[\>svg\]\:px-3:has(>svg){padding-left:.75rem;padding-right:.75rem}.has-\[\>svg\]\:px-4:has(>svg){padding-left:1rem;padding-right:1rem}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;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))}.data-\[side\=left\]\:-translate-x-1[data-side=left]{--tw-translate-x: -.25rem;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))}.data-\[side\=right\]\:translate-x-1[data-side=right]{--tw-translate-x: .25rem;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))}.data-\[side\=top\]\:-translate-y-1[data-side=top]{--tw-translate-y: -.25rem;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))}.data-\[state\=checked\]\:border-primary[data-state=checked]{border-color:hsl(var(--primary))}.data-\[state\=active\]\:bg-background[data-state=active]{background-color:hsl(var(--background))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=active\]\:text-foreground[data-state=active]{color:hsl(var(--foreground))}.data-\[state\=checked\]\:text-primary-foreground[data-state=checked]{color:hsl(var(--primary-foreground))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}.data-\[state\=active\]\:shadow[data-state=active]{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.data-\[state\=open\]\:animate-in[data-state=open]{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}.data-\[side\=bottom\]\:slide-in-from-top-2[data-side=bottom]{animation:slideInFromTopSmall .2s ease-out}.dark\:bg-blue-900\/30:is(.dark *){background-color:#1e3a8a4d}.dark\:bg-green-900\/30:is(.dark *){background-color:#14532d4d}.dark\:bg-red-900\/30:is(.dark *){background-color:#7f1d1d4d}.dark\:text-blue-400:is(.dark *){--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.dark\:text-green-400:is(.dark *){--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.dark\:text-red-400:is(.dark *){--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}@media(min-width:640px){.sm\:mb-12{margin-bottom:3rem}.sm\:mb-4{margin-bottom:1rem}.sm\:mb-6{margin-bottom:1.5rem}.sm\:mb-8{margin-bottom:2rem}.sm\:mr-auto{margin-right:auto}.sm\:block{display:block}.sm\:inline{display:inline}.sm\:flex{display:flex}.sm\:h-12{height:3rem}.sm\:h-6{height:1.5rem}.sm\:w-12{width:3rem}.sm\:w-6{width:1.5rem}.sm\:w-80{width:20rem}.sm\:w-auto{width:auto}.sm\:max-w-lg{max-width:32rem}.sm\:max-w-md{max-width:28rem}.sm\:max-w-sm{max-width:24rem}.sm\:flex-shrink-0{flex-shrink:0}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-end{justify-content:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:gap-0{gap:0px}.sm\:gap-3{gap:.75rem}.sm\:gap-4{gap:1rem}.sm\:gap-6{gap:1.5rem}.sm\:space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.sm\:p-2{padding:.5rem}.sm\:p-6{padding:1.5rem}.sm\:px-0{padding-left:0;padding-right:0}.sm\:px-4{padding-left:1rem;padding-right:1rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-16{padding-top:4rem;padding-bottom:4rem}.sm\:py-4{padding-top:1rem;padding-bottom:1rem}.sm\:pb-16{padding-bottom:4rem}.sm\:pb-4{padding-bottom:1rem}.sm\:pt-16{padding-top:4rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-base{font-size:1rem;line-height:1.5rem}.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media(min-width:768px){.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:p-8{padding:2rem}}@media(min-width:1024px){.lg\:static{position:static}.lg\:inset-y-0{top:0;bottom:0}.lg\:z-auto{z-index:auto}.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:block{display:block}.lg\:inline{display:inline}.lg\:hidden{display:none}.lg\:translate-x-0{--tw-translate-x: 0px;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))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:gap-8{gap:2rem}.lg\:p-12{padding:3rem}.lg\:p-8{padding:2rem}.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:py-20{padding-top:5rem;padding-bottom:5rem}.lg\:pt-20{padding-top:5rem}.lg\:text-4xl{font-size:2.25rem;line-height:2.5rem}.lg\:text-5xl{font-size:3rem;line-height:1}.lg\:text-6xl{font-size:3.75rem;line-height:1}.lg\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media(min-width:1280px){.xl\:text-6xl{font-size:3.75rem;line-height:1}}.\[\&\>span\]\:line-clamp-1>span{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:1rem;height:1rem}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.user-dashboard{padding:20px;max-width:1400px;margin:0 auto;min-height:100vh;background:#f8f9fa}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.user-welcome h1{margin:0 0 4px;color:#333;font-size:28px;font-weight:700}.user-welcome p{margin:0;color:#666;font-size:16px}.logout-button{background:#dc3545;color:#fff;border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.logout-button:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 4px 12px #dc35454d}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:16px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:20px}.dashboard-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px}.card-icon{background:#fff3;padding:8px;border-radius:6px}.card-header h3{margin:0;font-size:16px;font-weight:600}.card-content{padding:20px}.profile-info{display:flex;flex-direction:column;gap:16px}.info-item{display:flex;justify-content:space-between;align-items:center;padding-bottom:12px;border-bottom:1px solid #f1f3f4}.info-item:last-child{border-bottom:none;padding-bottom:0}.info-item label{font-weight:600;color:#333;font-size:14px}.info-item span{color:#666;font-size:14px}.provider-badge{color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive,.status-badge.blocked{background:#f8d7da;color:#721c24}.roles-list{display:flex;flex-direction:column;gap:12px}.role-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.role-icon{background:#667eea;color:#fff;padding:8px;border-radius:6px;display:flex;align-items:center;justify-content:center}.role-info{flex:1;display:flex;flex-direction:column;gap:2px}.role-name{font-weight:600;color:#333;font-size:14px}.role-location{font-size:12px;color:#666}.role-doctor{font-size:11px;color:#999;font-style:italic}.role-badge{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.role-badge.global{background:#fff3cd;color:#856404}.role-badge.clinic{background:#d1ecf1;color:#0c5460}.no-roles,.no-clinics{text-align:center;color:#666;font-style:italic;padding:20px 0}.clinics-list{display:flex;flex-direction:column;gap:8px}.clinic-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#f8f9fa;border-radius:6px}.clinic-icon{color:#667eea}.clinic-info{display:flex;flex-direction:column;gap:2px}.clinic-code{font-weight:600;color:#333;font-size:14px}.clinic-external{font-size:12px;color:#666}.session-info{display:flex;flex-direction:column;gap:12px}.actions-list{display:flex;flex-direction:column;gap:8px}.action-button{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;color:#495057;transition:all .2s ease;text-align:left;width:100%}.action-button:hover{background:#e9ecef;border-color:#dee2e6}.action-button.admin{background:#fff3cd;border-color:#ffeaa7;color:#856404}.action-button.admin:hover{background:#ffeaa7;border-color:#fed7aa}.action-button.danger{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.action-button.danger:hover{background:#f5c6cb;border-color:#f1b0b7}.permissions-grid{display:grid;grid-template-columns:1fr;gap:8px}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f8f9fa;border-radius:6px}.permission-label{font-size:14px;color:#333;font-weight:500}.permission-status{font-size:12px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase}.permission-status.granted{background:#d4edda;color:#155724}.permission-status.denied{background:#f8d7da;color:#721c24}.loading-spinner{width:24px;height:24px;border:2px solid rgba(102,126,234,.3);border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@media(max-width:1200px){.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}@media(max-width:768px){.user-dashboard{padding:10px}.dashboard-header{flex-direction:column;gap:16px;text-align:center}.dashboard-grid{grid-template-columns:1fr;gap:16px}.card-content{padding:16px}.role-item{flex-direction:column;text-align:center;gap:8px}.role-info{text-align:center}.info-item{flex-direction:column;gap:4px;text-align:center}}.temp-layout{display:flex;flex-direction:column;height:100vh;background-color:#f8fafc}.temp-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:0 2rem;box-shadow:0 4px 6px #0000001a}.temp-header-content{display:flex;justify-content:space-between;align-items:center;height:70px;max-width:1400px;margin:0 auto}.temp-header-left{display:flex;align-items:center;gap:1rem}.temp-header h1{font-size:1.5rem;font-weight:600;margin:0}.temp-badge{background-color:#ffffff40;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.temp-header-right{display:flex;align-items:center;gap:1rem}.temp-clock-display{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:1.1rem;font-weight:500;color:#fff;background-color:#ffffff26;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.3);min-width:80px;text-align:center;letter-spacing:.5px}.temp-expiry{display:flex;align-items:center;gap:.5rem;background-color:#ffffff26;padding:.5rem 1rem;border-radius:8px;border:1px solid rgba(255,255,255,.3);transition:all .3s ease}.temp-expiry.expiring-soon{background-color:#ef444433;border-color:#ef444480;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.expiry-details{display:flex;flex-direction:column;gap:2px}.expiry-label{font-size:.7rem;color:#fffc;text-transform:uppercase;letter-spacing:.5px}.expiry-time{font-size:.95rem;font-weight:600;color:#fff;font-family:Courier New,monospace}.upgrade-btn{background-color:#10b981;border:none;color:#fff;border-radius:8px;padding:.6rem 1.2rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;font-weight:500;font-size:.9rem}.upgrade-btn:hover{background-color:#059669;transform:translateY(-1px);box-shadow:0 4px 6px #0003}.temp-logout-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:8px;padding:.6rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.temp-logout-btn:hover{background:#ffffff40;border-color:#ffffff80}.temp-warning-banner{background-color:#fef3c7;border-bottom:2px solid #f59e0b;color:#92400e;padding:.75rem 2rem;display:flex;align-items:center;gap:.75rem;font-size:.9rem;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.temp-content{flex:1;padding:2rem;overflow-y:auto;background-color:#f8fafc}@media(max-width:768px){.temp-header-content{flex-direction:column;height:auto;padding:1rem 0;gap:1rem}.temp-header-right{flex-wrap:wrap;justify-content:center}.temp-content{padding:1rem}}.audit-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.audit-modal{background:#fff;border-radius:12px;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a}.audit-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px;border-bottom:1px solid #e5e7eb}.audit-modal-header h2{font-size:20px;font-weight:600;color:#1f2937;margin:0 0 4px}.document-name{font-size:14px;color:#6b7280;margin:0}.close-btn{padding:8px;background:none;border:none;cursor:pointer;color:#6b7280;border-radius:6px;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#1f2937}.audit-modal-content{flex:1;overflow-y:auto;padding:24px}.audit-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.audit-loading p{margin:0;font-size:14px;font-weight:500}.audit-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.audit-error p{font-size:16px;font-weight:600;color:#dc2626;margin:0 0 8px}.error-details{font-size:14px;color:#6b7280}.audit-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#9ca3af}.audit-empty svg{margin-bottom:16px;opacity:.5}.audit-empty p{font-size:16px;font-weight:600;color:#6b7280;margin:0 0 8px}.audit-empty span{font-size:14px;color:#9ca3af}.audit-timeline{display:flex;flex-direction:column;gap:0}.audit-entry{display:flex;gap:16px;position:relative}.entry-marker{display:flex;flex-direction:column;align-items:center;padding-top:4px}.action-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#f3f4f6;color:#6b7280;flex-shrink:0;padding:6px}.action-icon.upload{background:#dbeafe;color:#2563eb}.action-icon.download{background:#d1fae5;color:#059669}.action-icon.view{background:#fef3c7;color:#d97706}.action-icon.update{background:#e0e7ff;color:#6366f1}.action-icon.delete{background:#fee2e2;color:#dc2626}.action-icon.share{background:#e9d5ff;color:#9333ea}.entry-line{width:2px;flex:1;background:#e5e7eb;margin-top:8px;min-height:20px}.entry-content{flex:1;padding-bottom:24px}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:16px}.entry-action{font-size:15px;font-weight:600;color:#1f2937}.entry-time{display:flex;align-items:center;gap:6px;font-size:13px;color:#6b7280;white-space:nowrap}.entry-time svg{flex-shrink:0}.entry-details{font-size:14px;color:#4b5563;margin-bottom:12px;line-height:1.5}.entry-meta{display:flex;flex-wrap:wrap;gap:16px;font-size:13px}.meta-item{display:flex;align-items:center;gap:6px;color:#6b7280}.meta-item svg{flex-shrink:0;color:#9ca3af}.user-agent{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-modal-footer{padding:16px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px}@media(max-width:768px){.audit-modal{max-height:95vh}.audit-modal-header,.audit-modal-content{padding:20px}.entry-header{flex-direction:column;align-items:flex-start;gap:4px}.entry-time{font-size:12px}.entry-meta{gap:12px}.meta-item{font-size:12px}}.metadata-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;padding:1rem}.metadata-modal{background:#fff;border-radius:.5rem;box-shadow:0 10px 25px #0000001a;width:100%;max-width:42rem;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.metadata-modal-header{border-bottom:1px solid #e5e7eb;padding:1.5rem;flex-shrink:0}.metadata-modal-content{overflow-y:auto;padding:1.5rem;flex:1}.metadata-modal-footer{border-top:1px solid #e5e7eb;padding:1.5rem;flex-shrink:0;display:flex;justify-content:flex-end;gap:.75rem}.metadata-form-field{margin-bottom:1.5rem}.metadata-form-field label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem}.metadata-form-field input,.metadata-form-field select,.metadata-form-field textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;transition:border-color .2s}.metadata-form-field input:focus,.metadata-form-field select:focus,.metadata-form-field textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.metadata-readonly{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.tag-input-wrapper{display:flex;gap:.5rem}.tag-input-wrapper input{flex:1}.tags-container{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.metadata-grid{display:grid;grid-template-columns:1fr;gap:1rem}@media(min-width:768px){.metadata-grid{grid-template-columns:1fr 1fr}}.pdf-viewer-container{display:flex;flex-direction:column;height:100%;background-color:#f3f4f6}.pdf-controls{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:#fff;border-bottom:1px solid #e5e7eb;gap:16px;flex-wrap:wrap}.pdf-navigation,.pdf-zoom{display:flex;align-items:center;gap:12px}.control-btn{background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:8px 12px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;color:#374151;font-size:14px;font-weight:500}.control-btn:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.control-btn:disabled{opacity:.4;cursor:not-allowed}.download-btn{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.download-btn:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}.page-info,.zoom-level{font-size:14px;color:#6b7280;font-weight:500;min-width:100px;text-align:center}.zoom-level{min-width:60px}.pdf-document-wrapper{flex:1;overflow:auto;display:flex;justify-content:center;align-items:flex-start;padding:20px}.react-pdf__Document{display:flex;flex-direction:column;align-items:center}.pdf-page{box-shadow:0 4px 12px #0000001a;margin-bottom:20px;background:#fff}.react-pdf__Page__canvas{max-width:100%;height:auto!important}.react-pdf__Page__textContent,.react-pdf__Page__annotations{max-width:100%}.pdf-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.pdf-loading p{margin:0;font-size:14px;font-weight:500}.pdf-viewer-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#991b1b;background-color:#fee2e2;border-radius:8px;margin:20px}.pdf-viewer-error p{margin:0 0 16px;font-size:14px;font-weight:500}@media(max-width:768px){.pdf-controls{flex-direction:column;gap:12px}.pdf-navigation,.pdf-zoom{width:100%;justify-content:space-between}.control-btn{flex:1;justify-content:center}.page-info,.zoom-level{min-width:auto;flex:1}}.document-preview-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.document-preview-modal{background:#fff;border-radius:12px;width:100%;max-width:1400px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.header-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.header-info h2{font-size:18px;font-weight:600;color:#1f2937;margin:0;word-break:break-word}.category-badge{padding:4px 12px;background:#dbeafe;color:#1e40af;border-radius:6px;font-size:13px;font-weight:500;white-space:nowrap}.header-actions{display:flex;gap:8px}.action-btn{padding:8px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;color:#6b7280;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:#f9fafb;border-color:#d1d5db}.action-btn.delete:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.action-btn.close{background:transparent;border:none}.action-btn.close:hover{background:#f3f4f6}.preview-content{display:flex;flex:1;overflow:hidden;position:relative}.document-viewer{flex:1;overflow:auto;background:#f9fafb;display:flex;align-items:center;justify-content:center;padding:24px}.image-viewer{width:100%;height:100%;display:flex;flex-direction:column;gap:16px}.image-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.image-controls button{padding:8px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;color:#374151;font-size:14px;font-weight:500}.image-controls button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.image-controls button:disabled{opacity:.4;cursor:not-allowed}.image-controls .zoom-level{font-size:14px;color:#6b7280;font-weight:500;min-width:60px;text-align:center}.image-container{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:#f9fafb;border-radius:8px}.image-container img{max-width:100%;height:auto;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;transition:transform .2s ease}.pdf-viewer{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.pdf-iframe{width:100%;height:100%;border:none}.pdf-placeholder{text-align:center;padding:40px;background:#fff;border-radius:12px;border:2px dashed #d1d5db;max-width:500px}.pdf-placeholder p{font-size:18px;font-weight:600;color:#374151;margin-bottom:8px}.pdf-info{font-size:14px;color:#6b7280;margin-bottom:16px;word-break:break-word}.pdf-fallback{text-align:center;padding:60px 40px;background:#f9fafb;border-radius:12px;border:2px dashed #d1d5db;max-width:500px;margin:40px auto}.pdf-fallback p{font-size:18px;font-weight:600;color:#374151;margin-bottom:8px}.pdf-fallback .pdf-filename{font-size:14px;color:#6b7280;margin-bottom:24px;word-break:break-word;font-weight:400}.pdf-fallback .btn-primary{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.pdf-fallback .btn-primary:hover{background:#2563eb}.pdf-note{font-size:13px;color:#9ca3af;margin-bottom:24px;font-style:italic}.btn-primary{padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:background .2s}.unsupported-viewer{text-align:center;padding:40px}.unsupported-viewer p{font-size:16px;color:#6b7280;margin-bottom:24px}.details-sidebar{width:350px;background:#fff;border-left:1px solid #e5e7eb;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb}.sidebar-header h3{font-size:16px;font-weight:600;color:#1f2937;margin:0}.toggle-btn{padding:4px;background:none;border:none;cursor:pointer;color:#6b7280;border-radius:4px;transition:all .2s}.toggle-btn:hover{background:#f3f4f6}.details-content{flex:1;overflow-y:auto;padding:20px}.detail-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #f3f4f6}.detail-section:last-child{border-bottom:none}.detail-section h4{font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}.detail-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:14px}.detail-item .label{color:#6b7280;font-weight:500;min-width:60px}.detail-item .value{color:#1f2937;word-break:break-word}.detail-item svg{color:#9ca3af;flex-shrink:0}.category-display{padding:8px 12px;background:#dbeafe;color:#1e40af;border-radius:6px;font-size:14px;font-weight:500;display:inline-block}.tags-display{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.tags-display svg{color:#9ca3af}.tags-display .tag{padding:4px 8px;background:#f3f4f6;border-radius:4px;font-size:13px;color:#4b5563}.version-list{display:flex;flex-direction:column;gap:12px}.version-item{padding:12px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb;position:relative}.version-item.current{background:#eff6ff;border-color:#bfdbfe}.version-info{display:flex;align-items:center;gap:8px;margin-bottom:8px}.version-number{font-size:14px;font-weight:600;color:#1f2937}.version-badge{padding:2px 6px;background:#3b82f6;color:#fff;border-radius:3px;font-size:11px;font-weight:500}.version-details{display:flex;flex-direction:column;gap:4px;font-size:13px}.version-date{color:#6b7280}.version-author{color:#6b7280;font-size:12px}.version-description{color:#374151;font-style:italic;margin-top:4px}.version-size{color:#9ca3af;font-size:12px}.version-download-btn{position:absolute;top:12px;right:12px;padding:6px 8px;background:#fff;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;color:#374151;transition:all .2s;display:flex;align-items:center;gap:4px}.version-download-btn:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.version-loading{text-align:center;padding:20px;color:#6b7280;font-size:14px}.no-versions{text-align:center;padding:20px;color:#6b7280}.no-versions p{margin:0;font-size:14px}.sharing-info{padding:12px;background:#f9fafb;border-radius:6px}.no-shares{font-size:14px;color:#6b7280;margin:0 0 12px}.shares-summary{display:flex;flex-direction:column;gap:12px}.shares-summary p{font-size:14px;color:#1f2937;font-weight:500;margin:0}.btn-manage-sharing,.btn-share-doc{width:100%;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;color:#374151}.btn-manage-sharing:hover,.btn-share-doc:hover{background:#f9fafb;border-color:#d1d5db}.shares-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.share-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:6px;border:1px solid #e5e7eb}.share-user{display:flex;align-items:center;gap:8px;color:#374151;font-size:14px}.share-user .username{font-weight:500}.permission-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-transform:uppercase}.permission-badge.view{background:#dbeafe;color:#1e40af}.permission-badge.download{background:#d1fae5;color:#065f46}.permission-badge.edit{background:#fef3c7;color:#92400e}.btn-audit{width:100%;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;color:#374151}.btn-audit:hover{background:#f9fafb;border-color:#d1d5db}.show-details-btn{position:absolute;right:24px;top:24px;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px -1px #0000001a}.show-details-btn:hover{background:#f9fafb}@media(max-width:1024px){.details-sidebar{width:300px}}@media(max-width:768px){.document-preview-modal{max-height:100vh;border-radius:0}.preview-content{flex-direction:column}.details-sidebar{width:100%;max-height:40vh;border-left:none;border-top:1px solid #e5e7eb}.header-info h2{font-size:16px}.header-actions{gap:4px}.action-btn{padding:6px 10px}}.dashboard{max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h2{font-size:2rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.dashboard-header p{color:#64748b;font-size:1.1rem;margin:0}@media(max-width:768px){.dashboard-header h2{font-size:1.5rem}.dashboard-header p{font-size:1rem}.dashboard{padding:0}}@media(max-width:480px){.dashboard-header{margin-bottom:1.5rem}.dashboard-header h2{font-size:1.35rem}}.schedule{max-width:1400px;margin:0 auto}.schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-left h2{font-size:2rem;font-weight:700;color:#1e293b;margin:0 0 .5rem}.week-navigation{display:flex;align-items:center;gap:1rem}.nav-btn{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.nav-btn:hover{background-color:#f8fafc;border-color:#cbd5e1}.week-range{font-weight:600;color:#374151;font-size:1.1rem;min-width:200px;text-align:center}.header-actions{display:flex;gap:.75rem}.today-btn{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.5rem 1rem;cursor:pointer;font-weight:500;color:#374151;transition:all .2s ease}.today-btn:hover{background-color:#f8fafc;border-color:#cbd5e1}.new-appointment-btn{background-color:#3b82f6;color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;cursor:pointer;font-weight:500;display:flex;align-items:center;gap:.5rem;transition:background-color .2s ease}.schedule-grid{display:grid;grid-template-columns:80px repeat(7,1fr);gap:1px;background-color:#e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.time-column{background-color:#f8fafc}.time-header{height:60px;border-bottom:1px solid #e2e8f0}.time-slot{height:40px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#64748b;font-weight:500;background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.day-column{background-color:#fff}.day-header{height:60px;display:flex;flex-direction:column;align-items:center;justify-content:center;background-color:#f8fafc;border-bottom:1px solid #e2e8f0}.day-header.today{background-color:#eff6ff;color:#2563eb}.day-name{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:#64748b}.day-header.today .day-name{color:#2563eb}.day-number{font-size:1.5rem;font-weight:700;color:#1e293b}.day-header.today .day-number{color:#2563eb}.schedule-cell{height:40px;border-bottom:1px solid #f1f5f9;position:relative;background-color:#fff}.appointment-block{position:absolute;inset:2px;background-color:#3b82f6;color:#fff;border-radius:4px;padding:.25rem;font-size:.75rem;overflow:hidden;cursor:pointer;transition:all .2s ease}.appointment-block:hover{background-color:#2563eb;transform:scale(1.02);z-index:10}.appointment-patient{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}.appointment-type{font-size:.625rem;opacity:.9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appointment-time{position:absolute;top:.25rem;right:.25rem;font-size:.625rem;opacity:.8}@media(max-width:1024px){.schedule-grid{grid-template-columns:60px repeat(7,1fr)}.time-slot,.appointment-block{font-size:.625rem}}@media(max-width:768px){.schedule-header{flex-direction:column;align-items:stretch}.header-actions{justify-content:center}.schedule-grid{grid-template-columns:50px repeat(7,1fr)}.week-range{min-width:auto}}.appointments{max-width:1400px;margin:0 auto}.appointments-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.header-left h2{font-size:2rem;font-weight:700;color:#1e293b;margin:0 0 .25rem}.header-left p{color:#64748b;font-size:1.1rem;margin:0}.new-appointment-btn{background-color:#3b82f6;color:#fff;border:none;border-radius:8px;padding:.75rem 1.25rem;cursor:pointer;font-weight:500;display:flex;align-items:center;gap:.5rem;transition:background-color .2s ease}.new-appointment-btn:hover{background-color:#2563eb}.appointments-controls{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:center;flex-wrap:wrap}.search-bar{position:relative;flex:1;min-width:300px}.search-bar svg{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#64748b}.search-bar input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:1rem;transition:all .2s ease}.search-bar input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.filter-controls{display:flex;gap:.75rem}.status-filter{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;background:#fff;font-size:1rem;cursor:pointer;transition:border-color .2s ease}.status-filter:focus{outline:none;border-color:#3b82f6}.appointments-content{display:grid;grid-template-columns:1fr 350px;gap:1.5rem}.appointments-list{display:flex;flex-direction:column;gap:.75rem}.appointment-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .2s ease}.appointment-card:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000001a}.appointment-card.selected{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.appointment-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.appointment-patient{display:flex;align-items:center;gap:.5rem}.patient-name{font-weight:600;color:#1e293b;font-size:1.1rem}.appointment-datetime{display:flex;gap:1rem}.appointment-date,.appointments-list .appointment-card .appointment-time{position:static!important;top:auto!important;right:auto!important;display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#64748b}.appointment-details{display:flex;justify-content:space-between;align-items:center}.appointment-type{color:#374151;font-weight:500}.appointment-status{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.appointment-status.confirmed{background-color:#dcfce7;color:#166534}.appointment-status.pending{background-color:#fef3c7;color:#92400e}.appointment-status.urgent{background-color:#fecaca;color:#991b1b}.appointment-status.cancelled{background-color:#f3f4f6;color:#6b7280}.no-appointments{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:#6b7280}.no-appointments svg{color:#d1d5db;margin-bottom:1rem}.no-appointments h3{margin:0 0 .5rem;color:#374151}.no-appointments p{margin:0}.appointment-sidebar{background:#fff;border:1px solid #e2e8f0;border-radius:12px;height:-moz-fit-content;height:fit-content;overflow:hidden}.sidebar-header{padding:1.25rem;border-bottom:1px solid #e2e8f0;background-color:#f8fafc}.sidebar-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1e293b}.patient-info{padding:1.25rem;border-bottom:1px solid #f1f5f9}.patient-info h4{margin:0 0 .75rem;font-size:1.125rem;font-weight:600;color:#1e293b}.contact-info{display:flex;flex-direction:column;gap:.5rem}.contact-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#64748b}.appointment-info{padding:1.25rem;border-bottom:1px solid #f1f5f9}.info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.info-row:last-child{margin-bottom:0}.label{font-weight:500;color:#64748b}.status-badge{padding:.125rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:500;text-transform:capitalize}.status-badge.confirmed{background-color:#dcfce7;color:#166534}.status-badge.pending{background-color:#fef3c7;color:#92400e}.status-badge.urgent{background-color:#fecaca;color:#991b1b}.status-badge.cancelled{background-color:#f3f4f6;color:#6b7280}.appointment-notes{padding:1.25rem;border-bottom:1px solid #f1f5f9}.appointment-notes h5{margin:0 0 .5rem;font-weight:600;color:#1e293b}.appointment-notes p{margin:0;color:#64748b;line-height:1.5}.appointment-actions{padding:1.25rem;display:flex;flex-direction:column;gap:.5rem}.action-btn{padding:.5rem 1rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid}.action-btn.primary{background-color:#3b82f6;color:#fff;border-color:#3b82f6}.action-btn.primary:hover{background-color:#2563eb}.action-btn.secondary{background-color:#fff;color:#64748b;border-color:#e2e8f0}.action-btn.secondary:hover{background-color:#f8fafc;border-color:#cbd5e1}@media(max-width:1024px){.appointments-content{grid-template-columns:1fr}.appointment-sidebar{order:-1}}@media(max-width:768px){.appointments-controls{flex-direction:column}.search-bar{min-width:auto}.appointment-main{flex-direction:column;align-items:flex-start;gap:.5rem}.appointment-datetime{gap:.75rem}}@-webkit-keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{-webkit-box-sizing:border-box;box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{-ms-touch-action:none;touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{-ms-touch-action:none;touch-action:none}.ReactCrop__crop-mask{position:absolute;inset:0;pointer-events:none;width:calc(100% + .5px);height:calc(100% + .5px)}.ReactCrop__crop-selection{position:absolute;top:0;left:0;-webkit-transform:translateZ(0);transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;inset:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){-webkit-animation:marching-ants 1s;animation:marching-ants 1s;background-image:-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,right top,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444)),-webkit-gradient(linear,left top,left bottom,color-stop(50%,#fff),color-stop(50%,#444));background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;-webkit-animation-play-state:running;animation-play-state:running;-webkit-animation-timing-function:linear;animation-timing-function:linear;-webkit-animation-iteration-count:infinite;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;-webkit-transform:translate(50%,-50%);transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;-webkit-transform:translate(50%,50%);transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;-webkit-transform:translate(-50%,-50%);transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);-webkit-transform:translateY(-50%);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;-webkit-transform:translate(50%);transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);-webkit-transform:translateY(50%);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;-webkit-transform:translate(-50%);transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media(pointer:coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.photo-capture-modal{max-width:600px;max-height:90vh;width:100%;padding:0;overflow:hidden}.photo-capture-modal__header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #e5e7eb)}.photo-capture-modal__close-btn{background:none;border:none;cursor:pointer;padding:.5rem;color:var(--text-muted, #6b7280);border-radius:.375rem;transition:background-color .2s}.photo-capture-modal__close-btn:hover{background-color:var(--hover-bg, #f3f4f6)}.photo-capture-modal__content{padding:1.5rem;overflow-y:auto;max-height:calc(90vh - 100px)}.photo-capture-modal__processing{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem}.photo-capture-modal__processing p{color:var(--text-muted, #6b7280)}.photo-capture-modal__progress{width:200px;height:4px;background-color:var(--progress-bg, #e5e7eb);border-radius:2px;overflow:hidden}.photo-capture-modal__progress-bar{height:100%;background-color:var(--primary-color, #3b82f6);transition:width .3s ease}.camera-view{display:flex;flex-direction:column;gap:1rem}.camera-view__viewfinder{position:relative;width:100%;aspect-ratio:4/3;background-color:#000;border-radius:.5rem;overflow:hidden}.camera-view__viewfinder video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.camera-view__overlay{position:absolute;top:1rem;right:1rem;z-index:10}.camera-view__controls{display:flex;justify-content:center;align-items:center;gap:2rem;padding:1rem}.camera-view__capture-btn{width:72px;height:72px;border-radius:50%;border:4px solid var(--primary-color, #3b82f6);background-color:transparent;cursor:pointer;padding:4px;transition:transform .1s,border-color .2s}.camera-view__capture-btn:hover{transform:scale(1.05)}.camera-view__capture-btn:active{transform:scale(.95)}.camera-view__capture-btn:disabled{border-color:var(--disabled-color, #d1d5db);cursor:not-allowed}.camera-view__capture-btn-inner{width:100%;height:100%;border-radius:50%;background-color:var(--primary-color, #3b82f6);transition:background-color .2s}.camera-view__capture-btn:disabled .camera-view__capture-btn-inner{background-color:var(--disabled-color, #d1d5db)}.camera-view__switch-btn,.camera-view__placeholder{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center}.camera-view__switch-btn{background-color:var(--secondary-bg, #f3f4f6);border:none;cursor:pointer;color:var(--text-color, #374151);transition:background-color .2s}.camera-view__switch-btn:hover{background-color:var(--hover-bg, #e5e7eb)}.camera-view__placeholder{background:transparent}.camera-view__error,.camera-view__permission{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;gap:1rem;padding:2rem}.camera-view__error{color:var(--error-color, #ef4444)}.camera-view__permission{color:var(--text-muted, #6b7280)}.camera-view__error h3,.camera-view__permission h3{margin:0;font-size:1.125rem;font-weight:600}.camera-view__error p,.camera-view__permission p{margin:0;max-width:300px}.sharpness-indicator{display:flex;align-items:center;gap:.5rem}.sharpness-indicator__badge{display:flex;align-items:center;justify-content:center;background-color:var(--indicator-color);color:#fff;font-weight:600;border-radius:9999px;padding:.25rem .75rem}.sharpness-indicator__label{font-size:.875rem;color:var(--indicator-color);font-weight:500}.sharpness-indicator--sm .sharpness-indicator__badge{font-size:.625rem;padding:.125rem .375rem}.sharpness-indicator--md .sharpness-indicator__badge{font-size:.75rem;padding:.25rem .5rem}.sharpness-indicator--lg .sharpness-indicator__badge{font-size:.875rem;padding:.375rem .75rem}.photo-review{display:flex;flex-direction:column;gap:1rem}.photo-review__header{display:flex;align-items:center;gap:.5rem}.photo-review__header h3{margin:0;font-size:1rem;font-weight:600}.photo-review__count{background-color:var(--primary-color, #3b82f6);color:#fff;font-size:.75rem;font-weight:600;padding:.125rem .5rem;border-radius:9999px}.photo-review__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.photo-review__item{position:relative;aspect-ratio:4/3;border-radius:.5rem;overflow:hidden;border:2px solid transparent}.photo-review__item--blurry{border-color:var(--error-color, #ef4444)}.photo-review__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.photo-review__sharpness{position:absolute;top:.5rem;left:.5rem}.photo-review__actions{position:absolute;top:.5rem;right:.5rem;display:flex;gap:.25rem}.photo-review__action-btn{width:28px;height:28px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .1s,background-color .2s}.photo-review__action-btn:hover{transform:scale(1.1)}.photo-review__action-btn--remove{background-color:var(--error-color, #ef4444);color:#fff}.photo-review__action-btn--edit{background-color:var(--primary-color, #3b82f6);color:#fff}.photo-review__warning{position:absolute;bottom:0;left:0;right:0;background-color:#ef4444e6;color:#fff;font-size:.625rem;padding:.25rem;text-align:center}.photo-review__add-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;aspect-ratio:4/3;border:2px dashed var(--border-color, #d1d5db);border-radius:.5rem;background:none;cursor:pointer;color:var(--text-muted, #6b7280);transition:border-color .2s,color .2s}.photo-review__add-btn:hover{border-color:var(--primary-color, #3b82f6);color:var(--primary-color, #3b82f6)}.photo-review__add-btn span{font-size:.75rem}.photo-review__footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-color, #e5e7eb)}.photo-editor{display:flex;flex-direction:column;gap:1rem}.photo-editor__header h3{margin:0;font-size:1rem;font-weight:600}.photo-editor__cropper{display:flex;justify-content:center;align-items:center;width:100%;min-height:200px;max-height:400px;background-color:#f3f4f6;border-radius:.5rem;overflow:auto;padding:1rem}.photo-editor__react-crop{max-width:100%}.photo-editor__react-crop img{display:block}.photo-editor__controls{display:flex;justify-content:center;align-items:center;gap:1rem}.photo-editor__control-btn{display:inline-flex;padding:.5rem 1rem;border-radius:.375rem;border:1px solid var(--border-color, #d1d5db);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-color, #374151);transition:all .2s}.photo-editor__control-btn:hover:not(:disabled){border-color:var(--primary-color, #3b82f6);color:var(--primary-color, #3b82f6)}.photo-editor__control-btn:disabled{opacity:.5;cursor:not-allowed}.photo-editor__footer{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--border-color, #e5e7eb)}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background-color:var(--primary-color, #3b82f6);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover, #2563eb)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background-color:var(--secondary-bg, #f3f4f6);color:var(--text-color, #374151);border:1px solid var(--border-color, #d1d5db)}.btn-secondary:hover:not(:disabled){background-color:var(--hover-bg, #e5e7eb)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.animate-spin{animation:spin 1s linear infinite}@media(max-width:768px){.photo-capture-modal{max-width:100vw;max-height:100vh;width:100vw;height:100vh;border-radius:0;margin:0}.photo-capture-modal__content{max-height:calc(100vh - 60px);padding:1rem}.camera-view__viewfinder{aspect-ratio:auto;height:calc(100vh - 250px);min-height:300px}.camera-view__capture-btn{width:80px;height:80px}.photo-review__grid{grid-template-columns:repeat(2,1fr)}.photo-editor__cropper{max-height:calc(100vh - 350px);min-height:200px}}@media(max-width:480px){.photo-review__grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.photo-review__footer,.photo-editor__footer{flex-direction:column}.photo-review__footer button,.photo-editor__footer button{width:100%;justify-content:center}}.document-upload{max-width:900px;margin:0 auto;padding:20px}.upload-header{margin-bottom:24px}.upload-header h2{font-size:24px;font-weight:600;margin-bottom:8px;color:#1f2937}.upload-header p{color:#6b7280;font-size:14px}.drop-zone{border:2px dashed #d1d5db;border-radius:12px;padding:48px 24px;text-align:center;cursor:pointer;transition:all .2s;background:#f9fafb}.drop-zone:hover,.drop-zone.active{border-color:#3b82f6;background:#eff6ff}.drop-zone svg{color:#9ca3af;margin:0 auto 16px}.drop-zone.active svg{color:#3b82f6}.drop-zone-title{font-size:16px;font-weight:500;color:#374151;margin-bottom:4px}.drop-zone-subtitle{font-size:14px;color:#6b7280}.camera-capture-btn{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.camera-capture-btn:hover{background:#2563eb;transform:translateY(-1px)}.camera-capture-btn:active{transform:translateY(0)}.camera-capture-btn svg{color:#fff;margin:0}.selected-files{margin-top:32px}.selected-files h3{font-size:18px;font-weight:600;margin-bottom:16px;color:#1f2937}.file-item{display:flex;gap:16px;padding:16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:12px}.file-preview{flex-shrink:0;width:80px;height:80px;border-radius:6px;overflow:hidden;background:#f3f4f6;display:flex;align-items:center;justify-content:center}.file-preview img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.file-preview svg{color:#9ca3af}.file-details{flex:1}.file-header{display:flex;justify-content:space-between;align-items:start;margin-bottom:8px}.file-header h4{font-size:14px;font-weight:500;color:#1f2937;word-break:break-all;margin-right:8px}.remove-btn{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;transition:color .2s;flex-shrink:0}.remove-btn:hover{color:#ef4444}.file-size{font-size:12px;color:#6b7280;margin-bottom:12px}.file-errors{margin-bottom:12px}.error-message{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;font-size:13px;color:#dc2626;margin-bottom:4px}.error-message svg{flex-shrink:0}.metadata-field{margin-bottom:12px}.metadata-field label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.metadata-field select{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;color:#1f2937;background:#fff}.metadata-field select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tags-container{display:flex;flex-wrap:wrap;gap:6px;padding:8px;border:1px solid #d1d5db;border-radius:6px;background:#fff;min-height:40px}.tags-container:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:4px;font-size:13px;color:#1e40af}.tag button{background:none;border:none;cursor:pointer;padding:0;color:#3b82f6;display:flex;align-items:center}.tag button:hover{color:#1e40af}.tags-container input{flex:1;border:none;outline:none;padding:4px;font-size:13px;min-width:120px}.progress-bar{position:relative;height:24px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-top:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);transition:width .3s}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.1)}.upload-actions{display:flex;gap:12px;margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background:#f9fafb}.file-header-actions{display:flex;align-items:center;gap:8px}.status-success{color:#10b981}.status-error{color:#ef4444}.status-message{padding:6px 10px;border-radius:4px;font-size:13px;margin-bottom:8px}.status-message.success{background:#d1fae5;color:#065f46}.status-message.error{background:#fee2e2;color:#991b1b}.status-message.info{background:#dbeafe;color:#1e40af}.drop-zone.disabled{opacity:.6;cursor:not-allowed}.shared-indicator{font-size:12px;color:#6366f1;padding:4px 8px;background:#eef2ff;border-radius:4px;display:inline-block;margin-top:8px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.spinner{animation:spin 1s linear infinite;color:#3b82f6}.error-message{color:#dc2626;margin-bottom:16px}.meta-item.version{background:#f3f4f6;padding:2px 6px;border-radius:3px;font-weight:500}@media(max-width:1024px){.document-upload{max-width:100%;padding:16px}}@media(max-width:768px){.document-upload{padding:12px}.upload-header h2{font-size:20px}.upload-header p{font-size:13px}.drop-zone{padding:36px 16px}.drop-zone-title{font-size:15px}.drop-zone-subtitle{font-size:13px}.file-item{flex-direction:column;padding:12px}.file-preview{width:100%;max-width:120px;height:120px;align-self:center}.file-header{flex-direction:column;align-items:flex-start;gap:8px}.file-header-actions{width:100%;justify-content:space-between}.upload-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center;padding:12px}.selected-files h3{font-size:16px}}@media(max-width:480px){.upload-header{margin-bottom:20px}.upload-header h2{font-size:18px}.drop-zone{padding:24px 12px}.file-item{padding:10px}.file-preview{max-width:100px;height:100px}.metadata-field label{font-size:12px}.tags-container{padding:6px}.tag{font-size:12px;padding:3px 6px}.tags-container input{font-size:12px;min-width:80px}}.admin-notifications{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.notification-stats{display:flex;gap:16px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.stat-mini{flex:1;display:flex;flex-direction:column;align-items:center;padding:16px;background:#f9fafb;border-radius:8px}.stat-mini-value{font-size:24px;font-weight:700;color:#1f2937}.stat-mini-label{font-size:12px;color:#6b7280;margin-top:4px}.stat-mini.stat-pending{background:#fef3c7}.stat-mini.stat-pending .stat-mini-value{color:#d97706}.stat-mini.stat-sent{background:#dbeafe}.stat-mini.stat-sent .stat-mini-value{color:#2563eb}.stat-mini.stat-delivered{background:#d1fae5}.stat-mini.stat-delivered .stat-mini-value{color:#059669}.stat-mini.stat-failed{background:#fee2e2}.stat-mini.stat-failed .stat-mini-value{color:#dc2626}.sub-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:2px solid #e5e7eb;padding-bottom:0}.sub-tab-button{display:flex;align-items:center;gap:6px;padding:10px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;position:relative;bottom:-2px}.sub-tab-button:hover{color:#3b82f6;background:#eff6ff}.sub-tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6;font-weight:600}.filters-bar{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:20px;padding:16px;background:#f9fafb;border-radius:8px;align-items:center}.filter-group{display:flex;align-items:center;gap:8px}.filter-label{font-size:13px;font-weight:500;color:#374151}.filter-chips{display:flex;gap:6px;flex-wrap:wrap}.filter-chip{display:flex;align-items:center;gap:4px;padding:6px 12px;background:#fff;border:1px solid #d1d5db;border-radius:16px;font-size:12px;color:#374151;cursor:pointer;transition:all .2s}.filter-chip:hover{border-color:#3b82f6;color:#3b82f6}.filter-chip.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.btn-refresh{margin-left:auto;padding:8px;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;transition:all .2s}.btn-refresh:hover{background:#f9fafb;color:#3b82f6}.notifications-table,.templates-table{overflow-x:auto}.notifications-table table,.templates-table table{width:100%;border-collapse:collapse}.notifications-table thead,.templates-table thead{background:#f9fafb}.notifications-table th,.templates-table th{text-align:left;padding:12px 16px;font-size:12px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.notifications-table tbody tr,.templates-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.notifications-table tbody tr:hover,.templates-table tbody tr:hover{background:#f9fafb}.notifications-table td,.templates-table td{padding:14px 16px;font-size:14px;color:#1f2937}.recipient-cell,.subject-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.template-name{font-weight:500}.channel-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:#f3f4f6;border-radius:4px;font-size:12px;color:#374151}.status-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500}.status-badge.status-pending{background:#fef3c7;color:#d97706}.status-badge.status-scheduled{background:#dbeafe;color:#2563eb}.status-badge.status-sent{background:#d1fae5;color:#059669}.status-badge.status-delivered{background:#a7f3d0;color:#047857}.status-badge.status-failed{background:#fee2e2;color:#dc2626}.status-badge.status-cancelled{background:#f3f4f6;color:#6b7280}.priority-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:500}.priority-badge.priority-low{background:#f3f4f6;color:#6b7280}.priority-badge.priority-normal{background:#dbeafe;color:#2563eb}.priority-badge.priority-high{background:#fed7aa;color:#c2410c}.priority-badge.priority-urgent{background:#fee2e2;color:#dc2626}.active-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.active-badge.active{background:#d1fae5;color:#059669}.active-badge.inactive{background:#f3f4f6;color:#6b7280}.action-buttons{display:flex;gap:6px}.btn-icon{padding:6px;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#374151;cursor:pointer;transition:all .2s}.btn-icon:hover{background:#f9fafb;color:#3b82f6;border-color:#3b82f6}.btn-icon.btn-retry:hover{color:#f59e0b;border-color:#f59e0b}.btn-icon.btn-cancel:hover,.btn-icon.btn-delete:hover{color:#dc2626;border-color:#dc2626;background:#fee2e2}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{font-size:18px;font-weight:600;color:#1f2937;margin:0}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#9ca3af}.loading-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state p{font-size:16px;color:#6b7280;margin:0 0 16px}.send-section h3{font-size:18px;font-weight:600;color:#1f2937;margin:0 0 20px}.template-selector{margin-bottom:24px;padding:16px;background:#f9fafb;border-radius:8px}.template-selector label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.template-selector select{width:100%;max-width:400px;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff}.send-form .form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.send-form .form-group{margin-bottom:20px}.send-form .form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.send-form .form-group input,.send-form .form-group select,.send-form .form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s}.send-form .form-group input:focus,.send-form .form-group select:focus,.send-form .form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.send-form .form-group textarea{resize:vertical;min-height:100px}.send-form .help-text{display:block;font-size:12px;color:#6b7280;margin-top:6px}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:20px;border-top:1px solid #e5e7eb;margin-top:24px}.btn-primary:disabled{background:#9ca3af;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.modal-content{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a}.modal-content.modal-lg{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.btn-close{padding:4px;background:transparent;border:none;color:#6b7280;cursor:pointer;transition:color .2s}.btn-close:hover{color:#1f2937}.modal-footer{display:flex;gap:12px;justify-content:flex-end;padding:16px 24px;border-top:1px solid #e5e7eb}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:20px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-item label{font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.detail-item span{font-size:14px;color:#1f2937}.detail-item .mono{font-family:Courier New,monospace;font-size:13px;background:#f3f4f6;padding:4px 8px;border-radius:4px}.detail-section{margin-bottom:20px}.detail-section label{display:block;font-size:12px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.detail-section p{font-size:14px;color:#1f2937;margin:0}.content-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:12px;font-size:13px;font-family:Courier New,monospace;white-space:pre-wrap;word-break:break-word;margin:0;max-height:200px;overflow-y:auto}.error-section{background:#fee2e2;border-radius:6px;padding:12px}.error-text{color:#dc2626!important}.checkbox-group{margin-top:16px}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#374151;cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:#3b82f6}@media(max-width:768px){.admin-notifications{padding:16px}.notification-stats{flex-wrap:wrap}.stat-mini{min-width:80px}.sub-tabs{overflow-x:auto;padding-bottom:0}.filters-bar{flex-direction:column;align-items:flex-start}.filter-group{flex-direction:column;align-items:flex-start;width:100%}.filter-chips{width:100%}.btn-refresh{margin-left:0;margin-top:12px}.notifications-table,.templates-table{overflow-x:scroll}.notifications-table table,.templates-table table{min-width:800px}.send-form .form-row{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.detail-grid{grid-template-columns:1fr}.modal-content{margin:16px}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.send-mode-toggle{display:flex;gap:8px;margin-bottom:20px;padding:4px;background:#f3f4f6;border-radius:8px;width:-moz-fit-content;width:fit-content}.mode-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:transparent;border:none;border-radius:6px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.mode-btn:hover{color:#374151}.mode-btn.active{background:#fff;color:#3b82f6;box-shadow:0 1px 3px #0000001a}.mode-btn .recipient-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;background:#3b82f6;color:#fff;border-radius:10px;font-size:12px;font-weight:600}.bulk-recipients-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:20px;margin-bottom:20px}.bulk-recipients-header{margin-bottom:16px}.bulk-recipients-header h4{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#1f2937;margin:0 0 6px}.recipient-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;background:#3b82f6;color:#fff;border-radius:12px;font-size:13px;font-weight:600}.add-recipient-form{display:flex;gap:12px;margin-bottom:8px}.add-recipient-form .recipient-input{flex:1;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;background:#fff}.add-recipient-form .recipient-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-add-recipient{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add-recipient:hover{background:#2563eb}.btn-add-recipient:disabled{background:#9ca3af;cursor:not-allowed}.paste-hint{display:block;font-size:12px;color:#6b7280;font-style:italic;margin-bottom:16px}.recipients-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.recipient-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:6px;transition:all .2s}.recipient-item:hover{border-color:#d1d5db;box-shadow:0 1px 2px #0000000d}.recipient-info{display:flex;gap:16px;overflow:hidden}.recipient-user-id{font-size:13px;color:#6b7280;font-family:Courier New,monospace;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.recipient-address{font-size:14px;color:#1f2937;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-remove-recipient{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:1px solid transparent;border-radius:4px;color:#9ca3af;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-remove-recipient:hover{background:#fee2e2;border-color:#fca5a5;color:#dc2626}.no-recipients{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 20px;color:#9ca3af;text-align:center}.no-recipients svg{margin-bottom:12px;opacity:.5}.no-recipients p{font-size:14px;color:#6b7280;margin:0}@media(max-width:768px){.send-mode-toggle{width:100%}.mode-btn{flex:1;justify-content:center;padding:10px 12px}.add-recipient-form{flex-direction:column}.btn-add-recipient{width:100%;justify-content:center}.recipient-info{flex-direction:column;gap:4px}.recipient-user-id{max-width:100%}}.header-actions{display:flex;align-items:center;gap:12px}.language-selector{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#f3f4f6;border-radius:6px;color:#374151}.language-selector select{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;background:#fff;cursor:pointer;min-width:120px}.language-selector select:focus{outline:none;border-color:#3b82f6}.btn-sm{padding:6px 12px;font-size:13px}.source-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.source-badge.default{background:#dbeafe;color:#1e40af}.source-badge.custom{background:#fef3c7;color:#92400e}.templates-table tbody tr.default-template{background:#f0f9ff}.templates-table tbody tr.default-template:hover{background:#e0f2fe}.info-banner{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;margin-bottom:20px;font-size:14px;color:#1e40af}.info-banner svg{flex-shrink:0;margin-top:2px}.variables-intro{font-size:14px;color:#6b7280;margin-bottom:24px;padding:12px 16px;background:#f9fafb;border-radius:6px}.variables-list{display:flex;flex-direction:column;gap:24px}.variable-group{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.variable-group-title{font-size:14px;font-weight:600;color:#1f2937;margin:0;padding:12px 16px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.variables-table{width:100%;border-collapse:collapse}.variables-table th{text-align:left;padding:10px 16px;font-size:12px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;background:#f9fafb;border-bottom:1px solid #e5e7eb}.variables-table td{padding:10px 16px;font-size:13px;color:#374151;border-bottom:1px solid #f3f4f6}.variables-table tbody tr:last-child td{border-bottom:none}.variables-table tbody tr:hover{background:#f9fafb}.variable-name code{background:#f3f4f6;padding:3px 8px;border-radius:4px;font-family:Courier New,monospace;font-size:12px;color:#7c3aed}.variable-example{color:#6b7280;font-style:italic}.available-variables{margin-bottom:20px;padding:16px;background:#fefce8;border:1px solid #fef08a;border-radius:8px}.available-variables label{display:block;font-size:13px;font-weight:500;color:#854d0e;margin-bottom:10px}.variable-chips{display:flex;flex-wrap:wrap;gap:8px}.variable-chip{display:inline-block;padding:4px 10px;background:#fff;border:1px solid #fbbf24;border-radius:4px;font-family:Courier New,monospace;font-size:12px;color:#92400e;cursor:pointer;transition:all .2s}.variable-chip:hover{background:#fef08a;border-color:#f59e0b}.modal-body .form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.modal-body .form-group{margin-bottom:16px}.modal-body .form-group label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.modal-body .form-group input,.modal-body .form-group select,.modal-body .form-group textarea{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s}.modal-body .form-group input:focus,.modal-body .form-group select:focus,.modal-body .form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-body .form-group textarea{resize:vertical;min-height:120px;font-family:Courier New,monospace}.modal-body .form-group select:disabled{background:#f3f4f6;color:#6b7280;cursor:not-allowed}.modal-body .help-text{display:block;font-size:12px;color:#6b7280;margin-top:4px}@media(max-width:768px){.header-actions{flex-direction:column;align-items:stretch;width:100%;gap:8px}.language-selector{justify-content:space-between}.language-selector select{flex:1}.modal-body .form-row{grid-template-columns:1fr}.variable-chips{justify-content:flex-start}.variables-table th,.variables-table td{padding:8px 12px}.section-header{flex-direction:column;align-items:flex-start;gap:12px}}.admin-providers{padding:0}.channel-tabs{display:flex;gap:8px;margin-bottom:16px;padding:4px;background:var(--bg-secondary, #f5f5f5);border-radius:8px}.channel-tab{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;background:transparent;color:var(--text-secondary, #666);border-radius:6px;cursor:pointer;transition:all .2s ease;font-weight:500}.channel-tab:hover{background:var(--bg-hover, #e8e8e8)}.channel-tab.active{background:var(--bg-primary, #fff);color:var(--primary, #2563eb);box-shadow:0 1px 3px #0000001a}.direction-toggle{display:flex;gap:4px;margin-bottom:20px}.direction-btn{padding:6px 16px;border:1px solid var(--border, #e0e0e0);background:var(--bg-primary, #fff);color:var(--text-secondary, #666);border-radius:20px;cursor:pointer;font-size:13px;transition:all .2s ease}.direction-btn:hover{border-color:var(--primary, #2563eb);color:var(--primary, #2563eb)}.direction-btn.active{background:var(--primary, #2563eb);border-color:var(--primary, #2563eb);color:#fff}.providers-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border, #e0e0e0)}.header-info{display:flex;align-items:center;gap:12px}.header-info h3{margin:0;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}.direction-badge{font-size:11px;font-weight:500;padding:2px 8px;background:var(--bg-secondary, #f5f5f5);color:var(--text-secondary, #666);border-radius:12px;text-transform:uppercase}.provider-count{font-size:13px;color:var(--text-muted, #999)}.providers-list{display:flex;flex-direction:column;gap:12px}.provider-card{display:flex;align-items:stretch;background:var(--bg-primary, #fff);border:1px solid var(--border, #e0e0e0);border-radius:8px;overflow:hidden;transition:all .2s ease}.provider-card:hover{border-color:var(--primary, #2563eb);box-shadow:0 2px 8px #00000014}.provider-card.inactive{opacity:.6}.provider-card.default{border-color:var(--warning, #f59e0b);border-width:2px}.provider-priority{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;background:var(--bg-secondary, #f5f5f5);border-right:1px solid var(--border, #e0e0e0);min-width:48px}.priority-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--text-secondary, #666);cursor:pointer;border-radius:4px;transition:all .2s ease}.priority-btn:hover:not(:disabled){background:var(--bg-hover, #e0e0e0);color:var(--primary, #2563eb)}.priority-btn:disabled{opacity:.3;cursor:not-allowed}.priority-value{font-size:14px;font-weight:600;color:var(--text-primary, #333);padding:4px 0}.provider-main{flex:1;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.provider-header{display:flex;justify-content:space-between;align-items:center}.provider-name-section{display:flex;align-items:center;gap:8px}.provider-name-section h4{margin:0;font-size:15px;font-weight:600}.default-badge{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 8px;background:var(--warning-light, #fef3c7);color:var(--warning, #f59e0b);border-radius:12px}.provider-type-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.provider-type-badge.type-resend{background:#ede9fe;color:#7c3aed}.provider-type-badge.type-smtp{background:#e0f2fe;color:#0284c7}.provider-type-badge.type-twilio{background:#fce7f3;color:#db2777}.provider-type-badge.type-firebase{background:#fff7ed;color:#ea580c}.provider-type-badge.type-vonage{background:#ecfdf5;color:#059669}.provider-type-badge.type-custom{background:var(--bg-secondary, #f5f5f5);color:var(--text-secondary, #666)}.provider-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary, #666)}.meta-item.meta-date{font-size:12px;color:var(--text-muted, #999)}.health-healthy{color:var(--success, #22c55e)}.health-unhealthy{color:var(--error, #ef4444)}.health-unknown{color:var(--text-muted, #999)}.active-status{font-size:12px;font-weight:500;padding:2px 8px;border-radius:12px}.active-status.active{background:var(--success-light, #dcfce7);color:var(--success, #22c55e)}.active-status.inactive{background:var(--bg-secondary, #f5f5f5);color:var(--text-muted, #999)}.test-result{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;font-size:13px;margin-top:4px}.test-result.success{background:var(--success-light, #dcfce7);color:var(--success, #22c55e)}.test-result.error{background:var(--error-light, #fee2e2);color:var(--error, #ef4444)}.provider-actions{display:flex;flex-direction:column;gap:4px;padding:8px;border-left:1px solid var(--border, #e0e0e0);background:var(--bg-secondary, #f5f5f5)}.provider-actions .btn-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:var(--bg-primary, #fff);color:var(--text-secondary, #666);border-radius:6px;cursor:pointer;transition:all .2s ease}.provider-actions .btn-icon:hover:not(:disabled){background:var(--primary, #2563eb);color:#fff}.provider-actions .btn-icon:disabled{opacity:.5;cursor:not-allowed}.provider-actions .btn-star:hover{background:var(--warning, #f59e0b);color:#fff}.provider-actions .btn-delete:hover{background:var(--error, #ef4444);color:#fff}.spinning{animation:spin 1s linear infinite}.priority-info{display:flex;align-items:center;gap:8px;padding:12px 16px;margin-top:16px;background:var(--info-light, #e0f2fe);color:var(--info, #0284c7);border-radius:8px;font-size:13px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--text-secondary, #666)}.empty-state svg{opacity:.3;margin-bottom:16px}.empty-state p{margin:0 0 16px;font-size:15px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border, #e0e0e0);border-top-color:var(--primary, #2563eb);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}.modal-content{background:var(--bg-primary, #fff);border-radius:12px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-content.modal-lg{max-width:600px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border, #e0e0e0)}.modal-header h3{margin:0;font-size:18px;font-weight:600}.btn-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary, #666);border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-close:hover{background:var(--bg-secondary, #f5f5f5)}.modal-body{padding:24px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border, #e0e0e0);background:var(--bg-secondary, #f5f5f5)}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--text-primary, #333)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border, #e0e0e0);border-radius:6px;font-size:14px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary, #2563eb);box-shadow:0 0 0 3px #2563eb1a}.form-group .help-text{display:block;margin-top:4px;font-size:12px;color:var(--text-muted, #999)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.config-section{margin-top:24px;padding-top:20px;border-top:1px solid var(--border, #e0e0e0)}.config-section h4{margin:0 0 16px;font-size:14px;font-weight:600;color:var(--text-secondary, #666);text-transform:uppercase;letter-spacing:.5px}.password-field{position:relative}.password-field input{width:100%;padding-right:40px}.toggle-password{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary, #666);cursor:pointer;border-radius:4px}.toggle-password:hover{background:var(--bg-secondary, #f5f5f5)}.checkbox-group{margin:16px 0}.checkbox-field{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-field input{width:auto;margin:0}.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:var(--primary, #2563eb);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s ease}.btn-primary:hover{background:var(--primary-dark, #1d4ed8)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-secondary, #f5f5f5);color:var(--text-primary, #333);border:1px solid var(--border, #e0e0e0);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-secondary:hover{background:var(--bg-hover, #e8e8e8)}.btn-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@media(max-width:768px){.channel-tabs{flex-wrap:wrap}.channel-tab{flex:1;min-width:80px;justify-content:center}.provider-card{flex-direction:column}.provider-priority{flex-direction:row;border-right:none;border-bottom:1px solid var(--border, #e0e0e0);padding:8px 12px}.priority-btn{transform:rotate(-90deg)}.provider-actions{flex-direction:row;border-left:none;border-top:1px solid var(--border, #e0e0e0);justify-content:flex-end}.form-row{grid-template-columns:1fr}.providers-header{flex-direction:column;align-items:flex-start;gap:12px}}.admin-dashboard{padding:32px;max-width:1400px;margin:0 auto}.admin-header{margin-bottom:32px}.header-content h1{font-size:32px;font-weight:700;color:#1f2937;margin:0 0 8px}.header-content p{font-size:16px;color:#6b7280;margin:0}.admin-tabs{display:flex;gap:8px;margin-bottom:32px;border-bottom:2px solid #e5e7eb;padding-bottom:0}.tab-button{display:flex;align-items:center;gap:8px;padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;position:relative;bottom:-2px}.tab-button:hover{color:#3b82f6;background:#eff6ff}.tab-button.active{color:#3b82f6;border-bottom-color:#3b82f6;font-weight:600}.tab-button svg{width:18px;height:18px}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;transition:all .2s}.stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.stat-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-icon.files{background:#dbeafe;color:#2563eb}.stat-icon.storage{background:#d1fae5;color:#059669}.stat-icon.usage{background:#fef3c7;color:#d97706}.stat-icon.users{background:#e9d5ff;color:#9333ea}.stat-content{display:flex;flex-direction:column;gap:4px}.stat-value{font-size:28px;font-weight:700;color:#1f2937;line-height:1}.stat-label{font-size:14px;color:#6b7280}.admin-search{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px}.admin-search h2{font-size:20px;font-weight:600;color:#1f2937;margin:0 0 24px}.search-form{display:flex;gap:12px;margin-bottom:24px}.search-input-wrapper{flex:1;position:relative;display:flex;align-items:center}.search-input-wrapper svg{position:absolute;left:16px;color:#9ca3af;pointer-events:none}.search-input-wrapper input{width:100%;padding:12px 16px 12px 48px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;font-family:inherit;transition:all .2s}.search-input-wrapper input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.btn-search{padding:12px 24px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-search:hover:not(:disabled){background:#2563eb}.btn-search:disabled{background:#9ca3af;cursor:not-allowed}.search-help{padding:20px;background:#f9fafb;border:2px dashed #e5e7eb;border-radius:8px;text-align:center}.search-help p{font-size:14px;color:#6b7280;margin:0}.search-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#6b7280}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.search-loading p{margin:0;font-size:14px;font-weight:500}.search-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;background:#fee2e2;border-radius:8px}.search-error svg{color:#dc2626}.search-error p{font-size:14px;color:#dc2626;margin:0}.search-results{display:flex;flex-direction:column;gap:24px}.results-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.results-header h3{font-size:18px;font-weight:600;color:#1f2937;margin:0}.results-count{font-size:14px;color:#6b7280}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#9ca3af;text-align:center}.no-results svg{margin-bottom:16px;opacity:.5}.no-results p{font-size:16px;font-weight:600;color:#6b7280;margin:0 0 8px}.no-results span{font-size:14px}.results-table{overflow-x:auto}.results-table table{width:100%;border-collapse:collapse}.results-table thead{background:#f9fafb}.results-table th{text-align:left;padding:12px 16px;font-size:13px;font-weight:600;color:#374151;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.results-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background .2s}.results-table tbody tr:hover{background:#f9fafb}.results-table td{padding:16px;font-size:14px;color:#1f2937}.doc-name{font-weight:500;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.category-badge{display:inline-block;padding:4px 8px;background:#dbeafe;color:#1e40af;border-radius:4px;font-size:12px;font-weight:500}.tags-cell{display:flex;gap:6px;flex-wrap:wrap}.tag{padding:3px 8px;background:#f3f4f6;border-radius:4px;font-size:12px;color:#4b5563}.tag-more{padding:3px 8px;background:#e5e7eb;border-radius:4px;font-size:12px;color:#6b7280;font-weight:500}.no-tags{color:#9ca3af}.action-buttons{display:flex;gap:8px}.btn-action{padding:6px 12px;background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s}.btn-action:hover{background:#f9fafb;border-color:#9ca3af}.btn-action.btn-delete{color:#dc2626;border-color:#fecaca;display:flex;align-items:center;gap:6px}.btn-action.btn-delete:hover{background:#fee2e2;border-color:#dc2626}.user-management-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px}.section-title{font-size:20px;font-weight:600;color:#1f2937;margin:0 0 24px;display:flex;align-items:center;gap:12px}.user-count{font-size:14px;color:#6b7280;margin-bottom:20px;font-weight:500}.user-management-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.users-list{display:flex;flex-direction:column;gap:12px}.user-card{border:1px solid #e5e7eb;border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;background:#fff;text-align:left}.user-card:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.user-card.selected{border-color:#3b82f6;background:#eff6ff}.user-card-content{display:flex;flex-direction:column;gap:12px}.user-info{display:flex;flex-direction:column;gap:8px}.user-name{font-size:16px;font-weight:600;color:#1f2937;margin:0;display:flex;align-items:center;gap:6px}.user-id{font-size:13px;color:#6b7280;margin:0;font-family:Courier New,monospace}.user-stats{display:flex;flex-direction:column;gap:8px}.stat-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#4b5563}.stat-item svg{width:16px;height:16px;color:#9ca3af}.stat-item.date-range{font-size:12px;color:#6b7280}.documents-panel{border:1px solid #e5e7eb;border-radius:8px;padding:20px;background:#fff;min-height:400px}.no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#9ca3af;padding:60px 20px}.no-selection svg{margin-bottom:16px;opacity:.5}.no-selection p{font-size:14px;margin:0}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.panel-header h3{font-size:16px;font-weight:600;color:#1f2937;margin:0}.btn-delete-all{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-delete-all:hover{background:#fee2e2;border-color:#dc2626}.document-count{font-size:14px;color:#6b7280;margin-bottom:16px}.documents-list{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.document-item{border:1px solid #e5e7eb;border-radius:6px;padding:12px;background:#fff;transition:all .2s}.document-item:hover{box-shadow:0 2px 4px #0000000d}.document-content{display:flex;flex-direction:column;gap:8px}.document-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.document-header svg{width:16px;height:16px;color:#6b7280}.document-name{font-size:14px;font-weight:500;color:#1f2937}.document-details{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#6b7280}.document-details p{margin:0}.retention-info{color:#d97706!important;font-weight:500}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:24px;max-width:500px;width:100%;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.modal-header svg{color:#3b82f6;width:24px;height:24px}.modal-header.warning svg{color:#d97706}.modal-header h3{font-size:18px;font-weight:600;color:#1f2937;margin:0}.modal-body{margin-bottom:20px}.warning-text{font-size:14px;color:#4b5563;margin:0 0 16px}.user-info-box{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:12px;margin:16px 0}.user-info-box p{font-size:13px;color:#374151;margin:4px 0}.user-info-box strong{font-weight:600}.danger-text{font-size:14px;color:#dc2626;font-weight:500;margin:16px 0 0}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.form-group textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;transition:all .2s}.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-danger{padding:10px 20px;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#b91c1c}.btn-secondary{padding:10px 20px;background:#fff;color:#374151;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.retention-management-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px}.search-section,.filter-controls{margin-bottom:24px}.filter-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:12px}.filter-buttons{display:flex;gap:12px;flex-wrap:wrap}.filter-button{padding:10px 20px;background:#f3f4f6;color:#374151;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.filter-button:hover{background:#e5e7eb;border-color:#d1d5db}.filter-button.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.filter-button.expired.active{background:#dc2626;border-color:#dc2626}.results-count{font-size:14px;color:#6b7280;margin-bottom:16px}.retention-date{display:inline-flex;align-items:center;gap:4px;color:#6b7280}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;gap:4px}.status-badge.status-none{background:#f3f4f6;color:#6b7280}.status-badge.status-active{background:#d1fae5;color:#065f46}.status-badge.status-expired{background:#fee2e2;color:#991b1b}.help-text{font-size:12px;color:#6b7280;margin-top:6px}.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#2563eb}.btn-warning{padding:10px 20px;background:#f59e0b;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-warning:hover{background:#d97706}.form-group input[type=date]{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;font-family:inherit;transition:all .2s}.form-group input[type=date]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@media(max-width:1024px){.admin-dashboard{padding:24px}.stats-overview{grid-template-columns:repeat(2,1fr)}.user-management-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-dashboard{padding:16px}.header-content h1{font-size:24px}.stats-overview{grid-template-columns:1fr;gap:16px}.admin-search{padding:20px}.search-form{flex-direction:column}.results-table{overflow-x:scroll}.results-table table{min-width:800px}.action-buttons{flex-direction:column}.user-management-section{padding:20px}.user-management-grid{grid-template-columns:1fr}.retention-management-section{padding:20px}.filter-buttons{flex-direction:column}.filter-button{width:100%}.modal-content{padding:20px}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}.shared-access-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.shared-access-container{background-color:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%;padding:3rem}.shared-access-header{text-align:center;margin-bottom:2.5rem}.access-icon{width:80px;height:80px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1.5rem}.shared-access-header h1{font-size:1.75rem;font-weight:700;color:#0f172a;margin:0}.shared-access-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;min-height:200px}.shared-access-state h2{font-size:1.5rem;font-weight:600;color:#334155;margin:1.5rem 0 .5rem}.shared-access-state p{color:#64748b;font-size:1rem;margin:0}.shared-access-state.success{color:#10b981}.shared-access-state.success h2{color:#059669}.shared-access-state.error,.shared-access-state.error h2{color:#dc2626}.spinner{color:#667eea;animation:spin 1s linear infinite}.spinner.large{width:64px;height:64px}.error-actions{display:flex;gap:1rem;margin-top:1.5rem}.retry-btn,.home-btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.retry-btn{background-color:#667eea;color:#fff}.retry-btn:hover{background-color:#5568d3;transform:translateY(-1px)}.home-btn{background-color:transparent;color:#64748b;border:1px solid #e2e8f0}.home-btn:hover{background-color:#f1f5f9;border-color:#cbd5e1}.shared-access-info{background-color:#f8fafc;border-radius:12px;padding:1.5rem;margin-top:2rem}.info-text{color:#475569;font-size:.9rem;line-height:1.6;margin:0;text-align:center}@media(max-width:768px){.shared-access-container{padding:2rem 1.5rem}.shared-access-header h1{font-size:1.5rem}.error-actions{flex-direction:column;width:100%}.retry-btn,.home-btn{width:100%}}.temp-viewer-page{max-width:1400px;margin:0 auto}.temp-viewer-loading,.temp-viewer-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:#64748b}.temp-viewer-loading .spinner{animation:spin 1s linear infinite;color:#667eea}.temp-viewer-error{color:#dc2626}.temp-viewer-error h2{margin-top:1rem;color:#dc2626}.temp-viewer-header{margin-bottom:2rem}.header-content h1{font-size:2rem;font-weight:600;color:#0f172a;margin:0 0 .5rem}.header-content p{color:#64748b;font-size:1rem;margin:0}.viewer-controls{display:flex;gap:1rem;margin-top:1.5rem}.search-input{flex:1;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;transition:all .2s ease}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.sort-select{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;background-color:#fff;cursor:pointer;transition:all .2s ease}.sort-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.no-documents{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;color:#64748b;background-color:#fff;border-radius:12px;padding:3rem}.no-documents h3{margin-top:1rem;color:#334155}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.document-card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;transition:all .2s ease}.document-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.document-icon{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff}.document-info{flex:1}.document-name{font-size:1rem;font-weight:600;color:#0f172a;margin:0 0 .5rem;word-break:break-word}.document-meta{display:flex;gap:1rem;font-size:.85rem;color:#64748b;margin-bottom:.5rem}.document-category{display:inline-block;background-color:#eff6ff;color:#2563eb;padding:.25rem .75rem;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.document-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.tag{background-color:#f1f5f9;color:#475569;padding:.25rem .5rem;border-radius:4px;font-size:.75rem}.document-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid #e2e8f0}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.preview-btn{background-color:#667eea;color:#fff}.preview-btn:hover{background-color:#5568d3;transform:translateY(-1px)}.download-btn{background-color:#10b981;color:#fff}.download-btn:hover{background-color:#059669;transform:translateY(-1px)}@media(max-width:768px){.documents-grid{grid-template-columns:1fr}.viewer-controls,.document-actions{flex-direction:column}}.temp-upgrade-page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:2rem}.upgrade-container{background-color:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;max-width:600px;width:100%;padding:3rem}.upgrade-header{text-align:center;margin-bottom:2rem}.upgrade-icon{width:80px;height:80px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 1.5rem}.upgrade-header h1{font-size:1.75rem;font-weight:700;color:#0f172a;margin:0 0 .5rem}.upgrade-header p{color:#64748b;font-size:1rem;margin:0}.upgrade-benefits{background-color:#f8fafc;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.upgrade-benefits h3{font-size:1rem;font-weight:600;color:#334155;margin:0 0 1rem}.upgrade-benefits ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.upgrade-benefits li{display:flex;align-items:center;gap:.75rem;color:#475569;font-size:.95rem}.upgrade-benefits li svg{color:#10b981;flex-shrink:0}.session-warning{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;color:#92400e;font-size:.9rem;margin-bottom:1.5rem}.session-warning svg{flex-shrink:0}.upgrade-form{display:flex;flex-direction:column;gap:1.25rem}.error-banner{background-color:#fee2e2;border:1px solid #dc2626;border-radius:8px;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;color:#991b1b;font-size:.9rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#334155;font-size:.9rem}.form-group label svg{color:#667eea}.form-group input{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#dc2626}.form-group input.error:focus{box-shadow:0 0 0 3px #dc26261a}.form-group input:disabled{background-color:#f1f5f9;cursor:not-allowed}.error-text{color:#dc2626;font-size:.85rem}.upgrade-submit-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;padding:1rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:.5rem}.upgrade-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.upgrade-submit-btn:disabled{opacity:.6;cursor:not-allowed}.upgrade-submit-btn .spinner{animation:spin 1s linear infinite}.cancel-btn{background-color:transparent;color:#64748b;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;font-size:.95rem;cursor:pointer;transition:all .2s ease}.cancel-btn:hover:not(:disabled){background-color:#f1f5f9;border-color:#cbd5e1}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.conversion-success{position:fixed;inset:0;background-color:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:1000}.conversion-success svg{color:#10b981;margin-bottom:1rem}.conversion-success h3{font-size:1.5rem;margin:0 0 .5rem}.conversion-success p{color:#cbd5e1;margin:0}@media(max-width:768px){.upgrade-container{padding:2rem 1.5rem}.upgrade-header h1{font-size:1.5rem}}.document-preview-page{min-height:100vh;background-color:var(--background, #f8f9fa)}.preview-loading,.preview-error{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.loading-spinner{width:3rem;height:3rem;border:3px solid rgba(0,0,0,.1);border-top-color:var(--primary, #007bff);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.app{min-height:100vh;display:flex;flex-direction:column}.protected-route-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;background:#f8f9fa}.protected-route-loading .loading-spinner{width:32px;height:32px;border:3px solid rgba(102,126,234,.3);border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.protected-route-loading p{color:#666;font-size:16px;margin:0}.access-denied{display:flex;align-items:center;justify-content:center;height:100vh;background:#f8f9fa;padding:20px}.access-denied-content{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 30px #0000001a;text-align:center;max-width:500px;width:100%}.access-denied-content h2{color:#dc3545;margin:0 0 16px;font-size:24px}.access-denied-content p{color:#666;margin:8px 0;line-height:1.5}.access-denied-content strong{color:#333}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.access-denied{padding:15px}.access-denied-content{padding:30px 20px;max-width:100%}.access-denied-content h2{font-size:20px}.access-denied-content p{font-size:14px}}@media(max-width:480px){.access-denied-content{padding:24px 16px}.access-denied-content h2{font-size:18px}.access-denied-content p{font-size:13px}}
