*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--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:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb;box-sizing:border-box}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-y-0{bottom:0;top:0}.bottom-0{bottom:0}.left-0{left:0}.left-1{left:.25rem}.left-1\/2{left:50%}.left-2{left:.5rem}.right-0{right:0}.right-1{right:.25rem}.right-1\/2{right:50%}.top-0{top:0}.-z-10{z-index:-10}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.col-span-1{grid-column:span 1/span 1}.col-span-10{grid-column:span 10/span 10}.col-span-11{grid-column:span 11/span 11}.col-span-12{grid-column:span 12/span 12}.col-span-2{grid-column:span 2/span 2}.col-span-3{grid-column:span 3/span 3}.col-span-4{grid-column:span 4/span 4}.col-span-5{grid-column:span 5/span 5}.col-span-6{grid-column:span 6/span 6}.col-span-7{grid-column:span 7/span 7}.col-span-8{grid-column:span 8/span 8}.col-span-9{grid-column:span 9/span 9}.mx-2\.5{margin-left:.625rem;margin-right:.625rem}.mx-auto{margin-left:auto;margin-right:auto}.my-6{margin-bottom:1.5rem;margin-top:1.5rem}.-mb-px{margin-bottom:-1px}.-ml-0{margin-left:0}.-ml-0\.5{margin-left:-.125rem}.-ml-1{margin-left:-.25rem}.-ml-1\.5{margin-left:-.375rem}.-ml-px{margin-left:-1px}.-mr-1{margin-right:-.25rem}.mb-0{margin-bottom:0}.mb-1\.5{margin-bottom:.375rem}.mb-2{margin-bottom:.5rem}.ml-1\.5{margin-left:.375rem}.ml-2{margin-left:.5rem}.ml-px{margin-left:1px}.mr-1{margin-right:.25rem}.mr-1\.5{margin-right:.375rem}.mr-10{margin-right:2.5rem}.mr-2{margin-right:.5rem}.mr-2\.5{margin-right:.625rem}.mr-20{margin-right:5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.mr-5{margin-right:1.25rem}.mr-8{margin-right:2rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.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}.hidden{display:none}.size-3\.5{height:.875rem;width:.875rem}.h-0{height:0}.h-10{height:2.5rem}.h-12{height:3rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-40{height:10rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-7{height:1.75rem}.h-8{height:2rem}.h-80{height:20rem}.h-9{height:2.25rem}.h-\[1px\]{height:1px}.h-full{height:100%}.max-h-\[228px\]{max-height:228px}.min-h-full{min-height:100%}.w-0{width:0}.w-1{width:.25rem}.w-1\/2{width:50%}.w-10{width:2.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-28{width:7rem}.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-48{width:12rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-9{width:2.25rem}.w-\[90\%\]{width:90%}.w-\[var\(--button-width\)\]{width:var(--button-width)}.w-full{width:100%}.w-max{width:-webkit-max-content;width:max-content}.w-screen{width:100vw}.min-w-44{min-width:11rem}.min-w-\[10rem\]{min-width:10rem}.min-w-min{min-width:-webkit-min-content;min-width:min-content}.max-w-\[100px\]{max-width:100px}.max-w-full{max-width:100%}.max-w-lg{max-width:32rem}.max-w-sm{max-width:24rem}.max-w-xs{max-width:20rem}.flex-1{flex:1 1}.flex-none{flex:none}.shrink-0{flex-shrink:0}.border-collapse{border-collapse:collapse}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.-translate-y-4{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-4{--tw-translate-y:-1rem}.translate-x-0{--tw-translate-x:0px}.translate-x-0,.translate-x-1\/2{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-1\/2{--tw-translate-x:50%}.translate-x-5{--tw-translate-x:1.25rem}.translate-x-5,.translate-y-0{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-0{--tw-translate-y:0px}.-rotate-180{--tw-rotate:-180deg}.-rotate-180,.-rotate-90{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-rotate-90{--tw-rotate:-90deg}.scale-100{--tw-scale-x:1;--tw-scale-y:1}.scale-100,.scale-95{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-95{--tw-scale-x:.95;--tw-scale-y:.95}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes spin{to{transform:rotate(1turn)}}.animate-spin{animation:spin 1s linear infinite}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;user-select:none}.resize{resize:both}.snap-mandatory{--tw-scroll-snap-strictness:mandatory}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-10{grid-template-columns:repeat(10,minmax(0,1fr))}.grid-cols-11{grid-template-columns:repeat(11,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,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))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.grid-cols-9{grid-template-columns:repeat(9,minmax(0,1fr))}.grid-cols-none{grid-template-columns:none}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.gap-3{gap:.75rem}.gap-x-1{column-gap:.25rem}.space-x-0\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.125rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.125rem*var(--tw-space-x-reverse))}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.25rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.25rem*var(--tw-space-x-reverse))}.space-x-1\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.375rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.375rem*var(--tw-space-x-reverse))}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(.5rem*var(--tw-space-x-reverse))}.space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.space-x-6>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1.5rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1.5rem*var(--tw-space-x-reverse))}.space-x-8>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(2rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(2rem*var(--tw-space-x-reverse))}.space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.375rem*var(--tw-space-y-reverse));margin-top:calc(.375rem*(1 - var(--tw-space-y-reverse)))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse:0;border-bottom-width:calc(1px*var(--tw-divide-y-reverse));border-top-width:calc(1px*(1 - var(--tw-divide-y-reverse)))}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-y-auto{overflow-y:auto}.overflow-x-clip{overflow-x:clip}.overflow-x-scroll{overflow-x:scroll}.truncate{overflow:hidden;text-overflow:ellipsis}.truncate,.whitespace-nowrap{white-space:nowrap}.\!rounded-none{border-radius:0!important}.rounded{border-radius:.25rem}.rounded-\[1px\]{border-radius:1px}.rounded-lg{border-radius:.5rem}.rounded-l-none{border-bottom-left-radius:0;border-top-left-radius:0}.rounded-r-none{border-bottom-right-radius:0;border-top-right-radius:0}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-b-4{border-bottom-width:4px}.border-l{border-left-width:1px}.border-l-4{border-left-width:4px}.border-r{border-right-width:1px}.border-r-4{border-right-width:4px}.border-t-4{border-top-width:4px}.border-t-\[1px\]{border-top-width:1px}.border-dashed{border-style:dashed}.border-none{border-style:none}.border-red-500{--tw-border-opacity:1;border-color:#ef4444;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.border-transparent{border-color:#0000}.bg-slate-950\/30{background-color:#0206174d}.bg-transparent{background-color:initial}.bg-opacity-10{--tw-bg-opacity:0.1}.bg-opacity-20{--tw-bg-opacity:0.2}.bg-opacity-40{--tw-bg-opacity:0.4}.stroke-1{stroke-width:1}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-2\.5{padding:.625rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-3\.5{padding-left:.875rem;padding-right:.875rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-2\.5{padding-bottom:.625rem;padding-top:.625rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-3\.5{padding-bottom:.875rem;padding-top:.875rem}.py-\[10px\]{padding-bottom:10px;padding-top:10px}.pb-3{padding-bottom:.75rem}.pl-10{padding-left:2.5rem}.pl-11{padding-left:2.75rem}.pl-2{padding-left:.5rem}.pl-2\.5{padding-left:.625rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pr-1{padding-right:.25rem}.pr-1\.5{padding-right:.375rem}.pr-12{padding-right:3rem}.pr-14{padding-right:3.5rem}.pr-16{padding-right:4rem}.pr-2{padding-right:.5rem}.pr-2\.5{padding-right:.625rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pr-8{padding-right:2rem}.pt-2{padding-top:.5rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.align-top{vertical-align:top}.align-middle{vertical-align:middle}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing:tabular-nums;font-feature-settings:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction);font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.text-\[\#d1d5db\]\/15{color:#d1d5db26}.text-inherit{color:inherit}.text-red-500{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.text-rose-500{--tw-text-opacity:1;color:#f43f5e;color:rgb(244 63 94/var(--tw-text-opacity,1))}.text-transparent{color:#0000}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.opacity-0{opacity:0}.opacity-100{opacity:1}.opacity-20{opacity:.2}.opacity-30{opacity:.3}.opacity-40{opacity:.4}.opacity-50{opacity:.5}.shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid #0000;outline-offset:2px}.outline{outline-style:solid}.ring{--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)}.ring,.ring-1{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.ring-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),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ring-inset{--tw-ring-inset:inset}.ring-opacity-20{--tw-ring-opacity:0.2}.ring-opacity-40{--tw-ring-opacity:0.4}.blur{--tw-blur:blur(8px)}.blur,.drop-shadow{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.drop-shadow{--tw-drop-shadow:drop-shadow(0 1px 2px #0000001a) drop-shadow(0 1px 1px #0000000f)}.\!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)!important}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-text-decoration-color,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-100{transition-duration:.1s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.duration-75{transition-duration:75ms}.ease-in{transition-timing-function:cubic-bezier(.4,0,1,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-linear{transition-timing-function:linear}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.\[--anchor-gap\:4px\]{--anchor-gap:4px}.\[appearance\:textfield\]{-webkit-appearance:textfield;appearance:textfield}.\[scrollbar-width\:none\]{scrollbar-width:none}*{margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.placeholder\:text-red-500::placeholder{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.first\:rounded-l-\[4px\]:first-child{border-bottom-left-radius:4px;border-top-left-radius:4px}.last\:rounded-r-\[4px\]:last-child{border-bottom-right-radius:4px;border-top-right-radius:4px}.focus-within\:relative:focus-within{position:relative}.hover\:border-b-2:hover{border-bottom-width:2px}.hover\:bg-opacity-20:hover{--tw-bg-opacity:0.2}.hover\:underline:hover{-webkit-text-decoration-line:underline;text-decoration-line:underline}.focus\:outline-none:focus{outline:2px solid #0000;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(var(--tw-ring-offset-width)) var(--tw-ring-color)}.focus\:ring-0:focus,.focus\:ring-2:focus{box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),0 0 #0000;box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color)}.disabled\:hover\:bg-transparent:hover:disabled{background-color:initial}.group:hover .group-hover\:bg-opacity-30{--tw-bg-opacity:0.3}.group:active .group-active\:scale-95{--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[selected\]\:border-b-2[data-selected]{border-bottom-width:2px}.data-\[closed\]\:opacity-0[data-closed]{opacity:0}.data-\[enter\]\:duration-300[data-enter]{transition-duration:.3s}.data-\[leave\]\:duration-200[data-leave]{transition-duration:.2s}.data-\[enter\]\:ease-out[data-enter]{transition-timing-function:cubic-bezier(0,0,.2,1)}.data-\[leave\]\:ease-in[data-leave]{transition-timing-function:cubic-bezier(.4,0,1,1)}@media (min-width:640px){.sm\:col-span-1{grid-column:span 1/span 1}.sm\:col-span-10{grid-column:span 10/span 10}.sm\:col-span-11{grid-column:span 11/span 11}.sm\:col-span-12{grid-column:span 12/span 12}.sm\:col-span-2{grid-column:span 2/span 2}.sm\:col-span-3{grid-column:span 3/span 3}.sm\:col-span-4{grid-column:span 4/span 4}.sm\:col-span-5{grid-column:span 5/span 5}.sm\:col-span-6{grid-column:span 6/span 6}.sm\:col-span-7{grid-column:span 7/span 7}.sm\:col-span-8{grid-column:span 8/span 8}.sm\:col-span-9{grid-column:span 9/span 9}.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:grid-cols-10{grid-template-columns:repeat(10,minmax(0,1fr))}.sm\:grid-cols-11{grid-template-columns:repeat(11,minmax(0,1fr))}.sm\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.sm\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.sm\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.sm\:grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.sm\:grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.sm\:grid-cols-9{grid-template-columns:repeat(9,minmax(0,1fr))}.sm\:grid-cols-none{grid-template-columns:none}.sm\:flex-row{flex-direction:row}.sm\:space-x-4>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-left:calc(1rem*(1 - var(--tw-space-x-reverse)));margin-right:calc(1rem*var(--tw-space-x-reverse))}.sm\:space-y-0>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(0px*var(--tw-space-y-reverse));margin-top:calc(0px*(1 - var(--tw-space-y-reverse)))}}@media (min-width:768px){.md\:col-span-1{grid-column:span 1/span 1}.md\:col-span-10{grid-column:span 10/span 10}.md\:col-span-11{grid-column:span 11/span 11}.md\:col-span-12{grid-column:span 12/span 12}.md\:col-span-2{grid-column:span 2/span 2}.md\:col-span-3{grid-column:span 3/span 3}.md\:col-span-4{grid-column:span 4/span 4}.md\:col-span-5{grid-column:span 5/span 5}.md\:col-span-6{grid-column:span 6/span 6}.md\:col-span-7{grid-column:span 7/span 7}.md\:col-span-8{grid-column:span 8/span 8}.md\:col-span-9{grid-column:span 9/span 9}.md\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.md\:grid-cols-10{grid-template-columns:repeat(10,minmax(0,1fr))}.md\:grid-cols-11{grid-template-columns:repeat(11,minmax(0,1fr))}.md\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.md\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.md\:grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.md\:grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.md\:grid-cols-9{grid-template-columns:repeat(9,minmax(0,1fr))}.md\:grid-cols-none{grid-template-columns:none}}@media (min-width:1024px){.lg\:col-span-1{grid-column:span 1/span 1}.lg\:col-span-10{grid-column:span 10/span 10}.lg\:col-span-11{grid-column:span 11/span 11}.lg\:col-span-12{grid-column:span 12/span 12}.lg\:col-span-2{grid-column:span 2/span 2}.lg\:col-span-3{grid-column:span 3/span 3}.lg\:col-span-4{grid-column:span 4/span 4}.lg\:col-span-5{grid-column:span 5/span 5}.lg\:col-span-6{grid-column:span 6/span 6}.lg\:col-span-7{grid-column:span 7/span 7}.lg\:col-span-8{grid-column:span 8/span 8}.lg\:col-span-9{grid-column:span 9/span 9}.lg\:max-w-\[200px\]{max-width:200px}.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-10{grid-template-columns:repeat(10,minmax(0,1fr))}.lg\:grid-cols-11{grid-template-columns:repeat(11,minmax(0,1fr))}.lg\:grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.lg\:grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.lg\:grid-cols-8{grid-template-columns:repeat(8,minmax(0,1fr))}.lg\:grid-cols-9{grid-template-columns:repeat(9,minmax(0,1fr))}.lg\:grid-cols-none{grid-template-columns:none}}@media (prefers-color-scheme:dark){.dark\:border-red-500{--tw-border-opacity:1;border-color:#ef4444;border-color:rgb(239 68 68/var(--tw-border-opacity,1))}.dark\:bg-slate-950\/50{background-color:#02061780}.dark\:bg-white{--tw-bg-opacity:1;background-color:#fff;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.dark\:bg-opacity-10{--tw-bg-opacity:0.1}.dark\:bg-opacity-5{--tw-bg-opacity:0.05}.dark\:text-red-500{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.dark\:opacity-25{opacity:.25}.dark\:ring-opacity-60{--tw-ring-opacity:0.6}.dark\:placeholder\:text-red-500::placeholder{--tw-text-opacity:1;color:#ef4444;color:rgb(239 68 68/var(--tw-text-opacity,1))}.dark\:hover\:bg-opacity-20:hover{--tw-bg-opacity:0.2}}.\[\&\:\:-webkit-inner-spin-button\]\:appearance-none::-webkit-inner-spin-button,.\[\&\:\:-webkit-outer-spin-button\]\:appearance-none::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none}.\[\&\:\:-webkit-scrollbar\]\:hidden::-webkit-scrollbar{display:none}.App{background-color:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.App.app-fixed-viewport{height:100vh;max-height:100vh;overflow:hidden}.App.app-fixed-viewport .app-content{overflow:hidden}.app-content,.app-content>:last-child{display:flex;flex:1 1;flex-direction:column;min-height:0}.app-content>:last-child{overflow:hidden}.app-footer{background:#f5f5f5;border-top:1px solid #e0e0e0;color:#777;font-size:12px;padding:12px 16px;text-align:center}.App.app-fixed-viewport .app-footer{flex-shrink:0}*{box-sizing:border-box}.App.fullscreen-active nav.navbar,:-moz-full-screen nav.navbar,:-ms-fullscreen nav.navbar,:-webkit-full-screen nav.navbar,:fullscreen nav.navbar,body.fullscreen-active nav.navbar,html.fullscreen-active nav.navbar{display:none!important;height:0!important;margin:0!important;opacity:0!important;overflow:hidden!important;padding:0!important;visibility:hidden!important}.app-theme-kpi-analytics .kpi-sidebar{background:#151720;border-right-color:#1e2433}.app-theme-kpi-analytics .kpi-main,.app-theme-kpi-analytics .uzupelnij-raport-container{background:#1a1f2e}.app-theme-kpi-analytics .uzupelnij-raport-spreadsheet,.app-theme-kpi-analytics .uzupelnij-raport-spreadsheet table,.app-theme-kpi-analytics .uzupelnij-raport-spreadsheet td,.app-theme-kpi-analytics .uzupelnij-raport-spreadsheet th{background:#252d3d;border-color:#334155;color:#e4e8eb}.app-theme-kpi-analytics .uzupelnij-raport-spreadsheet input{background:#1e2433;border-color:#334155;color:#e4e8eb}.app-theme-kpi-analytics .uzupelnij-raport-spreadsheet input:focus{border-color:#3b82f6;outline:none}.app-theme-kpi-analytics [class*=Spreadsheet]{background:#252d3d!important;border-color:#334155!important}.app-theme-kpi-analytics [class*=Spreadsheet] table{border-color:#334155!important}.app-theme-kpi-analytics [class*=Spreadsheet] td,.app-theme-kpi-analytics [class*=Spreadsheet] th{background:#252d3d!important;border-color:#334155!important;color:#e4e8eb!important}.app-theme-kpi-analytics [class*=Spreadsheet] input{background:#1e2433!important;border-color:#334155!important;color:#e4e8eb!important}.App.app-theme-kpi-analytics,.App.app-theme-kpi-analytics .app-content{background-color:#1a1f2e}.app-content.app-theme-kpi-analytics .navbar{background:#1e2433!important;border-bottom:1px solid #2d3748;box-shadow:0 1px 3px #0000004d;color:#e4e8eb}.app-content.app-theme-kpi-analytics .navbar .nav-link{color:#cbd5e1}.app-content.app-theme-kpi-analytics .navbar .nav-link:hover{background:#3b82f626;color:#fff}.app-content.app-theme-kpi-analytics .navbar .navbar-brand h1{color:#fff}.app-content.app-theme-kpi-analytics .navbar .user-name{color:#cbd5e1}.app-content.app-theme-kpi-analytics .navbar .logout-button{background:#3b82f633;border:1px solid #3b82f6;color:#93c5fd}.app-content.app-theme-kpi-analytics .navbar .logout-button:hover{background:#3b82f6;color:#fff}.app-content.app-theme-kpi-analytics .navbar .submenu{background:#252d3d;border:1px solid #334155;box-shadow:0 8px 24px #0006}.app-content.app-theme-kpi-analytics .navbar .submenu-link{border-bottom-color:#334155;color:#cbd5e1}.app-content.app-theme-kpi-analytics .navbar .submenu-link:hover{background:#3b82f626;color:#93c5fd}.app-content.app-theme-kpi-analytics .navbar.mobile-open .navbar-menu{background:#1e2433}.app-content.app-theme-kpi-analytics .navbar .mobile-menu-close{color:#e4e8eb}.App.app-theme-kpi-analytics .app-footer{background:#1e2433;border-top:1px solid #2d3748;color:#94a3b8}.app-theme-kpi-analytics .wgraj-dane-container{background:#0000;min-height:calc(100vh - 80px);padding:24px}.app-theme-kpi-analytics .wgraj-dane-card{background:#252d3d;border:1px solid #334155;border-radius:12px;box-shadow:0 4px 24px #0006}.app-theme-kpi-analytics .wgraj-dane-title{color:#f1f5f9}.app-theme-kpi-analytics .wgraj-dane-description{color:#94a3b8}.app-theme-kpi-analytics .wgraj-dane-container .form-label{color:#cbd5e1}.app-theme-kpi-analytics .wgraj-dane-container .form-select,.app-theme-kpi-analytics .wgraj-dane-container .form-select option{background:#1e2433;border-color:#334155;color:#e4e8eb}.app-theme-kpi-analytics .wgraj-dane-container .form-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.app-theme-kpi-analytics .wgraj-dane-container .file-input{background:#1e2433;border-color:#334155;color:#cbd5e1}.app-theme-kpi-analytics .wgraj-dane-container .file-input:focus,.app-theme-kpi-analytics .wgraj-dane-container .file-input:hover{border-color:#3b82f6}.app-theme-kpi-analytics .instructions-box{background:#1e2433;border-color:#334155}.app-theme-kpi-analytics .instructions-title{color:#f1f5f9}.app-theme-kpi-analytics .instructions-list{color:#94a3b8}.app-theme-kpi-analytics .instructions-list li strong{color:#cbd5e1}.app-theme-kpi-analytics .instructions-note{background:#252d3d;border-left-color:#3b82f6;color:#94a3b8}.app-theme-kpi-analytics .file-info{background:#1e2433;border-color:#334155}.app-theme-kpi-analytics .file-name{color:#e4e8eb}.app-theme-kpi-analytics .file-size{color:#94a3b8}.app-theme-kpi-analytics .upload-status.success{background:#22c55e33;border-color:#22c55e;color:#4ade80}.app-theme-kpi-analytics .upload-status.error{background:#ef444433;border-color:#ef4444;color:#f87171}.app-theme-kpi-analytics .btn-upload{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 12px #3b82f666}.app-theme-kpi-analytics .btn-upload:hover:not(:disabled){box-shadow:0 6px 16px #3b82f680}.app-theme-kpi-analytics .btn-reset{background:#252d3d;border-color:#334155;color:#cbd5e1}.app-theme-kpi-analytics .btn-reset:hover:not(:disabled){background:#334155;border-color:#475569;color:#e4e8eb}.app-theme-kpi-analytics .no-projects-message{background:#ef444426;border-color:#334155}.app-theme-kpi-analytics .no-projects-message p{color:#f87171}.app-theme-kpi-analytics .kpi-info-box{background:#1e2433;border-color:#334155}.app-theme-kpi-analytics .kpi-info-title{color:#f1f5f9}.app-theme-kpi-analytics .kpi-preview-item{background:#252d3d;border-color:#334155}.app-theme-kpi-analytics .kpi-preview-name{color:#e4e8eb}.app-theme-kpi-analytics .kpi-preview-unit{color:#60a5fa}.app-theme-kpi-analytics .kpi-info-note{color:#94a3b8}.app-theme-kpi-analytics .kpi-warning-box{background:#ef444426;border-color:#334155}.app-theme-kpi-analytics .kpi-warning-box p{color:#f87171}.app-theme-kpi-analytics .file-parsed-info{background:#1e2433;color:#94a3b8}.app-theme-kpi-analytics .btn-mapping{background:#252d3d;border-color:#3b82f6;color:#60a5fa}.app-theme-kpi-analytics .btn-mapping:hover{background:#3b82f633;border-color:#60a5fa}.app-theme-kpi-analytics .kpi-results-section{background:#1e2433;border-color:#334155}.app-theme-kpi-analytics .kpi-results-title{color:#f1f5f9}.app-theme-kpi-analytics .kpi-result-item{background:#252d3d;border-color:#334155}.app-theme-kpi-analytics .kpi-result-name{color:#e4e8eb}.app-theme-kpi-analytics .kpi-result-value{color:#60a5fa}.app-theme-kpi-analytics .kpi-result-target{color:#94a3b8}.app-theme-kpi-analytics .kpi-target-met{color:#22c55e}.app-theme-kpi-analytics .kpi-target-not-met{color:#ef4444}.app-theme-kpi-analytics .kpi-result-datapoints{color:#64748b}.app-theme-kpi-analytics .powerbi-dashboard{background:#252d3d;border:1px solid #334155}.app-theme-kpi-analytics .dashboard-header h3{color:#f1f5f9}.app-theme-kpi-analytics .dashboard-header p{color:#94a3b8}.app-theme-kpi-analytics .slicers-section{background:#1e2433;border:1px solid #334155}.app-theme-kpi-analytics .slicers-section h4{color:#e4e8eb}.app-theme-kpi-analytics .slicer-label{color:#cbd5e1}.app-theme-kpi-analytics .slicer-select{background:#252d3d;border-color:#334155;color:#e4e8eb}.app-theme-kpi-analytics .kpi-card{background:#252d3d;border:1px solid #334155;border-left-width:4px}.app-theme-kpi-analytics .kpi-card.target-met{background:linear-gradient(135deg,#22c55e1a,#252d3d);border-left-color:#22c55e}.app-theme-kpi-analytics .kpi-card.target-not-met{background:linear-gradient(135deg,#ef44441a,#252d3d);border-left-color:#ef4444}.app-theme-kpi-analytics .kpi-card-name{color:#e4e8eb}.app-theme-kpi-analytics .kpi-card-unit{background:#1e2433;color:#94a3b8}.app-theme-kpi-analytics .kpi-card-value{color:#f1f5f9}.app-theme-kpi-analytics .kpi-card-footer,.app-theme-kpi-analytics .kpi-card-target{border-top-color:#334155;color:#94a3b8}.app-theme-kpi-analytics .pivot-table-section{background:#1e2433;border:1px solid #334155}.app-theme-kpi-analytics .pivot-table-section h4{color:#e4e8eb}.app-theme-kpi-analytics .pivot-select{background:#252d3d;border-color:#334155;color:#e4e8eb}.app-theme-kpi-analytics .btn-visualization{background:linear-gradient(135deg,#3b82f6,#2563eb)}.app-theme-kpi-analytics .modal-content{background:#252d3d;border:1px solid #334155}.app-theme-kpi-analytics .modal-header{border-bottom-color:#334155}.app-theme-kpi-analytics .modal-header h3{color:#f1f5f9}.app-theme-kpi-analytics .modal-close{color:#94a3b8}.app-theme-kpi-analytics .modal-close:hover{background:#334155;color:#e4e8eb}.app-theme-kpi-analytics .modal-body{color:#cbd5e1}.app-theme-kpi-analytics .modal-actions{border-top-color:#334155}.app-theme-kpi-analytics .btn-cancel{background:#252d3d;border-color:#334155;color:#cbd5e1}.app-theme-kpi-analytics .btn-cancel:hover{background:#334155;color:#e4e8eb}.app-theme-kpi-analytics .btn-save{background:linear-gradient(135deg,#3b82f6,#2563eb)}.app-theme-kpi-analytics .mapping-modal .modal-content{background:#252d3d}.app-theme-kpi-analytics .mapping-description{color:#94a3b8}.app-theme-kpi-analytics .mapping-example-box{background:#3b82f61a;border-color:#334155;color:#93c5fd}.app-theme-kpi-analytics .mapping-item{background:#1e2433;border-color:#334155}.app-theme-kpi-analytics .mapping-label,.app-theme-kpi-analytics .mapping-label strong{color:#cbd5e1}.app-theme-kpi-analytics .mapping-select{background:#252d3d;border-color:#334155;color:#e4e8eb}.app-theme-kpi-analytics .btn-add-column{background:#3b82f633;border-color:#3b82f6;color:#60a5fa}.app-theme-kpi-analytics .btn-remove-column{background:#ef444433;border-color:#334155;color:#f87171}.app-theme-kpi-analytics .mapping-formula-section{background:#3b82f614;border-color:#334155}.app-theme-kpi-analytics .mapping-formula-label{color:#60a5fa}.app-theme-kpi-analytics .mapping-formula-input{background:#1e2433;border-color:#334155;color:#e4e8eb}.app-theme-kpi-analytics .mapping-advanced-section{background:#1e2433;border-color:#334155}.app-theme-kpi-analytics .mapping-preview{background:#252d3d;border-color:#334155;color:#94a3b8}.app-theme-kpi-analytics .kpi-result-group-item{background:#252d3d;border-color:#334155}.app-theme-kpi-analytics .kpi-result-group-name{color:#cbd5e1}.app-theme-kpi-analytics .dax-functions-help{background:#3b82f61a;color:#93c5fd}.app-theme-kpi-analytics .kpi-ps-table td,.app-theme-kpi-analytics .kpi-ps-table th,.app-theme-kpi-analytics .kpi-ps-table tr td,.app-theme-kpi-analytics .kpi-ps-table tr th{border-color:#33415573!important}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;max-width:400px;padding:40px;width:100%}.login-box h2{color:#333;font-size:28px;margin-bottom:30px;text-align:center}.form-group input{border:2px solid #e0e0e0;border-radius:5px;font-size:16px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.error-message{background-color:#fee;border-radius:5px;color:#c33;font-size:14px;margin-bottom:15px;padding:10px}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:transform .2s,box-shadow .2s;width:100%}.login-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.login-hint{background:#f8f9fa;border-radius:5px;color:#666;font-size:13px;margin-top:20px;padding:15px;text-align:left}.login-hint p{font-weight:600;margin:0 0 10px}.example-accounts{margin:10px 0}.account-item{color:#555;font-size:12px;padding:5px 0}.account-item strong{color:#333;margin-right:5px}.demo-note{color:#888;font-size:11px;font-style:italic;margin-top:10px!important}@media (max-width:768px){.login-container{padding:15px}.login-box{padding:30px 25px}.login-box h2{font-size:24px;margin-bottom:25px}.form-group input,.login-button{font-size:15px;padding:11px}}@media (max-width:480px){.login-container{padding:10px}.login-box{padding:25px 20px}.login-box h2{font-size:22px;margin-bottom:20px}.form-group{margin-bottom:15px}.form-group label{font-size:14px}.form-group input,.login-button{font-size:14px;padding:10px}.login-hint{font-size:12px;padding:12px}}.navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:0;transition:opacity .3s ease,transform .3s ease,visibility .3s ease}.App.fullscreen-active .navbar,.App.fullscreen-active nav.navbar,:-moz-full-screen .navbar,:-moz-full-screen body .navbar,:-moz-full-screen body nav.navbar,:-moz-full-screen nav.navbar,:-ms-fullscreen .navbar,:-ms-fullscreen body .navbar,:-ms-fullscreen body nav.navbar,:-ms-fullscreen nav.navbar,:-webkit-full-screen .navbar,:-webkit-full-screen body .navbar,:-webkit-full-screen body nav.navbar,:-webkit-full-screen nav.navbar,:fullscreen .navbar,:fullscreen body .navbar,:fullscreen body nav.navbar,:fullscreen nav.navbar,body.fullscreen-active .navbar,body.fullscreen-active nav.navbar,html.fullscreen-active .navbar,html.fullscreen-active nav.navbar,html:has(body.fullscreen-active) .navbar,html:has(body.fullscreen-active) nav.navbar{display:none!important;height:0!important;left:-9999px!important;margin:0!important;max-height:0!important;opacity:0!important;overflow:hidden!important;padding:0!important;position:absolute!important;top:-9999px!important;transform:translateY(-100%)!important;visibility:hidden!important;width:0!important;z-index:-1!important}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:15px 30px;position:relative}.navbar-brand h1{font-size:24px;font-weight:600;margin:0}.navbar-menu{align-items:center;display:flex;flex:1 1;gap:30px;justify-content:center}.nav-link{border-radius:5px;color:#fff;font-weight:500;padding:8px 15px;text-decoration:none;transition:background-color .3s}.nav-link:hover{background-color:#fff3}.navbar-user{align-items:center;display:flex;gap:15px}.user-name{font-weight:500;text-transform:capitalize}.logout-button{background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:8px 20px;transition:background-color .3s}.logout-button:hover{background:#ffffff4d}.nav-item-with-submenu{position:relative}.nav-item-with-submenu,.nav-item-with-submenu .nav-link{align-items:center;display:flex;height:100%}.submenu-arrow{font-size:10px;line-height:1;margin-left:5px}.submenu{background:#fff;border-radius:5px;box-shadow:0 4px 12px #00000026;left:0;margin-top:5px;min-width:180px;overflow:hidden;position:absolute;top:100%;z-index:1000}.submenu-link{border-bottom:1px solid #f0f0f0;color:#333;display:block;font-weight:500;padding:12px 20px;text-decoration:none;transition:background-color .3s}.submenu-link:last-child{border-bottom:none}.submenu-link:hover{background-color:#f8f9fa;color:#667eea}.mobile-menu-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:999}.mobile-menu-toggle{background:none;border:none;cursor:pointer;display:none;padding:8px;z-index:1001}.mobile-menu-close{display:none}.hamburger{background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;height:20px;justify-content:space-around;padding:0;width:24px}.hamburger span{background-color:#fff;border-radius:3px;height:3px;transform-origin:center;transition:all .3s ease;width:100%}.hamburger.active span:first-child{transform:rotate(45deg) translate(6px,6px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}@media (min-width:1025px){.mobile-menu-close,.mobile-menu-overlay,.mobile-menu-toggle{display:none!important}.navbar-menu{background:#0000!important;box-shadow:none!important;flex:1 1;height:auto!important;justify-content:center;left:auto!important;position:static!important;top:auto!important}.mobile-menu-content,.navbar-menu{align-items:center;display:flex!important;gap:30px;overflow:visible!important;padding:0!important;width:auto!important}.mobile-menu-content{flex:none!important;flex-direction:row!important}.nav-link{border-bottom:none!important;border-radius:5px;color:#fff!important;display:inline-block!important;font-size:inherit!important;font-weight:500;margin:0!important;padding:8px 15px!important;text-align:center;text-decoration:none;transition:background-color .3s;width:auto!important}.nav-item-with-submenu{flex-direction:row!important;margin-top:0!important;position:relative!important}.nav-item-with-submenu,.nav-item-with-submenu .nav-link{align-items:center!important;display:flex!important;height:100%!important;width:auto!important}.nav-item-with-submenu .nav-link{border-bottom:none!important;padding:8px 15px!important}.submenu{background:#fff!important;border-radius:5px!important;box-shadow:0 4px 12px #00000026!important;flex-direction:column!important;left:0!important;margin-top:5px!important;min-width:180px!important;overflow:hidden!important;position:absolute!important;top:100%!important;width:auto!important;z-index:1000!important}.submenu,.submenu-link{display:block!important}.submenu-link{border-bottom:1px solid #f0f0f0!important;color:#333!important;font-size:inherit!important;font-weight:500;padding:12px 20px!important;text-align:left!important;text-decoration:none;transition:background-color .3s}.submenu-link:hover{background-color:#f8f9fa!important;color:#667eea!important}.navbar-user{align-items:center!important;background:#0000!important;border-top:none!important;bottom:auto!important;box-shadow:none!important;display:flex!important;flex-direction:row!important;gap:15px!important;left:auto!important;padding:0!important;position:static!important;top:auto!important;width:auto!important}.user-name{font-size:inherit;font-weight:500;margin:0;text-align:left;text-transform:capitalize}.logout-button{background:#fff3;border:1px solid #ffffff4d;border-radius:5px;color:#fff;cursor:pointer;font-weight:500;padding:8px 20px;transition:background-color .3s;width:auto}.logout-button:hover{background:#ffffff4d}}@media (max-width:1024px){.mobile-menu-overlay,.mobile-menu-toggle{display:block}.navbar-container{padding:12px 20px}.navbar-brand h1{font-size:20px}.navbar-menu{align-items:stretch;background:linear-gradient(180deg,#667eea,#764ba2);box-shadow:2px 0 10px #0003;display:flex;flex-direction:column;gap:0;height:100vh;left:-100%;overflow:hidden;padding:0;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:1000}.navbar-menu.mobile-open{left:0}.mobile-menu-close{align-items:center;background:#0000;border:1px solid #ffffff80;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:300;height:32px;justify-content:center;line-height:1;padding:0;position:absolute;right:15px;top:15px;transition:all .3s ease;width:32px;z-index:1001}.mobile-menu-close:hover{background:#ffffff1a;border-color:#fffc}.mobile-menu-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding-top:60px;width:100%}.nav-link{border-bottom:1px solid #ffffff26;color:#fff;display:block;font-size:16px;font-weight:500;margin:0;padding:15px 20px;text-align:left;transition:background-color .2s ease;width:100%}.nav-link:hover{background-color:#ffffff1a}.navbar-user{align-items:stretch;background:linear-gradient(180deg,#764ba2,#764ba2);border-top:1px solid #fff3;bottom:0;box-shadow:2px 0 10px #0003;flex-direction:column;gap:15px;left:-100%;padding:20px;position:fixed;top:auto;transition:left .3s ease;width:280px;z-index:1000}.navbar-user.mobile-open{left:0}.user-name{font-size:15px;margin:0;text-align:center}.logout-button,.user-name{color:#fff;font-weight:500}.logout-button{background:#ffffff26;border:1px solid #ffffff4d;border-radius:5px;font-size:14px;padding:12px;transition:all .3s ease;width:100%}.logout-button:hover{background:#ffffff40;border-color:#ffffff80}.nav-item-with-submenu{align-items:stretch;display:flex;flex-direction:column;height:auto;margin-top:0;position:static;width:100%}.nav-item-with-submenu .nav-link{align-items:center;display:flex;height:auto;justify-content:space-between;padding:15px 20px;width:100%}.submenu{background:#00000026;border-radius:0;box-shadow:none;display:flex;flex-direction:column;left:auto;margin-left:0;margin-top:0;padding:0;position:static;top:auto;width:100%}.submenu-link{border-bottom:1px solid #ffffff1a;color:#fff;display:block;font-size:15px;padding:14px 20px 14px 40px;text-align:left;transition:background-color .2s ease}.submenu-link:hover{background-color:#ffffff1a;color:#fff}.submenu-link:last-child{border-bottom:none}.submenu-arrow{font-size:12px;opacity:.8}}@media (max-width:768px){.navbar-container{padding:12px 15px}.navbar-brand h1{font-size:18px}.navbar-menu,.navbar-user{max-width:320px;width:100%}}@media (max-width:480px){.navbar-container{padding:10px 12px}.navbar-brand h1{font-size:16px}.navbar-menu{width:100%}.nav-link{font-size:13px;padding:12px}.user-name{font-size:12px}.logout-button{font-size:12px;padding:8px}}.dashboard{box-sizing:border-box;display:flex;margin:0;max-width:100%;min-height:100vh;overflow-x:hidden;padding:0;width:100%}.dashboard-content{box-sizing:border-box;flex:1 1;margin-left:50px;transition:margin-left .3s ease,width .3s ease;width:calc(100% - 50px)}.dashboard-content.toolbar-hidden{margin-left:0;width:100%}.dashboard-content.fullscreen-mode .dashboard-toolbar,.dashboard-content.fullscreen-mode .toolbar-toggle-btn-float{display:none!important}.dashboard-content.fullscreen-mode{margin-left:0!important;padding:0!important;width:100%!important}.dashboard-toolbar{align-items:center;background:linear-gradient(180deg,#667eea,#764ba2);border-radius:0 12px 12px 0;box-shadow:2px 0 10px #667eea4d;display:flex;flex-direction:column;left:0;max-height:90vh;overflow-y:auto;padding:12px 0;position:fixed;top:50%;transform:translateY(-50%);transition:left .3s ease,transform .3s ease;width:45px;z-index:1000}.dashboard-toolbar.hidden{left:-45px}.dashboard-toolbar.visible{left:0}.toolbar-toggle-btn{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;margin-bottom:15px;transition:all .2s;width:32px}.toolbar-toggle-btn:hover{background:#fff3;transform:scale(1.1)}.toolbar-toggle-btn svg{height:16px;width:16px}.toolbar-toggle-btn-float{align-items:center;background:linear-gradient(180deg,#667eea,#764ba2);border:none;border-radius:0 8px 8px 0;box-shadow:2px 0 8px #667eea4d;cursor:pointer;display:flex;height:36px;justify-content:center;left:0;position:fixed;top:50%;transform:translateY(-50%);transition:all .3s ease;width:36px;z-index:1001}.toolbar-toggle-btn-float.toolbar-visible{left:45px}.toolbar-toggle-btn-float.toolbar-hidden{left:0}.toolbar-toggle-btn-float:hover{background:linear-gradient(180deg,#764ba2,#667eea);box-shadow:2px 0 12px #667eea80;transform:translateY(-50%) scale(1.1)}.toolbar-toggle-btn-float svg{height:16px;width:16px}.toolbar-logo{align-items:center;cursor:pointer;display:flex;height:32px;justify-content:center;margin-bottom:15px;transition:transform .2s;width:32px}.toolbar-logo:hover{transform:scale(1.1)}.toolbar-logo svg{height:100%;width:100%}.toolbar-icons{flex-direction:column;gap:8px;width:100%}.toolbar-icon,.toolbar-icons{align-items:center;display:flex}.toolbar-icon{background:#0000;border:none;border-radius:6px;color:#fff;cursor:pointer;height:32px;justify-content:center;position:relative;transition:all .2s;width:32px}.toolbar-icon svg{height:18px;width:18px}.toolbar-icon:hover{background:#ffffff1a;transform:scale(1.1)}.toolbar-icon.active{background:#fff3;box-shadow:0 2px 8px #0000004d}.toolbar-icon.active:before{background:#4caf50;border-radius:0 3px 3px 0;content:"";height:60%;left:0;position:absolute;top:50%;transform:translateY(-50%);width:3px}.dashboard-toolbar::-webkit-scrollbar{width:4px}.dashboard-toolbar::-webkit-scrollbar-track{background:#0000}.dashboard-toolbar::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.dashboard-toolbar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.dashboard-header{margin-bottom:30px}.dashboard-header h2{color:#333;font-size:32px;margin-bottom:10px}.dashboard-header p{color:#666;font-size:16px}.dashboard-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.dashboard-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:25px;transition:transform .2s,box-shadow .2s}.dashboard-card:hover{box-shadow:0 5px 20px #00000026;transform:translateY(-5px)}.dashboard-card h3{color:#333;font-size:20px;margin-bottom:10px}.dashboard-card p{color:#666;font-size:14px;margin-bottom:20px}.card-stats{display:flex;flex-direction:column;gap:5px}.stat-value{font-size:36px}.stat-label{color:#888}@media (max-width:1024px){.dashboard{padding:20px}.dashboard-header h2{font-size:28px}.dashboard-grid{gap:15px}}@media (max-width:768px){.dashboard{padding:15px}.dashboard-header h2{font-size:24px}.dashboard-header p{font-size:14px}.dashboard-grid{gap:15px;grid-template-columns:1fr}.dashboard-card{padding:20px}.dashboard-card h3{font-size:18px}.stat-value{font-size:32px}}@media (max-width:480px){.dashboard{padding:10px}.dashboard-header h2{font-size:20px}.dashboard-card{padding:15px}.stat-value{font-size:28px}}.trailer-section{background:#f5f5f5;border-radius:0;box-sizing:border-box;display:block;margin-bottom:0;margin-top:0;overflow-x:hidden;overflow-y:visible;padding:20px 15px;position:relative;width:100%}.trailer-section-title{color:#333;font-size:24px;font-weight:600;margin-bottom:20px;text-align:center}.trailer-tables-container{box-sizing:border-box;display:flex;flex-direction:row;gap:12px;overflow-x:auto;overflow-y:visible;padding:0;position:relative;width:100%}.trailer-tables-container::-webkit-scrollbar{height:8px}.trailer-tables-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.trailer-tables-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.trailer-tables-container::-webkit-scrollbar-thumb:hover{background:#555}.trailer-table-wrapper{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 10px #0000001a;flex:1 1;max-width:calc(33.333% - 8px);min-width:0;overflow:visible;padding:12px;position:relative;z-index:1}.card-header-compact{align-items:flex-start;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e3f2fd;border-radius:8px;box-shadow:0 2px 8px #667eea1a;box-sizing:border-box;display:flex;flex-wrap:nowrap;gap:8px;margin-bottom:15px;overflow:hidden;padding:10px;width:100%}.last-update-section{align-items:center;background:linear-gradient(135deg,#f0f4ff,#e8f0ff);border:1px solid #c5d5ff;border-radius:6px;box-shadow:0 1px 4px #667eea14;display:flex;gap:12px;margin-bottom:12px;padding:8px 12px}.last-update-label{color:#667eea;font-size:14px;font-weight:600;margin:0;white-space:nowrap}.last-update-time{background:#fff;border:1px solid #cbd5e0;border-radius:4px;box-shadow:inset 0 1px 2px #0000000d;color:#4a5568;font-family:Courier New,monospace;font-size:15px;font-weight:700;letter-spacing:.5px;min-width:60px;padding:6px 12px;text-align:center}.extended-columns-toggle{align-items:center;display:flex;gap:8px;margin-left:auto}.toggle-switch-label{cursor:pointer;display:inline-block;height:24px;position:relative;width:44px}.toggle-switch-input{height:0;opacity:0;width:0}.toggle-switch-slider{background-color:#cbd5e0;border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-switch-slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;position:absolute;transition:.3s;width:18px}.toggle-switch-input:checked+.toggle-switch-slider{background-color:#667eea}.toggle-switch-input:checked+.toggle-switch-slider:before{transform:translateX(20px)}.toggle-switch-input:disabled+.toggle-switch-slider{cursor:not-allowed;opacity:.5}.toggle-switch-text{color:#4a5568;font-size:13px;font-weight:500;white-space:nowrap}.card-number-large{align-items:center;align-self:stretch;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #ffffff4d;border-radius:8px;box-shadow:0 4px 12px #667eea4d;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:28px;font-weight:800;height:auto;justify-content:center;line-height:1;min-width:50px;padding:0;text-align:center;transition:all .3s ease;-webkit-user-select:none;user-select:none;width:50px}.card-number-large.disabled{cursor:default!important;pointer-events:none}.assignment-cell.disabled{cursor:not-allowed;pointer-events:none}.assignment-cell.disabled .assigned-user-badge,.assignment-cell.disabled .assignment-drop-zone{cursor:not-allowed}.card-number-large.card-number-hover,.card-number-large:hover{background:linear-gradient(135deg,#f44336,#d32f2f);border-color:#fff6;box-shadow:0 4px 12px #f4433666;transform:scale(1.05)}.card-number-large:active{box-shadow:0 2px 8px #f443364d;transform:scale(.98)}.card-fields-grid{align-items:flex-start;display:flex;flex:1 1;flex-wrap:nowrap;gap:6px;min-width:0;overflow:visible}.card-field-item{display:flex;flex:1 1;flex-direction:column;gap:4px}.card-field-item.trailer-field{flex:1.5 1;max-width:180px;min-width:120px}.card-field-item.status-field{flex:0.75 1;max-width:95px;min-width:80px}.card-field-label{color:#667eea;font-size:11px;font-weight:700;letter-spacing:.3px;line-height:1.2;margin-bottom:2px;text-transform:uppercase}.card-field-input,.card-field-select{background-color:#fff;border:2px solid #e0e0e0;border-radius:6px;box-shadow:0 1px 3px #0000000d;box-sizing:border-box;color:#333;font-size:16px;font-weight:600;height:38px;line-height:1;max-width:100%;min-width:0;padding:8px 10px;transition:all .2s;width:100%}.card-field-input:focus,.card-field-select:focus{background-color:#f8f9ff;border-color:#667eea;box-shadow:0 0 0 3px #667eea26,0 2px 8px #667eea33;outline:none}.card-field-input.validation-error,.table-input.validation-error{background-color:#fff5f5!important;border-color:#f44336!important;border-width:2px!important;box-shadow:0 0 0 3px #f4433626,0 2px 8px #f4433633!important}.card-field-input.validation-error:focus,.table-input.validation-error:focus{border-color:#d32f2f!important;box-shadow:0 0 0 3px #f4433640,0 2px 8px #f443364d!important}.card-field-input:hover,.card-field-select:hover{border-color:#667eea;box-shadow:0 2px 6px #667eea26}.card-field-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;padding-right:30px}.status-select-wrapper-compact{height:42px;position:relative;width:100%}.status-select-wrapper-compact .status-arrow{color:#667eea;font-size:12px;font-weight:700;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);z-index:10}.reset-card-btn-compact{align-items:center;align-self:flex-end;background:linear-gradient(135deg,#f44336,#d32f2f);border:2px solid #fff3;border-radius:6px;box-shadow:0 3px 8px #f443364d;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:10px;font-weight:700;height:38px;justify-content:center;letter-spacing:.2px;margin-left:4px;margin-top:18px;max-width:85px;min-width:70px;opacity:1;padding:0 12px;text-transform:uppercase;transition:all .2s;visibility:visible;white-space:nowrap}.reset-card-btn-compact:hover{background:linear-gradient(135deg,#d32f2f,#c62828);box-shadow:0 4px 12px #f4433666;transform:translateY(-1px)}.reset-card-btn-compact:active{box-shadow:0 1px 3px #f4433633;transform:translateY(0)}.card-header{margin-bottom:15px}.card-number{color:#333;font-size:24px;font-weight:700;line-height:1}.date-time-row{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;gap:15px;margin-bottom:20px;padding-bottom:15px;width:100%}.date-container,.time-container{align-items:center;display:flex;flex:0 0 auto;gap:6px}.bottom-row{border-bottom:2px solid #e0e0e0;gap:20px;justify-content:space-between;padding-bottom:15px}.bottom-row,.reset-button-container{align-items:center;display:flex;margin-bottom:15px}.reset-button-container{justify-content:center;padding-bottom:10px}.reset-card-btn{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:10px 20px;text-transform:uppercase;transition:background-color .2s,transform .2s}.reset-card-btn:hover{background:#d32f2f;box-shadow:0 2px 6px #f443364d;transform:translateY(-1px)}.reset-card-btn:active{box-shadow:0 1px 3px #f4433633;transform:translateY(0)}.trailer-container{flex:1 1}.status-container,.trailer-container{align-items:center;display:flex;gap:10px}.status-container{position:relative;z-index:100}.status-select-wrapper{align-items:center;display:flex;position:relative;width:90px}.status-arrow{color:#9c88ff;font-size:12px;font-weight:700;pointer-events:none;position:absolute;right:10px;top:50%;transform:translateY(-50%);-webkit-user-select:none;user-select:none;z-index:102}.field-label{color:#333;font-size:14px;font-weight:600;white-space:nowrap}.trailer-label{font-weight:700}.trailer-input{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;font-size:14px;font-weight:600;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:120px}.trailer-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.trailer-input:hover{border-color:#999}.date-input{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;font-size:13px;font-weight:600;padding:8px 10px;transition:border-color .2s,box-shadow .2s;width:140px}.date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7}.date-input::-webkit-calendar-picker-indicator:hover{opacity:1}.date-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.date-input:hover{border-color:#999}.time-input{background-color:#fff;border:1px solid #ccc;border-radius:4px;color:#333;font-size:13px;font-weight:600;padding:8px 10px;transition:border-color .2s,box-shadow .2s;width:100px}.time-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.7}.time-input::-webkit-calendar-picker-indicator:hover{opacity:1}.time-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.time-input:hover{border-color:#999}.status-select{background-color:#fff!important;background-image:none;border:2px solid #9c88ff;border-radius:4px;box-shadow:0 2px 4px #9c88ff33;color:#333!important;font-size:15px;font-weight:700;line-height:1.5;padding:10px 30px 10px 12px;position:relative;transition:all .2s;width:100%;z-index:101}.status-select:focus{background-color:#f8f9ff;border-color:#667eea;box-shadow:0 0 0 3px #667eea40,0 2px 6px #00000026;outline:none}.status-select:hover{background-color:#f8f9ff;border-color:#7c6aff;box-shadow:0 2px 6px #9c88ff4d}.status-select-wrapper:hover .status-arrow{color:#667eea;transform:translateY(-50%) scale(1.2)}.status-select option{background-color:#fff!important;border:none;color:#333!important;font-size:14px;font-weight:600;padding:10px 12px}.status-select option:checked,.status-select option[selected]{background-color:#667eea!important;color:#fff!important}.status-select option:hover{background-color:#f0f0f0!important}.status-select,.status-select:focus,.status-select:hover{background-color:#fff!important;color:#333!important}.trailer-table-wrapper select{max-width:100%}@supports (-webkit-appearance:none){.status-select{max-width:90px}}.trailer-table{box-sizing:border-box;display:flex;flex-direction:column;margin-top:10px;min-width:0;overflow-x:auto;width:100%}.trailer-table:has(.table-header-row.extended-columns){min-width:525px}.table-header-row{grid-gap:0;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:2px solid #667eea;display:grid;font-size:11px;font-weight:600;gap:0;grid-auto-flow:row;grid-template-columns:50px 70px 55px 55px 150px 1fr;overflow:visible}.table-header-cell{align-items:center;border-right:1px solid #ddd;box-sizing:border-box;color:#333;display:flex;font-size:10px;justify-content:center;min-width:0;overflow:hidden;padding:6px 3px;text-align:center;white-space:nowrap}.table-header-cell:first-child,.table-header-cell:nth-child(10),.table-header-cell:nth-child(2),.table-header-cell:nth-child(3),.table-header-cell:nth-child(4),.table-header-cell:nth-child(5),.table-header-cell:nth-child(6),.table-header-cell:nth-child(7),.table-header-cell:nth-child(8),.table-header-cell:nth-child(9){font-size:15px;font-weight:700}.table-header-cell:last-child{border-right:none}.table-data-row{grid-gap:0;border-bottom:1px solid #e0e0e0;display:grid;font-size:12px;gap:0;grid-auto-flow:row;grid-template-columns:50px 70px 55px 55px 150px 1fr;height:auto;min-height:40px;overflow:visible}.table-data-row.extended-columns,.table-header-row.extended-columns{grid-auto-flow:row!important;grid-template-columns:50px 70px 55px 55px 50px 50px 50px 50px 50px 50px!important;min-width:525px;overflow:visible!important}.settings-icon-container{align-items:center;display:flex;justify-content:flex-start;margin-top:20px;padding:20px 0 10px 15px}.settings-icon-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:24px;height:50px;justify-content:center;transition:all .3s;width:50px;z-index:1000}.settings-icon-btn:hover{background:#5568d3;box-shadow:0 6px 16px #667eea80;transform:scale(1.1)}.settings-icon-btn:active{transform:scale(.95)}.assignment-icon-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:grab;display:flex;font-size:24px;height:50px;justify-content:center;position:fixed;transition:all .3s;-webkit-user-select:none;user-select:none;width:50px;z-index:1000}.assignment-icon-btn:active{cursor:grabbing}.assignment-icon-btn:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);box-shadow:0 6px 16px #667eea80;transform:scale(1.1)}.assignment-icon-btn:active{background:linear-gradient(135deg,#4d5fc4,#5d387e);transform:scale(.95)}.modal-overlay{pointer-events:auto;z-index:2000}.modal-content{border-radius:8px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:80vh;overflow:hidden}.history-modal-content{max-height:90vh}.modal-header{background:#f8f9fa;border-bottom:2px solid #e0e0e0;padding:20px}.modal-header h3{color:#333;font-weight:600}.modal-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-close-btn:hover{background:#e0e0e0;color:#333}.modal-body{flex:1 1;overflow-y:auto;padding:20px}.history-modal-body{display:flex;flex-direction:column;overflow-y:hidden}.history-content{display:flex;flex:1 1;flex-direction:column;min-height:0}.seq-list h4{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.seq-items{margin-bottom:20px;max-height:300px;overflow-y:auto}.seq-item{align-items:center;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px;padding:12px}.seq-item-content{display:flex;flex:1 1;flex-direction:column;gap:8px}.seq-item-label{color:#333;font-size:14px;font-weight:600}.seq-description-input{background:#fff;border:1px solid #ddd;border-radius:4px;color:#333;font-size:13px;padding:6px 10px;transition:border-color .2s,box-shadow .2s;width:100%}.seq-description-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.seq-description-input::placeholder{color:#999;font-style:italic}.seq-delete-btn{background:#f44336;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:6px 12px;transition:background-color .2s}.seq-delete-btn:hover{background:#d32f2f}.bulk-add-section{border-top:2px solid #e0e0e0;margin-top:25px;padding-top:25px}.bulk-add-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 10px}.bulk-add-hint{color:#666;font-size:13px;margin:0 0 10px}.bulk-seq-textarea{border:2px solid #ddd;border-radius:4px;box-sizing:border-box;font-family:monospace;font-size:14px;margin-bottom:12px;min-height:120px;padding:12px;resize:vertical;width:100%}.bulk-seq-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.bulk-add-btn{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:background-color .2s,transform .2s;width:100%}.bulk-add-btn:hover{background:#1976d2;transform:translateY(-2px)}.bulk-add-btn:active{transform:translateY(0)}.modal-actions{border-top:2px solid #e0e0e0;justify-content:center;padding-top:15px}.add-seq-btn{background:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:background-color .2s,transform .2s}.add-seq-btn:hover{background:#45a049;transform:translateY(-2px)}.add-seq-btn:active{transform:translateY(0)}.table-data-row:hover{background:#f8f9fa}.table-data-row.row-in-progress{background-color:#f4e4bc}.table-data-row.row-in-progress:hover{background-color:#e6d5b8}.table-data-row.row-completed{background-color:#81c784}.table-data-row.row-completed:hover{background-color:#66bb6a}.table-data-cell{align-items:center;border-right:1px solid #e0e0e0;box-sizing:border-box;color:#333;display:flex;height:100%;justify-content:center;min-height:40px;overflow:hidden;padding:5px 3px;text-align:center}.table-data-cell:last-child{border-right:none}.j-cell,.seq-cell{align-items:center;color:#555;display:flex;font-size:15px;font-weight:700;height:100%;justify-content:center;width:100%}.seq-cell{cursor:help;position:relative}.seq-cell:hover{background-color:#f0f0f0}.seq-cell-with-tooltip{cursor:help;position:relative}.seq-cell-with-tooltip:before{word-wrap:break-word;background-color:#333;border-radius:4px;bottom:calc(100% + 8px);box-shadow:0 2px 8px #0003;color:#fff;content:attr(data-tooltip);font-size:13px;font-weight:400;line-height:1.4;max-width:300px;min-width:150px;padding:8px 12px;text-align:left;white-space:normal;z-index:10000}.seq-cell-with-tooltip:after,.seq-cell-with-tooltip:before{left:50%;opacity:0;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s ease-in-out}.seq-cell-with-tooltip:after{border:5px solid #0000;border-top-color:#333;bottom:calc(100% + 3px);content:"";z-index:10001}.seq-cell-with-tooltip:hover:after,.seq-cell-with-tooltip:hover:before{opacity:1}.table-input{-webkit-appearance:textfield;appearance:textfield;background-color:#fff;border:1px solid #ddd;border-radius:3px;box-sizing:border-box;color:#333;font-size:15px;font-weight:600;height:auto;min-height:30px;padding:4px 2px;text-align:center;transition:border-color .2s,box-shadow .2s;width:100%}.table-input::-webkit-inner-spin-button,.table-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.comment-cell{align-items:flex-start!important;height:100%;min-height:40px;padding:5px 3px!important}.table-input-comment{background-color:#fff;border:1px solid #ddd;box-sizing:border-box;font-family:Arial,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:15px;font-style:normal;font-weight:400;max-height:30px;min-height:30px;min-width:0;padding:4px 8px;resize:none;text-align:left;transition:background-color .2s;width:100%}.comment-cell{overflow:hidden;position:relative}.comment-assigned-container{gap:4px;justify-content:flex-start;left:3px;pointer-events:none;position:absolute;right:3px;top:5px;z-index:2}.comment-assigned-badge,.comment-assigned-container{align-items:center;display:flex;height:30px;overflow:hidden}.comment-assigned-badge{border:2px solid #2196f3;border-radius:6px;box-sizing:border-box;color:#1565c0;font-size:13px;font-weight:700;gap:6px;max-height:30px;max-width:150px;padding:4px 8px;pointer-events:auto;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap;width:auto}.comment-remove-assignment-btn{align-items:center;background:#f44336;border:none;border-radius:50%;box-shadow:0 1px 3px #f443364d;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:700;height:16px;justify-content:center;line-height:1;padding:0;width:16px}.comment-remove-assignment-btn:disabled{cursor:not-allowed;opacity:.6}.table-input-comment.with-badge{padding-top:4px}.table-input-comment.has-comment{background-color:#ffd54f;border-radius:3px;font-family:inherit;font-weight:500;line-height:1.4}.table-input-readonly.ocz-calculated{align-items:center;background-color:#f5f5f5;border:1px solid #ddd;border-radius:3px;box-sizing:border-box;color:#333;cursor:not-allowed;display:flex;font-size:15px;font-weight:600;height:auto;justify-content:center;min-height:30px;padding:4px 8px;text-align:center;-webkit-user-select:none;user-select:none}.table-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26;outline:none}.table-input:hover{border-color:#999}.zainfekowane-cell{font-weight:500}.zainfekowane-input{color:#d32f2f}.zainfekowane-input:focus{border-color:#d32f2f;box-shadow:0 0 0 2px #d32f2f26}@media (max-width:1400px){.trailer-table-wrapper{max-width:calc(33.333% - 8px)}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){grid-template-columns:65px 50px 50px 140px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{grid-template-columns:50px 60px 50px 50px 45px 45px 45px 45px 45px 45px!important}.table-header-cell{font-size:9px;padding:5px 2px}.table-data-cell{min-height:32px;padding:4px 2px}.table-input{font-size:10px;padding:3px 2px}.table-input-comment{font-size:10px;max-height:28px;min-height:28px}}@media (max-width:1200px){.trailer-tables-container{flex-direction:row;gap:10px}.trailer-table-wrapper{max-width:calc(33.333% - 7px);padding:10px}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){grid-template-columns:60px 45px 45px 90px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{grid-template-columns:45px 55px 45px 45px 40px 40px 40px 40px 40px 40px!important}}@media (max-width:768px){.trailer-section{box-sizing:border-box;overflow-x:auto;padding:10px 5px;width:100%}.trailer-tables-container{flex-direction:row;gap:15px;min-width:100%;overflow-x:auto;overflow-y:visible;padding-bottom:10px;width:-webkit-max-content;width:max-content}.trailer-table-wrapper{box-sizing:border-box;flex:0 0 auto;max-width:420px;min-width:420px;padding:10px;width:420px}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){font-size:11px;grid-template-columns:50px 70px 55px 55px 120px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{font-size:11px;grid-template-columns:50px 70px 55px 55px 45px 45px 45px 45px 45px 45px!important}.table-header-cell{font-size:11px;padding:4px 2px}.table-data-cell,.table-input{padding:4px 2px}.table-input{font-size:12px}.table-input-comment{font-size:12px;max-height:25px;min-height:25px;padding:3px 4px}.card-header-compact{box-sizing:border-box;flex-wrap:wrap;gap:8px;padding:8px}.reset-card-btn-compact{flex-shrink:0;min-width:auto;width:auto}.card-number-large{font-size:24px;height:38px;min-width:45px}.card-fields-grid{flex:1 1;gap:6px;min-width:0}.card-field-item{flex:1 1 auto;min-width:0}.card-field-label{font-size:11px}.card-field-input,.card-field-select{font-size:16px;height:38px;padding:8px 10px}.reset-card-btn-compact{font-size:11px;height:38px;margin-top:0;padding:0 12px}.trailer-section::-webkit-scrollbar{height:8px}.trailer-section::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.trailer-section::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.trailer-section::-webkit-scrollbar-thumb:hover{background:#555}}@media (max-width:480px){.trailer-section{box-sizing:border-box;overflow-x:auto;padding:8px 5px;scroll-behavior:smooth;width:100%}.trailer-tables-container{flex-direction:row;gap:12px;min-width:100%;overflow-x:visible;overflow-y:visible;padding-bottom:10px;width:-webkit-max-content;width:max-content}.trailer-table-wrapper{box-sizing:border-box;flex:0 0 auto;max-width:380px;min-width:380px;padding:8px;width:380px}.table-data-row:not(.extended-columns),.table-header-row:not(.extended-columns){font-size:10px;gap:2px;grid-template-columns:45px 65px 50px 50px 110px 1fr}.table-data-row.extended-columns,.table-header-row.extended-columns{font-size:10px;gap:2px;grid-template-columns:45px 65px 50px 50px 40px 40px 40px 40px 40px 40px!important}.table-header-cell{font-size:10px;padding:4px 1px}.table-header-cell:first-child,.table-header-cell:nth-child(2),.table-header-cell:nth-child(3),.table-header-cell:nth-child(4),.table-header-cell:nth-child(5),.table-header-cell:nth-child(6){font-size:11px}.table-data-cell{font-size:10px;padding:4px 1px}.table-input{font-size:11px;padding:3px 1px}.table-input-comment{font-size:11px;max-height:22px;min-height:22px;padding:2px 3px}.j-cell,.seq-cell{font-size:11px}.trailer-table-header{font-size:12px;grid-template-columns:50px 15px 40px 50px}.dashboard-content{margin-left:0;width:100%}.dashboard-toolbar{left:-45px}.toolbar-toggle-btn-float{left:0}.card-header-compact{flex-direction:column;gap:10px;padding:8px}.card-number-large{align-self:center;font-size:24px;height:50px;width:50px}.card-fields-grid{flex-direction:column;gap:8px;width:100%}.card-field-item{width:100%}.reset-card-btn-compact{margin-top:0;width:100%}.modal-content{overflow-y:auto}.assignment-modal-content,.modal-content,.reminder-modal-content,.settings-modal-content{margin:10px;max-height:90vh;max-width:95%;padding:15px;width:95%}.reminder-popup{max-width:90%;padding:15px;width:90%}.reminder-popup-header h3{font-size:18px}.reminder-popup-title{font-size:16px}.reminder-popup-description{font-size:14px}.reminder-popup-footer{flex-direction:column;gap:10px}.reminder-postpone-section{flex-direction:column;gap:8px;width:100%}.reminder-popup-confirm-btn,.reminder-postpone-btn{width:100%}.confirm-delete-modal{max-width:90%;padding:15px;width:90%}.modal-footer{flex-direction:column;gap:10px}.confirm-delete-cancel-btn,.confirm-delete-ok-btn{width:100%}.excel-table-container,.seq-excel-table-wrapper{max-width:100%;overflow-x:auto}.excel-table,.seq-excel-table{min-width:500px}.seq-excel-th-j,.seq-excel-th-opis,.seq-excel-th-seq{font-size:11px;min-width:80px;padding:6px 4px}.seq-excel-input{font-size:12px;padding:6px 8px}.reminder-modal-tabs{flex-direction:column}.reminder-tab-btn{border-radius:0;width:100%}.reminder-days-checkboxes,.reminder-form-row{flex-direction:column;gap:8px}.reminder-day-checkbox-label{width:100%}.reminder-item{flex-direction:column;gap:10px}.reminder-delete-checkbox-label,.reminder-delete-selected-btn{width:100%}.history-tabs{flex-direction:column}.history-tab-btn{width:100%}.history-item-header{flex-direction:column;gap:5px}}@media (max-width:1024px) and (min-width:769px){.dashboard-content{margin-left:45px;width:calc(100% - 45px)}.card-header-compact{flex-wrap:nowrap;gap:10px;padding:12px}.card-fields-grid{flex:1 1;flex-wrap:nowrap;min-width:0}.card-field-item{flex:1 1 auto;min-width:100px}.reset-card-btn-compact{flex-shrink:0}.assignment-modal-content,.modal-content,.reminder-modal-content,.settings-modal-content{max-width:600px;width:85%}.reminder-popup{max-width:500px;width:80%}.confirm-delete-modal{max-width:400px;width:80%}.seq-excel-table{min-width:550px}.reminder-days-checkboxes{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}}.assignment-cell{height:100%;min-height:40px;padding:5px 3px;position:relative;transition:background-color .2s;z-index:1}.assignment-cell,.assignment-drop-zone{align-items:center;box-sizing:border-box;display:flex;justify-content:center;overflow:hidden}.assignment-drop-zone{border:2px dashed #ccc;border-radius:4px;color:#999;font-size:10px;height:30px;min-height:30px;padding:4px 2px;pointer-events:none;text-align:center;transition:all .2s;width:100%}.assignment-cell:hover .assignment-drop-zone{background-color:#f0f4ff;border-color:#667eea;color:#667eea}.assignment-cell.drag-over{background-color:#e3f2fd!important;border:2px solid #2196f3!important}.assignment-cell.drag-over .assignment-drop-zone{background-color:#bbdefb;border-color:#2196f3;color:#1976d2}.assigned-user-badge{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;border-radius:6px;box-shadow:0 2px 4px #2196f333;box-sizing:border-box;color:#1565c0;flex-shrink:0;font-size:13px;gap:6px;height:30px;justify-content:space-between;max-height:30px;overflow:hidden;padding:4px 8px;text-transform:uppercase;width:100%}.assigned-user-badge,.remove-assignment-btn{align-items:center;display:flex;font-weight:700;transition:all .2s}.remove-assignment-btn{background:#f44336;border:none;border-radius:50%;box-shadow:0 1px 3px #f443364d;color:#fff;cursor:pointer;font-size:16px;height:20px;justify-content:center;line-height:1;padding:0;width:20px}.remove-assignment-btn:hover{background:#d32f2f;box-shadow:0 2px 5px #f4433666;transform:scale(1.1)}.assigned-user-badge:hover{box-shadow:0 3px 6px #0003;opacity:.9;transform:translateY(-1px)}.assignment-modal-overlay{background:#0000!important;pointer-events:none;z-index:2000}.assignment-modal-overlay>*{pointer-events:auto}.assignment-modal-content{max-width:90vw;-webkit-user-select:none;user-select:none;width:350px}.assignment-modal-header{cursor:grab;-webkit-user-select:none;user-select:none}.assignment-modal-header:active{cursor:grabbing}.assignment-modal-body{max-height:400px;overflow-y:auto}.assignment-hint{color:#666;font-size:13px;font-style:italic;margin:0 0 15px;text-align:center}.users-list{display:flex;flex-direction:column;gap:8px}.user-item{align-items:center;background:#f5f5f5;border:2px solid #ddd;border-radius:6px;color:#333;cursor:grab;display:flex;font-size:14px;font-weight:500;justify-content:space-between;padding:12px 16px;position:relative;transition:all .2s;-webkit-user-select:none;user-select:none}.user-item:hover{background:#e3f2fd;border-color:#2196f3;transform:translateX(5px)}.user-item:active{cursor:grabbing;opacity:.7}.user-item.dragging{opacity:.5}.user-item.user-assigned{background:#e0e0e0;border-color:#bdbdbd;color:#757575;cursor:not-allowed;opacity:.6}.user-item.user-assigned:hover{background:#e0e0e0;border-color:#bdbdbd;transform:none}.assigned-badge{color:#4caf50;font-size:11px;font-weight:600;margin-left:8px}.no-users-message{color:#999;font-style:italic;padding:20px;text-align:center}.seq-excel-table-container{width:100%}.seq-excel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.seq-excel-header h4{color:#333;font-size:16px;font-weight:600;margin:0}.seq-excel-actions{display:flex;gap:10px}.seq-add-row-btn,.seq-remove-row-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:background-color .2s}.seq-add-row-btn:hover{background:#5568d3}.seq-remove-row-btn{background:#f44336}.seq-remove-row-btn:hover:not(:disabled){background:#d32f2f}.seq-remove-row-btn:disabled{background:#ccc;cursor:not-allowed}.seq-excel-table-wrapper{border:1px solid #ddd;border-radius:4px;max-height:500px;overflow-x:auto;overflow-y:auto}.seq-excel-table{background:#fff;border-collapse:collapse;width:100%}.seq-excel-th{background:#f8f9fa;border-bottom:2px solid #ddd;border-right:1px solid #ddd;color:#333;font-size:13px;font-weight:600;padding:10px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:10}.seq-excel-th:last-child{border-right:none}.seq-excel-th-j{min-width:80px;width:80px}.seq-excel-th-seq{min-width:150px;width:150px}.seq-excel-th-opis{min-width:200px;width:auto}.seq-excel-row{border-bottom:1px solid #e0e0e0}.seq-excel-row:hover{background:#f8f9fa}.seq-excel-cell{border-right:1px solid #e0e0e0;padding:0;vertical-align:middle}.seq-excel-cell:last-child{border-right:none}.seq-excel-input{background:#0000;border:none;box-sizing:border-box;color:#333;font-family:inherit;font-size:13px;outline:none;padding:8px 10px;width:100%}.seq-excel-input:focus{background:#fff;box-shadow:inset 0 0 0 2px #667eea}.seq-excel-input::placeholder{color:#999;font-style:italic}.seq-excel-cell-j .seq-excel-input{font-weight:600;text-align:center}.seq-excel-cell-seq .seq-excel-input{font-weight:600}.seq-excel-input.selected{background:#e3f2fd!important;box-shadow:inset 0 0 0 2px #2196f3}.seq-excel-input.selected:focus{background:#fff!important;box-shadow:inset 0 0 0 2px #667eea}.reminder-modal-content{max-height:80vh;max-width:600px;overflow-y:auto}.reminder-modal-tabs{border-bottom:2px solid #e0e0e0;display:flex;margin:0;padding:0}.reminder-tab{background:#f5f5f5;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:15px 20px;text-align:center;transition:all .2s}.reminder-tab:hover{background:#eee;color:#333}.reminder-tab.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.reminder-delete-section{padding:20px 0}.reminder-delete-section h4{color:#333;font-size:16px;font-weight:600;margin:0 0 20px}.reminders-delete-list{margin-bottom:20px;max-height:400px;overflow-y:auto}.reminder-delete-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:12px;transition:all .2s}.reminder-delete-item:hover{background:#f0f0f0;border-color:#667eea}.reminder-delete-checkbox-label{align-items:flex-start;cursor:pointer;display:flex;gap:12px;margin:0;padding:15px}.reminder-delete-checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.reminder-delete-item-content{flex:1 1}.reminder-delete-item-title{color:#333;font-size:15px;font-weight:700;margin-bottom:6px}.reminder-delete-item-description{color:#666;font-size:13px;line-height:1.4;margin-bottom:8px}.reminder-delete-item-details{margin-top:8px}.reminder-delete-selected-btn{background:#f44336;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:background-color .2s,transform .2s;width:100%}.reminder-delete-selected-btn:hover:not(:disabled){background:#d32f2f;transform:translateY(-1px)}.reminder-delete-selected-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.history-clear-section{margin-bottom:30px}.history-clear-section h4{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.history-delete-list{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;max-height:400px;overflow-y:auto;padding:10px}.history-delete-item{background:#fff;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:10px;transition:all .2s}.history-delete-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea26}.history-delete-checkbox-label{align-items:flex-start;cursor:pointer;display:flex;gap:12px;margin:0;padding:15px}.history-delete-checkbox-label input[type=checkbox]{cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.history-delete-item-content{flex:1 1}.history-delete-item-title{color:#333;font-size:15px;font-weight:700;margin-bottom:8px}.history-delete-item-details{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.history-badge{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:4px;color:#666;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.history-delete-actions{border-top:2px solid #e0e0e0;margin-top:20px;padding-top:20px}.history-delete-btn{background:#f44336;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 24px;text-transform:uppercase;transition:background-color .2s,transform .2s;width:100%}.history-delete-btn:hover:not(:disabled){background:#d32f2f;transform:translateY(-1px)}.history-delete-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.history-clear-message{align-items:flex-start;animation:slideIn .3s ease-out;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;gap:12px;margin-bottom:20px;padding:16px}.history-clear-message-success{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50;box-shadow:0 2px 8px #4caf5033}.history-clear-message-error{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #f44336;box-shadow:0 2px 8px #f4433633}.history-clear-message-icon{flex-shrink:0;font-size:24px;margin-top:2px}.history-clear-message-content{flex:1 1}.history-clear-message-text{color:#333;font-size:14px;font-weight:500;line-height:1.4}.history-clear-message-close{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;height:24px;justify-content:center;padding:0;transition:color .2s;width:24px}.history-clear-message-close:hover{color:#333}.reminder-form{border-bottom:2px solid #e0e0e0;margin-bottom:30px;padding-bottom:20px}.reminder-form h4{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.reminder-success-message{align-items:flex-start;animation:slideIn .3s ease-out;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:2px solid #4caf50;border-radius:8px;box-shadow:0 2px 8px #4caf5033;display:flex;gap:12px;margin-bottom:20px;padding:16px}.reminder-success-icon{flex-shrink:0;font-size:24px;margin-top:2px}.reminder-success-content{flex:1 1}.reminder-success-title{color:#2e7d32;font-size:15px;font-weight:600;line-height:1.4;margin-bottom:6px}.reminder-success-info{color:#388e3c;font-size:13px;line-height:1.4}.reminder-success-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#4caf50;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:24px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:24px}.reminder-success-close:hover{background:#4caf501a;color:#2e7d32;transform:scale(1.1)}.reminder-form-row{margin-bottom:15px}.reminder-date-time-row{align-items:flex-end;display:flex;gap:15px}.reminder-form-field{display:flex;flex:1 1;flex-direction:column}.reminder-label{color:#555;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.reminder-input,.reminder-select,.reminder-textarea{background-color:#fff;border:2px solid #ddd;border-radius:4px;box-sizing:border-box;color:#333;font-family:inherit;font-size:14px;font-weight:500;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.reminder-input:focus,.reminder-select:focus,.reminder-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.reminder-textarea{min-height:80px;resize:vertical}.reminder-checkbox-label{align-items:center;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px}.reminder-checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.reminder-days-checkboxes{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));margin-top:8px}.reminder-day-checkbox-label{align-items:center;background:#fff;border:2px solid #ddd;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:8px 12px;transition:all .2s}.reminder-day-checkbox-label:hover{background:#f8f9ff;border-color:#667eea}.reminder-day-checkbox-label input[type=checkbox]{cursor:pointer;height:18px;margin:0;width:18px}.reminder-day-checkbox-label input[type=checkbox]:checked+span{color:#667eea;font-weight:700}.reminder-day-checkbox-label:has(input[type=checkbox]:checked){background:#f0f2ff;border-color:#667eea}.reminder-add-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin-top:10px;padding:12px 24px;transition:background-color .2s,transform .2s;width:100%}.reminder-add-btn:hover{background:#5568d3;transform:translateY(-1px)}.reminders-list{margin-top:20px}.reminders-list h4{color:#333;font-size:16px;font-weight:600;margin:0 0 15px}.no-reminders{color:#999;font-style:italic;padding:20px;text-align:center}.reminders-items{max-height:400px;overflow-y:auto}.reminder-item{align-items:flex-start;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px;transition:background-color .2s}.reminder-item:hover{background:#f0f0f0}.reminder-item-content{flex:1 1}.reminder-item-title{color:#333;font-size:15px;font-weight:700;margin-bottom:6px}.reminder-item-description{color:#666;font-size:13px;line-height:1.4;margin-bottom:8px}.reminder-item-details{margin-top:8px}.reminder-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.reminder-badge.recurring{background:#e3f2fd;color:#1976d2}.reminder-badge.one-time{background:#fff3e0;color:#f57c00}.reminder-delete-btn{align-items:center;background:#f44336;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:28px;justify-content:center;margin-left:10px;transition:background-color .2s,transform .2s;width:28px}.reminder-delete-btn:hover{background:#d32f2f;transform:scale(1.1)}.reminder-popup-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.reminder-popup{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:600px;overflow:hidden;width:90%}.reminder-popup-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;gap:15px;padding:25px 30px}.reminder-popup-icon{font-size:36px}.reminder-popup-header h3{flex:1 1;font-size:24px;font-weight:700;margin:0}.reminder-popup-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:32px;justify-content:center;transition:background-color .2s;width:32px}.reminder-popup-close:hover{background:#ffffff4d}.reminder-popup-body{padding:30px 35px}.reminder-popup-title{color:#333;font-size:22px;font-weight:700;line-height:1.4;margin-bottom:15px}.reminder-popup-description{color:#666;font-size:18px;line-height:1.6}.reminder-popup-footer{align-items:center;border-top:1px solid #e0e0e0;display:flex;gap:15px;justify-content:space-between;padding:20px 30px}.reminder-postpone-section{align-items:center;display:flex;gap:10px}.reminder-postpone-label{color:#666;font-size:14px;font-weight:600}.reminder-postpone-select{background-color:#fff;border:2px solid #ddd;border-radius:4px;color:#333;cursor:pointer;font-size:14px;font-weight:500;padding:8px 12px;transition:border-color .2s}.reminder-postpone-select:focus{border-color:#667eea;outline:none}.reminder-popup-postpone-btn{background:#ff9800;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:background-color .2s,transform .2s}.reminder-popup-postpone-btn:hover{background:#f57c00;transform:translateY(-1px)}.reminder-popup-confirm-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;transition:background-color .2s,transform .2s}.reminder-popup-confirm-btn:hover{background:#5568d3;transform:translateY(-1px)}.confirm-delete-modal{max-width:320px;padding:0;width:auto}.confirm-delete-content{padding:12px 16px;text-align:center}.confirm-delete-icon{font-size:32px;margin-bottom:10px}.confirm-delete-message{color:#333;font-size:14px;font-weight:500;line-height:1.3;margin-bottom:6px}.confirm-delete-warning{background:#fff3e0;border-left:3px solid #f57c00;border-radius:4px;color:#f57c00;font-size:12px;font-weight:500;margin-top:6px;padding:6px 10px}.modal-footer{background:#fafafa;border-top:1px solid #e0e0e0;display:flex;gap:8px;justify-content:flex-end;padding:12px 16px}.confirm-delete-cancel-btn{background:#fff;border:1.5px solid #ddd;border-radius:6px;color:#666;cursor:pointer;font-size:13px;font-weight:600;min-width:70px;padding:8px 16px;transition:all .2s}.confirm-delete-cancel-btn:hover{background:#f5f5f5;border-color:#bbb;color:#333}.confirm-delete-confirm-btn,.confirm-delete-ok-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;box-shadow:0 2px 4px #667eea4d;color:#fff;cursor:pointer;font-size:13px;font-weight:600;min-width:70px;padding:8px 16px;transition:all .2s}.confirm-delete-confirm-btn:hover,.confirm-delete-ok-btn:hover{background:linear-gradient(135deg,#5568d3,#653a8f);box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.confirm-delete-confirm-btn:active,.confirm-delete-ok-btn:active{box-shadow:0 2px 4px #667eea4d;transform:translateY(0)}.history-tabs{border-bottom:2px solid #e0e0e0;display:flex;margin-bottom:20px}.history-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s}.history-tab.active{border-bottom-color:#667eea;color:#667eea}.history-list{flex:1 1;max-height:none;min-height:0;overflow-x:hidden;overflow-y:auto}.history-items{display:flex;flex-direction:column;gap:12px}.no-history{color:#999;font-style:italic;padding:40px 20px;text-align:center}.history-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;padding:15px;transition:background-color .2s}.history-item:hover{background:#f0f0f0}.history-item-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.history-item-title{color:#333;flex:1 1;font-size:15px;font-weight:700}.history-item-date{color:#999;font-size:12px;margin-left:15px}.history-item-details{align-items:center;display:flex;gap:15px}.history-item-action{background:#e3f2fd;border-radius:12px;color:#667eea;font-size:13px;font-weight:600;padding:4px 10px}.history-item-user{color:#666;font-size:13px}.history-item-grouped{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:12px;padding:15px;transition:background-color .2s}.history-item-grouped:hover{background:#f0f0f0}.history-line{color:#333;font-size:14px;line-height:1.5;padding:6px 0}.history-line-1{border-bottom:1px solid #e0e0e0;font-weight:600;margin-bottom:8px;padding-bottom:10px}.history-line-2,.history-line-3{color:#555}.history-line-4{border-top:1px solid #e0e0e0;margin-top:8px;padding-top:8px}.history-send-btn{background:#667eea;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background-color .2s}.history-send-btn:hover{background:#5568d3}.history-send-btn:active{background:#4457b8}.history-sent-info{color:#28a745;font-size:14px;font-weight:500}.history-search-container{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:15px;padding:10px}.history-search-label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.history-search-input{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s;width:100%}.history-search-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.admin-container{box-sizing:border-box;margin:0 auto;max-width:1400px;padding:40px 20px}.admin-header{margin-bottom:32px;text-align:center}.admin-header h2{color:#1a1a1a;font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.admin-header p{color:#6b7280;font-size:16px;font-weight:400;margin:0}.admin-header-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.permissions-button{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.permissions-button:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.admin-content{grid-gap:32px;display:grid;gap:32px}.admin-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:32px;transition:all .3s ease}.admin-section:hover{box-shadow:0 6px 32px #0000001a,0 2px 6px #00000014}.admin-section h3{border-bottom:2px solid #e5e7eb;color:#111827;font-size:24px;font-weight:700;letter-spacing:-.3px;margin:0 0 24px;padding-bottom:12px}.add-user-form{display:flex;flex-direction:column;gap:24px}.add-user-button{align-items:center;align-self:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 14px #667eea59;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:10px;letter-spacing:-.2px;padding:16px 48px;transition:all .3s ease}.add-user-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 6px 20px #667eea73;transform:translateY(-2px)}.add-user-button:active{box-shadow:0 2px 10px #667eea4d;transform:translateY(0)}.users-table-container{border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000000d;overflow-x:auto}.users-table{background:#fff;border-collapse:collapse;margin:0;width:100%}.users-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.users-table th{font-size:12px;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.users-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:14px;padding:16px 20px}.users-table tbody tr{transition:background-color .2s ease}.users-table tbody tr:hover{background-color:#f9fafb}.users-table tbody tr:last-child td{border-bottom:none}.role-cell{align-items:center;display:flex;gap:10px}.role-select{background:#fff;border:2px solid #e0e0e0;border-radius:5px;cursor:pointer;font-size:14px;min-width:150px;padding:8px 12px}.role-select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.role-badge{border-radius:12px;padding:4px 12px}.role-badge-owner{background-color:#ff6b6b;color:#fff}.role-badge-admin{background-color:#4ecdc4;color:#fff}.role-badge-lider{background-color:#ffe66d;color:#333}.role-badge-user{background-color:#95a5a6;color:#fff}.delete-button{align-items:center;background-color:#ef4444;border-radius:6px;box-shadow:0 1px 3px #ef44444d;box-sizing:border-box;display:inline-flex;font-size:13px;font-weight:600;height:36px;justify-content:center;line-height:20px;min-width:80px;padding:8px 16px;text-align:center;transition:all .2s ease}.delete-button:hover:not(:disabled){background-color:#dc2626;box-shadow:0 2px 6px #ef444466;transform:translateY(-1px)}.delete-button:active:not(:disabled){transform:translateY(0)}.delete-button:disabled{background-color:#d1d5db;box-shadow:none;cursor:not-allowed;opacity:.6}.action-buttons{gap:10px}.change-password-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;box-shadow:0 1px 3px #667eea4d;box-sizing:border-box;color:#fff;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;height:36px;justify-content:center;line-height:20px;min-width:80px;padding:8px 16px;text-align:center;transition:all .2s ease}.change-password-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 2px 6px #667eea66;transform:translateY(-1px)}.change-password-button:active{transform:translateY(0)}.edit-user-modal{max-width:750px!important;width:90%!important}.edit-user-form{padding:20px}.edit-user-form .form-group{margin-bottom:20px}.change-password-form,.edit-user-form{padding:32px}.edit-user-form .projects-group{margin-top:24px}.cancel-button{border-radius:8px;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.cancel-button:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.submit-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.submit-button:active{transform:translateY(0)}.password-error{color:#dc3545;font-size:12px;margin-top:5px}.project-badge{background-color:#e3f2fd;border-radius:12px;color:#1976d2;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px}.project-select{width:100%}.form-group label{flex-wrap:wrap}.projects-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.projects-header label{color:#374151;font-size:14px;font-weight:600;letter-spacing:-.2px;margin:0}.add-project-button{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:8px;box-shadow:0 2px 6px #10b98140;display:inline-flex;font-weight:600;gap:6px;letter-spacing:-.1px;padding:10px 18px;transition:all .2s ease}.add-project-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98159;transform:translateY(-1px)}.add-project-button:active{box-shadow:0 2px 6px #10b98140;transform:translateY(0)}.add-icon{font-size:18px;font-weight:700;line-height:1}.projects-container{margin-top:0}.projects-grid{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px solid #e2e8f0;border-radius:12px;box-shadow:inset 0 2px 4px #0000000a;display:flex;flex-wrap:wrap;gap:12px;max-height:320px;overflow-y:auto;padding:20px}.edit-user-modal .projects-grid{max-height:280px;padding:18px}.project-card{cursor:pointer;display:block;flex:0 0 auto;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.project-checkbox{opacity:0;pointer-events:none;position:absolute}.project-card-content{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;min-width:-webkit-fit-content;min-width:fit-content;padding:14px 18px;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.project-card:hover .project-card-content{background:#f8faff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.project-name{color:#374151;font-size:14px;letter-spacing:-.1px;transition:all .2s ease}.project-check-icon{align-items:center;background:#e2e8f0;border-radius:50%;color:#0000;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:22px;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);width:22px}.project-checkbox:checked~.project-card-content{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 4px 16px #667eea4d;transform:translateY(-2px)}.project-checkbox:checked~.project-card-content .project-name{color:#fff;font-weight:600}.project-checkbox:checked~.project-card-content .project-check-icon{background:#ffffff40;color:#fff}.project-card:active .project-card-content{transform:translateY(0)}.no-projects-message{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1.5px dashed #cbd5e1;border-radius:12px;display:flex;flex-direction:column;justify-content:center;padding:48px 24px}.no-projects-icon{font-size:48px;margin-bottom:12px;opacity:.5}.no-projects-text{color:#64748b;font-size:15px;font-style:normal;font-weight:500;margin:0}.projects-badges{display:flex;flex-wrap:wrap;gap:5px}.project-badge.no-project{background-color:#f5f5f5;color:#999}.edit-button{align-items:center;background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;border-radius:6px;box-shadow:0 1px 3px #06b6d44d;box-sizing:border-box;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;height:36px;justify-content:center;line-height:20px;min-width:80px;padding:8px 16px;text-align:center;transition:all .2s ease}.edit-button:hover{background:linear-gradient(135deg,#0891b2,#0e7490);box-shadow:0 2px 6px #06b6d466}.edit-button:active{transform:translateY(0)}@media (max-width:1366px){.admin-container{padding:28px 16px}.admin-header h2{font-size:28px}.admin-section{padding:28px}}@media (max-width:1024px){.admin-container{padding:24px 16px}.admin-header h2{font-size:26px}.admin-header p{font-size:15px}.admin-section{border-radius:12px;padding:24px}.admin-section h3{font-size:22px}.form-row{gap:20px}}@media (max-width:768px){.admin-container{padding:20px 12px}.admin-header{margin-bottom:24px}.admin-header h2{font-size:24px}.admin-header p{font-size:14px}.admin-section{border-radius:12px;padding:20px}.admin-section h3{font-size:20px;margin-bottom:20px}.form-row{gap:18px;grid-template-columns:1fr}.form-group input,.form-group select{font-size:15px;padding:12px 14px}.users-table-container{border-radius:10px;overflow-x:auto}.users-table td,.users-table th{font-size:13px;padding:12px 16px}.add-user-button{padding:14px;width:100%}.action-buttons{flex-wrap:wrap;gap:8px}.change-password-button,.delete-button,.edit-button{font-size:12px;height:32px;line-height:18px;min-width:70px;padding:6px 12px}.projects-header{align-items:flex-start;flex-direction:column;gap:10px}.projects-grid{gap:10px;max-height:280px;padding:16px}.project-card-content{font-size:13px;padding:12px 14px}.project-name{font-size:13px}.add-project-button{font-size:13px;padding:8px 14px}}@media (max-width:480px){.admin-container{padding:16px 10px}.admin-header h2{font-size:22px}.admin-header p{font-size:13px}.admin-section{border-radius:10px;padding:16px}.admin-section h3{font-size:18px;margin-bottom:16px}.form-group input,.form-group select{font-size:15px;padding:12px}.users-table td,.users-table th{font-size:12px;padding:10px 12px}.modal-content{border-radius:12px}.change-password-form,.edit-user-form,.modal-header{padding:20px}.projects-grid{gap:8px;max-height:240px;padding:12px}.project-card{flex:1 1 auto;min-width:calc(50% - 4px)}.project-card-content{padding:10px 12px}.project-name{font-size:12px}.add-project-button{justify-content:center;padding:10px;width:100%}.projects-header{gap:8px}}.project-manager{margin-top:20px}.add-project-form{margin-bottom:20px}.form-group-inline{align-items:flex-start;display:flex;gap:10px}.project-input{border:2px solid #e0e0e0;border-radius:5px;flex:1 1;font-size:14px;padding:10px;transition:border-color .3s}.project-input:focus{border-color:#667eea;outline:none}.add-project-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:transform .2s,box-shadow .2s;white-space:nowrap}.add-project-button:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.projects-list h4{color:#333;font-size:16px;margin-bottom:15px}.no-projects{color:#999;font-style:italic;padding:20px;text-align:center}.projects-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.project-item{align-items:center;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;display:flex;justify-content:space-between;padding:12px 15px;transition:background-color .3s}.project-item:hover{background-color:#e9ecef}.project-name{color:#333;font-weight:500}.delete-project-button{align-items:center;background:none;border:none;border-radius:50%;color:#dc3545;cursor:pointer;display:flex;font-size:24px;height:24px;justify-content:center;line-height:1;padding:0;transition:background-color .3s;width:24px}.delete-project-button:hover{background-color:#fee}@media (max-width:768px){.form-group-inline{flex-direction:column}.projects-grid{grid-template-columns:1fr}.modal-content{border-radius:12px}.modal-header{padding:20px}}.hr-container{box-sizing:border-box;margin:0;max-width:100%;padding:20px;width:100%}@media (min-width:2560px){.hr-container{margin:0 auto;max-width:2400px}}.hr-header{margin-bottom:30px}.hr-header h2{color:#333;font-size:32px;margin-bottom:0}.hr-content{margin-top:30px}.rotacja-container{min-height:200px;width:100%}.rotacja-tabs{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box;display:flex;gap:10px;margin-bottom:20px;margin-left:auto;margin-right:auto;max-width:1200px;padding:10px 20px}.rotacja-tab{background:#f5f5f5;border:none;border-radius:6px;color:#666;cursor:pointer;flex:1 1;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s ease}.rotacja-tab:hover{background:#e5e5e5}.rotacja-tab.active{background:#667eea;color:#fff}.rotacja-tab.active:hover{background:#5568d3}.rotacja-content{margin:0 auto;max-width:1200px;width:100%}@media (max-width:1366px){.hr-container{padding:15px}.hr-header h2{font-size:28px}}@media (max-width:1024px){.hr-container{padding:15px}.hr-header h2{font-size:24px}.rotacja-tabs{padding:8px 15px}.rotacja-tab{font-size:14px;padding:10px 20px}}@media (max-width:768px){.hr-container{padding:10px}.hr-header{margin-bottom:20px}.hr-header h2{font-size:22px}.rotacja-tabs{flex-direction:column;gap:8px;padding:10px}.rotacja-tab{padding:12px;width:100%}}@media (max-width:480px){.hr-header h2{font-size:20px}.rotacja-tab{font-size:13px;padding:10px}}.dodaj-pracownika-container{box-sizing:border-box;margin:0 auto;max-width:1200px;padding:0 20px;width:100%}@media (min-width:1367px){.dodaj-pracownika-container{max-width:1400px}}@media (min-width:1920px){.dodaj-pracownika-container{max-width:1600px}}.dodaj-pracownika-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;box-sizing:border-box;max-width:100%;padding:40px;width:100%}.form-header{margin-bottom:32px;text-align:center}.dodaj-pracownika-section h3{color:#1a1a1a;font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.form-subtitle{color:#6b7280;font-size:15px;font-weight:400;margin:0}.add-employee-form{display:flex;flex-direction:column;gap:32px;margin:0 auto;max-width:1000px;width:100%}.form-section{border-radius:12px;padding:28px;transition:all .3s ease}.form-section:hover{box-shadow:0 2px 8px #0000000a}.form-section-header{border-bottom:2px solid #e5e7eb;margin-bottom:24px;padding-bottom:16px}.form-section-title{color:#111827;letter-spacing:-.3px;margin:0}.form-row{grid-gap:24px;align-items:start;gap:24px;width:100%}.form-row-three{grid-template-columns:1fr 1fr 1fr;width:100%}@media (min-width:1367px){.add-employee-form{max-width:1100px}.form-row,.form-row-three{gap:32px}.form-section{padding:32px}}@media (min-width:1920px){.add-employee-form{max-width:1300px}.form-row,.form-row-three{gap:40px}.form-section{padding:36px}}.form-group{align-items:stretch;gap:10px}.form-group label{align-items:center;color:#374151;display:flex;flex-wrap:nowrap;font-weight:600;gap:24px;height:32px;justify-content:space-between;letter-spacing:-.2px;margin-bottom:0;min-height:32px}.form-group label>span:first-child{flex:0 0 auto;min-width:0}.form-group input,.form-group select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:inherit;font-size:15px;height:50px;line-height:1.5;max-width:100%;padding:14px 16px;text-align:left;transition:all .2s ease;width:100%}.form-group input:hover,.form-group select:hover{border-color:#9ca3af}.form-group input:focus,.form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input::placeholder{color:#9ca3af}.form-group select:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed;opacity:.7}.projects-group{grid-column:1/-1}.projects-checkboxes{grid-gap:10px;background-color:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:10px;padding:15px}.project-checkbox-label{align-items:center;background:#fff;border:1px solid #ddd;border-radius:5px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:background-color .3s,border-color .3s}.project-checkbox-label:hover{background-color:#f0f0f0;border-color:#667eea}.project-checkbox-label input[type=checkbox]{cursor:pointer;height:18px;width:18px}.project-checkbox-label input[type=checkbox]:checked+span{color:#667eea;font-weight:600}.password-requirements{background-color:#f8f9fa;border-radius:5px;font-size:13px;margin-top:10px;padding:10px}.password-strength{margin-bottom:8px}.strength-label{color:#555;font-weight:500}.strength-value{border-radius:3px;font-weight:600;padding:2px 8px}.strength-0,.strength-1{background-color:#fee;color:#dc3545}.strength-2{background-color:#fff3e0;color:#fd7e14}.strength-3{background-color:#fffbf0;color:#ffc107}.strength-4,.strength-5{background-color:#efe;color:#28a745}.strength-6{background-color:#d4edda;color:#155724}.password-errors{color:#dc3545;list-style:none;margin:8px 0 0;padding:0}.password-errors li{font-size:12px;padding:4px 0}.password-errors li:before{content:"✗ ";margin-right:5px}.password-valid{color:#28a745;font-size:12px;font-weight:500;margin-top:8px}.password-hint{color:#666;font-size:11px;font-style:italic;margin-top:8px}.password-hint strong{color:#333}.form-submit-wrapper{display:flex;justify-content:center;margin-top:8px;padding-top:24px}.add-employee-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 14px #667eea59;color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:10px;justify-content:center;letter-spacing:-.2px;min-width:200px;padding:16px 48px;transition:all .3s ease}.add-employee-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 6px 20px #667eea73;transform:translateY(-2px)}.add-employee-button:active{box-shadow:0 2px 10px #667eea4d;transform:translateY(0)}.add-employee-button .button-icon{font-size:18px;font-weight:700}.add-item-button{align-items:center;align-self:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 1px 3px #10b9814d;color:#fff;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:12px;font-weight:600;gap:4px;height:28px;line-height:1;margin-left:auto;margin-right:0;padding:6px 12px;transition:all .2s ease;white-space:nowrap}.add-item-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 2px 6px #10b98166;transform:translateY(-1px)}.add-item-button:active{transform:translateY(0)}.add-item-button .button-icon{font-size:14px;font-weight:700;line-height:1}.add-item-button .button-text{font-size:11px}.add-position-button{margin-left:32px}.modal-form-group{margin-bottom:24px}.modal-form-group label{margin-bottom:10px}.modal-form-group input{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:inherit;font-size:15px;height:50px;padding:14px 16px;transition:all .2s ease;width:100%}.modal-form-group input:hover{border-color:#9ca3af}.modal-form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-form-group input::placeholder{color:#9ca3af}.modal-actions .btn-cancel,.modal-actions .btn-confirm{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}@media (max-width:1366px){.dodaj-pracownika-container{max-width:100%;padding:0 15px}.dodaj-pracownika-section{padding:28px}.form-header{margin-bottom:28px}.dodaj-pracownika-section h3{font-size:24px}.form-section{padding:24px}.form-row{gap:20px}.form-group label{font-size:13px}.form-group input,.form-group select{font-size:15px;height:48px;padding:12px 14px}.add-item-button{font-size:11px;height:26px;padding:5px 10px}.projects-checkboxes{gap:8px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media (max-width:1024px){.dodaj-pracownika-section{padding:24px}.form-section{padding:20px}.form-row{gap:18px}.projects-checkboxes{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.add-employee-button{align-self:stretch;width:100%}}@media (max-width:768px){.dodaj-pracownika-container{padding:0 10px}.dodaj-pracownika-section{border-radius:12px;padding:20px}.form-header{margin-bottom:24px}.dodaj-pracownika-section h3{font-size:22px}.form-subtitle{font-size:14px}.form-section{border-radius:10px;padding:20px}.form-section-title{font-size:16px}.form-row{gap:18px}.form-row,.form-row-three{grid-template-columns:1fr}.form-group input,.form-group select{font-size:15px;height:48px;padding:12px 14px}.projects-checkboxes{gap:10px;grid-template-columns:1fr}.add-employee-button{font-size:16px;min-width:auto;padding:16px;width:100%}.add-item-button{font-size:11px;height:26px;padding:6px 10px}.modal-content{max-width:100%;padding:24px;width:95%}}@media (max-width:480px){.dodaj-pracownika-section{padding:16px}.form-header{margin-bottom:20px}.dodaj-pracownika-section h3{font-size:20px;margin-bottom:6px}.form-subtitle{font-size:13px}.form-section{padding:16px}.form-section-title{font-size:15px}.form-group label{font-size:13px}.form-group input,.form-group select{font-size:15px;height:46px;padding:12px}.add-item-button{font-size:10px;height:24px;margin-left:5px;padding:5px 8px}.add-item-button .button-text{display:none}.modal-content{padding:20px}.modal-content h3{font-size:18px}.add-employee-button{font-size:15px;padding:14px}}.employees-list-section{border-top:2px solid #e5e7eb;margin-top:40px;padding-top:32px}.employees-table-wrapper{margin-top:20px;overflow-x:auto}.employees-management-table{background:#fff;border-collapse:collapse;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden;width:100%}.employees-management-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employees-management-table th{font-size:14px;font-weight:600;letter-spacing:-.2px;padding:16px;text-align:left;white-space:nowrap}.employees-management-table td{border-bottom:1px solid #e5e7eb;color:#374151;font-size:14px;padding:14px 16px}.employees-management-table tbody tr:hover{background-color:#f9fafb;transition:background-color .2s ease}.employees-management-table tbody tr:last-child td{border-bottom:none}.shift-badge{background:linear-gradient(135deg,#10b981,#059669)}.leader-badge,.shift-badge{border-radius:6px;white-space:nowrap}.leader-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}@media (max-width:1024px){.employees-management-table{font-size:13px}.employees-management-table td,.employees-management-table th{padding:12px}.modal-form-row{grid-template-columns:1fr}}@media (max-width:768px){.employees-list-section{margin-top:32px;padding-top:24px}.employees-management-table{font-size:12px}.employees-management-table td,.employees-management-table th{padding:10px 8px}.action-buttons{flex-direction:column;gap:4px}.delete-button,.edit-button{min-width:auto;width:100%}.edit-employee-modal{max-width:95%;padding:20px}}.lista-pracownikow-container{width:100%}.lista-pracownikow-header{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:800px;padding:20px}.stats{display:flex;flex-wrap:wrap;gap:30px}.stat-item{color:#333;font-size:16px}.stat-item strong{color:#667eea;margin-right:8px}.no-projects-message{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:30px;text-align:center}.no-projects-message p{color:#666;font-size:16px}.projects-list{display:flex;flex-direction:column;gap:20px;margin:0 auto;max-width:800px}.project-section{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.project-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;display:flex;justify-content:space-between;padding:20px;transition:background .3s}.project-header:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f)}.project-header h3{font-size:20px;font-weight:600;margin:0}.project-info{align-items:center;display:flex;gap:15px}.employee-count{background:#fff3;border-radius:20px;font-size:14px;padding:5px 12px}.expand-icon{font-size:12px;transition:transform .3s}.employees-table-container{padding:20px}.no-employees{color:#666;padding:20px;text-align:center}.employees-table{border-collapse:collapse;width:100%}.employees-table thead{background-color:#f8f9fa}.employees-table th{border-bottom:2px solid #e0e0e0;color:#333;font-weight:600;padding:12px;text-align:left}.employees-table td{border-bottom:1px solid #f0f0f0;color:#555;padding:12px}.employees-table tbody tr:hover{background-color:#f8f9fa}.employees-table tbody tr:last-child td{border-bottom:none}.shift-badge{background-color:#667eea;border-radius:15px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}@media (max-width:1366px){.lista-pracownikow-header{padding:18px}.stats{gap:20px}}@media (max-width:1024px){.lista-pracownikow-header{padding:15px}.stats{gap:15px}.stat-item{font-size:14px}}@media (max-width:768px){.lista-pracownikow-header{margin-bottom:20px;padding:15px}.project-header,.stats{flex-direction:column;gap:10px}.project-header{align-items:flex-start;padding:15px}.project-header h3{font-size:18px}.project-info{justify-content:space-between;width:100%}.employees-table-container{overflow-x:auto;padding:15px}.employees-table{font-size:14px;min-width:600px}.employees-table td,.employees-table th{padding:8px}}@media (max-width:480px){.lista-pracownikow-header{padding:12px}.stat-item{font-size:13px}.project-header{padding:12px}.project-header h3{font-size:16px}.employees-table-container{padding:10px}.employees-table{font-size:12px;min-width:500px}.employees-table td,.employees-table th{padding:6px}}.action-buttons{align-items:center;display:flex;gap:8px}.delete-button,.edit-button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:16px;height:36px;justify-content:center;min-width:36px;padding:8px 12px;transition:all .2s ease}.edit-button{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d;color:#fff}.edit-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #3b82f666;transform:translateY(-1px)}.delete-button{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 4px #ef44444d}.delete-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px #ef444466;transform:translateY(-1px)}.admin-message{align-items:center;animation:slideIn .3s ease;border-left:4px solid;border-radius:10px;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:24px;margin-left:auto;margin-right:auto;max-width:800px;padding:16px 20px}.admin-message.error{background-color:#fef2f2;border-left-color:#ef4444;color:#dc2626}.admin-message.success{background-color:#f0fdf4;border-left-color:#22c55e;color:#16a34a}.modal-content{padding:32px}.modal-content h3{border-bottom:2px solid #e5e7eb;color:#111827;font-size:22px;font-weight:700;letter-spacing:-.3px;margin:0 0 24px;padding-bottom:12px}.delete-confirm-modal p{color:#374151;font-size:15px;line-height:1.6;margin:12px 0}.modal-actions .btn-cancel,.modal-actions .btn-delete{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.edit-employee-modal{max-height:90vh;max-width:800px;overflow-y:auto;width:90%}.modal-form-section{display:flex;flex-direction:column;gap:20px}.modal-form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.modal-form-group{display:flex;flex-direction:column;gap:8px}.modal-form-group label{color:#374151;font-size:14px;font-weight:600;letter-spacing:-.2px}.modal-form-group input,.modal-form-group select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;font-family:inherit;font-size:14px;height:46px;padding:12px 14px;transition:all .2s ease;width:100%}.modal-form-group input:hover,.modal-form-group select:hover{border-color:#9ca3af}.modal-form-group input:focus,.modal-form-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-form-group select:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed;opacity:.7}.required-asterisk{font-weight:700;margin-left:2px}@media (max-width:768px){.modal-content{max-width:100%;padding:24px;width:95%}.modal-form-row{grid-template-columns:1fr}.action-buttons{flex-direction:column;gap:4px}.delete-button,.edit-button{min-width:auto;width:100%}}.absencje-container{box-sizing:border-box;margin:0 auto;max-width:1800px;padding:20px;width:100%}.absencje-header{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;margin-bottom:24px;padding:24px}.absencje-header h3{color:#111827;font-size:28px;font-weight:700;margin:0 0 20px}.absencje-controls{align-items:flex-start;display:flex;flex-wrap:wrap;gap:20px}.date-selector,.month-selector,.project-selector,.quarter-selector,.rotation-selector,.view-mode-selector,.week-selector,.year-selector{align-items:flex-start;display:flex;flex:0 0 auto;flex-direction:column;gap:8px;justify-content:flex-start}.date-selector label,.month-selector label,.project-selector label,.quarter-selector label,.rotation-selector label,.view-mode-selector label,.week-selector label,.year-selector label{box-sizing:border-box;color:#374151;display:block;font-size:13px;font-weight:600;height:18px;line-height:18px;margin:0;max-height:18px;min-height:18px;padding:0;white-space:nowrap}.date-input,.month-select,.project-select,.quarter-select,.rotation-select,.view-mode-select,.week-select,.year-input{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-sizing:border-box;color:#111827;cursor:pointer;font-family:inherit;font-size:15px;height:44px;min-width:200px;padding:12px 16px;transition:all .2s ease}.year-input{cursor:text;min-width:120px}.week-select{min-width:250px}.month-select:hover,.project-select:hover,.rotation-select:hover,.view-mode-select:hover,.week-select:hover{border-color:#9ca3af}.date-input:focus,.month-select:focus,.project-select:focus,.rotation-select:focus,.view-mode-select:focus,.week-select:focus,.year-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.date-input{cursor:text;min-width:180px}.absencje-content{display:flex;flex-direction:column;gap:24px}.project-info-banner{align-items:center;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:1px solid #93c5fd;border-radius:12px;color:#1e40af;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:8px;padding:16px 20px}.project-info-banner .info-icon{flex-shrink:0;font-size:20px}.stats-overview{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 2px 8px #00000014,0 1px 3px #0000000d;overflow:hidden;padding:28px;position:relative;transition:all .3s ease}.stat-card:before{background:linear-gradient(135deg,#667eea,#764ba2);content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{border-color:#d1d5db;box-shadow:0 8px 24px #0000001f,0 2px 6px #00000014;transform:translateY(-4px)}.stat-icon{display:block;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));font-size:48px;line-height:1;margin-bottom:16px}.stat-value{color:#111827;font-size:42px;font-weight:800;letter-spacing:-1px;line-height:1.2;margin-bottom:8px}.stat-label{color:#6b7280;font-size:15px;font-weight:600;letter-spacing:.5px;margin-top:4px}.charts-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:24px}.chart-container{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:24px}.chart-container.full-width{grid-column:1/-1}.chart-container h4{color:#111827;font-size:20px;font-weight:700;margin:0 0 20px}.no-data-message{color:#6b7280;font-size:16px;padding:60px 20px;text-align:center}.detailed-stats{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:24px}.detailed-stats h4{color:#111827;font-size:24px;font-weight:700;margin:0 0 24px}.detailed-stats h5{color:#374151;font-size:18px;font-weight:600;margin:0 0 16px}.stats-by-type{margin-bottom:32px}.type-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.type-stat-card{align-items:center;background:#f9fafb;border-left:4px solid;border-radius:12px;display:flex;gap:16px;padding:16px;transition:all .2s ease}.type-stat-card:hover{background:#f3f4f6;transform:translateX(4px)}.type-stat-icon{font-size:32px}.type-stat-info{flex:1 1}.type-stat-label{color:#6b7280;font-size:14px;margin-bottom:4px}.type-stat-value{color:#111827;font-size:20px;font-weight:700}.stats-by-employee{margin-top:32px}.employee-stats-table{overflow-x:auto}.employee-stats-table table{background:#fff;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.employee-stats-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employee-stats-table th{font-size:14px;font-weight:600;padding:14px 16px;text-align:left;white-space:nowrap}.employee-stats-table td{border-bottom:1px solid #f3f4f6;font-size:14px;padding:12px 16px}.employee-stats-table tbody tr:hover{background-color:#f9fafb}.employee-stats-table tbody tr:last-child td{border-bottom:none}.no-employees-message,.no-projects-message{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:60px 40px;text-align:center}.no-employees-message p,.no-projects-message p{color:#6b7280;font-size:16px;margin:0}@media (max-width:1024px){.charts-section{grid-template-columns:1fr}.chart-container.full-width{grid-column:1}}@media (max-width:768px){.absencje-container{padding:12px}.absencje-header{padding:16px}.absencje-controls,.date-selector,.project-selector,.rotation-selector,.view-mode-selector{align-items:stretch;flex-direction:column}.date-input,.project-select,.view-mode-select{min-width:0;width:100%}.stats-overview{grid-template-columns:repeat(2,1fr)}.type-stats-grid{grid-template-columns:1fr}.employee-stats-table{font-size:12px}.employee-stats-table td,.employee-stats-table th{padding:8px 12px}}@media (max-width:480px){.stats-overview{grid-template-columns:1fr}.stat-card{padding:20px}.stat-value{font-size:28px}.chart-container{padding:16px}}.zmiany-container{margin:0 auto;max-width:1200px;width:100%}.zmiany-header{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.zmiany-header h3{color:#333;font-size:24px;margin:0}.add-shift-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:28px;height:50px;justify-content:center;transition:all .3s ease;width:50px}.add-shift-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.add-shift-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.add-shift-form h4{color:#333;font-size:20px;margin:0 0 20px}.form-group input[type=text],.form-group input[type=time]{border:1px solid #ddd;border-radius:6px;font-size:16px;padding:12px;transition:border-color .3s ease;width:100%}.form-group input[type=text]:focus,.form-group input[type=time]:focus{border-color:#667eea;outline:none}.color-picker{display:flex;flex-direction:column;gap:15px}.color-options-group{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.color-option{border:3px solid #0000;border-radius:50%;cursor:pointer;height:40px;position:relative;transition:all .3s ease;width:40px}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #667eea}.custom-color-wrapper{display:inline-block;position:relative}.custom-color-wrapper:hover .remove-color-btn{opacity:1}.remove-color-btn{align-items:center;background:#ef4444;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:20px;justify-content:center;line-height:1;opacity:0;padding:0;position:absolute;right:-8px;top:-8px;transition:opacity .3s ease;width:20px}.remove-color-btn:hover{background:#dc2626;transform:scale(1.1)}.color-picker-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.color-input{border:none;border-radius:50%;cursor:pointer;height:40px;overflow:hidden;padding:0;width:40px}.add-color-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .3s ease}.add-color-btn:hover:not(:disabled){background:#5568d3;transform:translateY(-1px)}.add-color-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.duration-preview{background:#f5f5f5;border-radius:6px;color:#666;font-size:14px;margin-bottom:20px;padding:12px}.btn-cancel,.btn-save{border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s ease}.shifts-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.shift-item{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:row;gap:15px;justify-content:space-between;padding:15px;transition:transform .2s ease,box-shadow .2s ease}.shift-item:hover{box-shadow:0 4px 15px #00000026;transform:translateY(-2px)}.shift-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:24px;font-weight:700;height:60px;justify-content:center;width:60px}.shift-details{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:5px}.shift-name{color:#333;font-size:18px;font-weight:600;margin:0}.shift-time{color:#666;font-size:14px}.shift-actions{display:flex;flex-shrink:0;gap:10px}.delete-btn,.edit-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:20px;padding:8px;transition:background .2s ease}.edit-btn:hover{background:#f0f0f0}.modal-content{padding:25px}.modal-content h3{border-bottom:2px solid #667eea;font-size:20px;margin:0 0 20px;padding-bottom:10px}.modal-form-group{margin-bottom:20px}.modal-form-group label{color:#555;display:block;font-weight:500;margin-bottom:8px}.color-input-group{align-items:center;display:flex;gap:10px;margin-bottom:15px}.color-hex-input{border:2px solid #e0e0e0;border-radius:6px;flex:1 1;font-family:monospace;font-size:16px;padding:12px;transition:border-color .3s}.color-hex-input:focus{border-color:#667eea;outline:none}.color-picker-input{border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;height:50px;overflow:hidden;padding:0;width:50px}.color-preview{align-items:center;border-radius:6px;color:#fff;display:flex;font-weight:500;justify-content:center;min-height:60px;padding:20px;text-align:center;text-shadow:0 1px 2px #0000004d}.modal-actions .btn-confirm:hover:not(:disabled){background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.modal-actions .btn-confirm:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed;opacity:.6}.modal-header{margin:-25px -25px 25px}.modal-header h3{border-bottom:none;padding-bottom:0}@media (max-width:768px){.form-row,.shifts-list{grid-template-columns:1fr}.shift-item{align-items:center;flex-direction:row}.shift-details{align-items:flex-start}.shift-actions{flex-shrink:0}.modal-content{padding:20px;width:95%}}.rotacje-container{margin:0 auto;max-width:1200px;width:100%}.rotacje-header{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.project-selector{align-items:center;display:flex;gap:10px;margin-bottom:20px}.project-selector label{color:#333;font-weight:500}.project-selector select{background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;min-width:200px;padding:8px 12px}.project-selector select:focus{border-color:#667eea;outline:none}.rotacje-header h3{color:#333;font-size:24px;margin:0}.add-rotation-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:28px;height:50px;justify-content:center;transition:all .3s ease;width:50px}.add-rotation-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.add-rotation-form{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;margin-bottom:30px;padding:25px}.add-rotation-form h4{color:#333;font-size:20px;margin:0 0 20px}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input[type=number],.form-group input[type=text]{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .3s ease;width:100%}.form-group input[type=number]:focus,.form-group input[type=text]:focus{border-color:#667eea;outline:none}.form-row{grid-gap:15px;gap:15px;grid-template-columns:repeat(4,1fr)}.form-actions{justify-content:flex-end;margin-top:30px}.btn-cancel,.btn-clear,.btn-save{border:none;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s ease}.btn-clear{background:#f59e0b;color:#fff}.btn-clear:hover{background:#d97706}.btn-cancel{background:#e5e5e5;color:#333}.btn-cancel:hover{background:#d5d5d5}.btn-save{background:#667eea;color:#fff}.btn-save:hover{background:#5568d3}.rotation-pattern-editor{background:#f9f9f9;border-radius:10px;margin-top:30px;padding:20px}.pattern-header{align-items:flex-start;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.pattern-header-left{flex:1 1}.pattern-header h5{color:#333;font-size:18px;margin:0 0 5px}.pattern-header p{color:#666;font-size:14px;margin:0}.pattern-header-actions{align-items:center;display:flex;gap:10px}.pattern-container{display:flex;flex-direction:column}.pattern-header-row-full{margin-bottom:15px;width:100%}.pattern-content-wrapper{align-items:flex-start;display:flex;gap:30px}.pattern-grid{flex:1 1;margin-bottom:0}.pattern-row{align-items:center;display:flex;gap:10px;margin-bottom:10px}.pattern-header-row{border-bottom:1px solid #e0e0e0;margin-bottom:15px;padding-bottom:10px}.row-number{color:#666;font-size:14px;font-weight:600;text-align:center;width:40px}.pattern-day-header{color:#555;font-size:12px;font-weight:600;height:30px;text-transform:uppercase}.pattern-cell,.pattern-day-header{align-items:center;display:flex;justify-content:center;width:50px}.pattern-cell{border:2px solid #0000;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;font-weight:700;height:50px;transition:all .2s ease}.pattern-cell.empty{background:#e5e5e5;border-color:#ddd;color:#999}.pattern-cell.has-shift{border-color:#ffffff80}.pattern-cell.has-shift:hover{box-shadow:0 2px 8px #0003;transform:scale(1.1)}.pattern-cell.off-day{background:#0000;border:2px dashed #ccc;cursor:not-allowed}.pattern-cell.empty:hover{background:#d5d5d5;border-color:#bbb}.pattern-cell.drag-highlight{border:2px solid #667eea!important;box-shadow:0 0 8px #667eea80;opacity:.7;position:relative;z-index:10}.pattern-cell.drag-highlight.has-shift{opacity:.8}.shifts-menu{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:10px;display:flex;flex:0 0 320px;flex-direction:column;max-height:calc(100vh - 200px);overflow-y:auto;padding:20px}.shifts-menu p{color:#555;font-size:14px;font-weight:500;margin:0 0 15px}.rotations-list-in-menu{border-top:1px solid #e0e0e0;display:flex;flex-direction:column;gap:10px;margin-top:20px;padding-top:20px}.rotations-list-in-menu .rotation-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 1px 5px #0000001a;display:flex;justify-content:space-between;padding:12px;transition:transform .2s ease,box-shadow .2s ease}.rotations-list-in-menu .rotation-item:hover{box-shadow:0 2px 8px #00000026;transform:translateY(-1px)}.rotations-list-in-menu .rotation-info{flex:1 1;min-width:0}.rotations-list-in-menu .rotation-title{color:#333;font-size:14px;font-weight:600;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rotations-list-in-menu .rotation-meta{color:#666;font-size:11px}.rotations-list-in-menu .rotation-actions{display:flex;flex-shrink:0;gap:5px}.rotations-list-in-menu .delete-btn,.rotations-list-in-menu .edit-btn,.rotations-list-in-menu .view-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:16px;padding:4px;transition:background .2s ease}.rotations-list-in-menu .edit-btn:hover,.rotations-list-in-menu .view-btn:hover{background:#f0f0f0}.rotations-list-in-menu .delete-btn:hover{background:#fee}.rotations-list-in-menu .empty-state{background:#fff;border-radius:8px;box-shadow:0 1px 5px #0000001a;padding:20px;text-align:center}.rotations-list-in-menu .empty-state p{color:#666;font-size:12px;margin:0}.shifts-menu-items{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.shift-menu-item{align-items:center;background:#fff;border:2px solid #0000;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:10px;transition:all .3s ease}.shift-menu-item:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.shift-menu-item.selected{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #667eea}.shift-menu-initials{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:700;height:35px;justify-content:center;width:35px}.shift-menu-name{color:#333;font-size:10px;font-weight:500;text-align:center}.shift-menu-duration{color:#666;font-size:9px;font-weight:400;margin-top:1px;text-align:center}.no-shifts-message{color:#999;font-size:14px;font-style:italic;margin:10px 0 0}.rotations-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.empty-state{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:40px;text-align:center}.empty-state p{color:#666;font-size:16px;margin:0}.rotation-item{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:row;gap:15px;justify-content:space-between;padding:15px;transition:transform .2s ease,box-shadow .2s ease}.rotation-item:hover{box-shadow:0 4px 15px #00000026;transform:translateY(-2px)}.rotation-info{align-items:flex-start;display:flex;flex:1 1;flex-direction:column;gap:5px}.rotation-title{color:#333;font-size:24px;font-weight:700;margin:0}.rotation-meta{color:#666;font-size:14px}.rotation-actions{display:flex;flex-shrink:0;gap:10px}.delete-btn,.edit-btn,.view-btn{background:none;border:none;border-radius:6px;cursor:pointer;font-size:20px;padding:8px;transition:background .2s ease}.edit-btn:hover,.view-btn:hover{background:#f0f0f0}.delete-btn:hover{background:#fee}.rotation-view{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px}.rotation-view-header{align-items:center;border-bottom:1px solid #eee;display:flex;gap:20px;margin-bottom:30px;padding-bottom:20px}.back-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:24px;font-weight:700;height:50px;justify-content:center;transition:all .3s ease;width:50px}.back-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:scale(1.05)}.rotation-view-title h3{color:#333;font-size:24px;margin:0 0 5px}.rotation-view-title p{color:#666;font-size:14px;margin:0}.rotation-view-content{margin-top:20px}.rotation-identifier{align-items:center;background:#f5f5f5;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:30px;padding:15px 20px}.identifier-label{flex:1 1}.rotation-title-input{background:#fff;border:1px solid #ddd;border-radius:6px;color:#333;font-size:14px;padding:8px 12px;transition:border-color .3s ease;width:100%}.rotation-title-input:focus{border-color:#667eea;outline:none}.identifier-value{color:#333;font-size:16px;font-weight:600;margin-left:20px}.pattern-grid-view{margin-top:20px}.pattern-grid-view .pattern-row{margin-bottom:15px}.pattern-grid-view .pattern-cell{cursor:default}.pattern-grid-view .pattern-cell:hover{transform:none}@media (max-width:768px){.form-row{grid-template-columns:1fr}.pattern-container{flex-direction:column}.shifts-menu{flex:1 1;width:100%}.shifts-menu-items{flex-direction:row;flex-wrap:wrap;justify-content:center}.shift-menu-item{min-width:80px;width:auto}.pattern-cell{font-size:12px;height:40px;width:40px}.rotations-list{grid-template-columns:1fr}.rotation-item{align-items:center;flex-direction:row}.rotation-info{align-items:flex-start}.rotation-actions{flex-shrink:0}}.modal-content{border-radius:10px;box-shadow:0 4px 20px #0000004d;padding:30px;width:90%}.modal-content h3{color:#333;font-size:24px;margin:0 0 15px}.modal-content p{color:#666;font-size:16px;line-height:1.5;margin:0 0 25px}.modal-actions .btn-cancel,.modal-actions .btn-confirm,.modal-actions .btn-delete{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.modal-actions .btn-cancel{background:#f3f4f6}.modal-actions .btn-cancel:hover{background:#e5e7eb;box-shadow:0 2px 4px #0000001a}.modal-actions .btn-delete{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 8px #ef44444d;color:#fff}.modal-actions .btn-delete:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.delete-warning{color:#dc2626;font-size:14px;font-weight:600;margin-top:12px}.modal-header{border-radius:10px 10px 0 0}.delete-confirm-modal{max-width:450px}.grafik-container{box-sizing:border-box;margin:0 auto;max-width:1800px;padding:20px;width:100%}.grafik-header-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;margin-bottom:24px;padding:24px}.grafik-controls{align-items:center;display:flex;flex-wrap:wrap;gap:20px}.control-group{align-items:center;display:flex;gap:12px}.control-group label{color:#374151;font-size:14px;font-weight:600;white-space:nowrap}.control-group select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#111827;cursor:pointer;font-size:15px;min-width:200px;padding:12px 16px;transition:all .2s ease}.control-group select:hover{border-color:#9ca3af}.control-group select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a;outline:none}.month-navigation{gap:8px;margin-left:auto}.month-year-display{color:#111827;font-size:18px;font-weight:700;letter-spacing:-.3px;min-width:180px;text-align:center}.nav-button{align-items:center;background:linear-gradient(135deg,#4f46e5,#6366f1);border:none;border-radius:8px;box-shadow:0 2px 4px #4f46e54d;color:#fff;cursor:pointer;display:flex;font-size:18px;height:36px;justify-content:center;transition:all .2s ease;width:36px}.nav-button:hover{background:linear-gradient(135deg,#4338ca,#5b21b6);box-shadow:0 4px 8px #4f46e566;transform:translateY(-1px)}.nav-button:active{transform:translateY(0)}.clear-hours-button{align-items:center;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;box-shadow:0 2px 4px #ef444433;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .2s ease}.clear-hours-button:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px #ef44444d;transform:translateY(-1px)}.clear-hours-button:active{box-shadow:0 2px 4px #ef444433;transform:translateY(0)}.clear-hours-button svg{stroke:currentColor;height:16px;width:16px}.grafik-table-container{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow-x:auto;padding:24px}.grafik-table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible}.grafik-table{background:#fff;border-collapse:collapse;min-width:1200px;width:100%}.grafik-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik-table th{border-right:1px solid #fff3;font-size:12px;font-weight:600;letter-spacing:.5px;padding:14px 8px;text-align:center;text-transform:uppercase;white-space:nowrap}.grafik-table th:last-child{border-right:none}.employee-name-col{background:linear-gradient(135deg,#667eea,#764ba2);left:0;min-width:180px;padding-left:16px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:11}.overtime-col,.summary-col{background:linear-gradient(135deg,#5568d3,#6a3d8f);min-width:100px}.day-header.weekend{background:#ffffff26}.day-header.holiday{background:#ef444433}.day-header .day-number{font-size:16px;font-weight:700;margin-bottom:4px}.day-header .day-name{font-size:11px;font-weight:400;opacity:.9}.day-shift-info{align-items:center;border-radius:4px;box-shadow:0 1px 3px #0003;display:flex;flex-direction:column;font-size:10px;font-weight:600;gap:2px;line-height:1.2;margin-top:6px;padding:4px 6px;text-align:center}.day-shift-info .shift-week{font-size:9px;font-weight:700;letter-spacing:.5px;opacity:.95}.day-shift-info .shift-name{font-size:10px;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grafik-table tbody tr{border-bottom:1px solid #f3f4f6;transition:background-color .2s ease}.grafik-table tbody tr:hover{background-color:#f9fafb}.grafik-table tbody tr:last-child{border-bottom:none}.employee-name-cell{background:#fff;border-right:2px solid #e5e7eb;left:0;padding:12px 16px!important;position:-webkit-sticky;position:sticky;z-index:5}.grafik-table tbody tr:hover .employee-name-cell{background:#f9fafb}.employee-info{display:flex;flex-direction:column;gap:4px}.day-cell{background:#fff;border-right:1px solid #f3f4f6}.day-cell.weekend{background:#f9fafb}.day-cell.holiday{background:#fef2f2}.day-cell.has-absence{background:#f0f9ff}.day-input-container{align-items:center;display:flex;flex-direction:column;gap:4px}.hours-input{border:1.5px solid #d1d5db;font-size:12px;padding:5px 6px;transition:all .2s ease;width:50px}.hours-input.hours-day{border-color:#3b82f6}.hours-input.hours-day:hover{border-color:#2563eb}.hours-input.hours-day:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.hours-input.hours-night{border-color:#6366f1}.hours-input.hours-night:hover{border-color:#4f46e5}.hours-input.hours-night:focus{border-color:#6366f1;box-shadow:0 0 0 2px #6366f11a}.hours-input:hover{border-color:#9ca3af}.hours-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.absence-select{background:#fff;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;font-size:11px;padding:4px 6px;transition:all .2s ease;width:100%}.absence-select:hover{border-color:#d1d5db}.absence-select:focus{border-color:#667eea;outline:none}.absence-badge{box-shadow:0 2px 4px #0000001a;font-size:16px;height:32px;margin:0 auto;width:32px}.overtime-cell,.summary-cell{background:#f9fafb;border-right:1px solid #e5e7eb;font-weight:600;padding:12px 8px!important;text-align:center}.hours-summary{color:#111827;display:flex;flex-direction:column;font-size:13px;gap:4px}.hours-total{font-size:15px}.hours-total strong{color:#667eea;font-size:16px}.hours-breakdown{color:#6b7280;display:flex;flex-direction:column;font-size:11px;gap:2px}.hours-day-label{color:#3b82f6}.hours-night-label{color:#6366f1}.overtime-summary{font-size:12px}.overtime-details{align-items:center;display:flex;flex-direction:column;gap:4px}.overtime-badge{border-radius:6px;display:inline-block;font-size:13px;font-weight:600;padding:4px 10px}.overtime-breakdown{color:#6b7280;display:flex;flex-direction:column;font-size:10px;gap:2px}.overtime-100{color:#dc2626;font-size:11px;font-weight:600;margin-top:2px}.no-overtime{color:#9ca3af}.grafik-summary-section{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;margin-top:32px;padding:24px}.summary-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;gap:16px;justify-content:space-between;padding-bottom:16px}.summary-header-left{align-items:center;cursor:pointer;display:flex;flex:1 1;gap:12px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.summary-header-left:hover{opacity:.8}.generate-report-button{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 2px 4px #10b9814d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.generate-report-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.generate-report-button:active{transform:translateY(0)}.generate-report-button svg{flex-shrink:0}.summary-title{color:#111827;font-size:24px;font-weight:700;margin:0}.summary-toggle-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 4px #667eea4d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .3s ease;width:36px}.summary-toggle-button:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.summary-toggle-button:active{transform:translateY(0)}.summary-toggle-button svg{transition:transform .3s ease}.summary-toggle-button.expanded svg{transform:rotate(180deg)}.summary-content-wrapper{margin-top:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .4s ease-out,opacity .3s ease-out,margin-top .3s ease-out}.summary-content-wrapper.expanded{margin-top:24px;max-height:5000px;opacity:1;transition:max-height .5s ease-in,opacity .4s ease-in,margin-top .4s ease-in}.summary-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.employee-summary-card{background:linear-gradient(135deg,#f9fafb,#fff);border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px;transition:all .3s ease}.employee-summary-card:hover{border-color:#d1d5db;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.summary-card-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.summary-card-header h4{color:#111827;font-size:18px;font-weight:700;margin:0}.summary-position{background:#f3f4f6;border-radius:6px;color:#6b7280;font-size:12px;padding:4px 10px}.summary-content{gap:20px}.summary-content,.summary-group{display:flex;flex-direction:column}.summary-group{gap:8px}.summary-group h5{color:#374151;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 4px;text-transform:uppercase}.summary-item{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:8px 0}.summary-item:last-child{border-bottom:none}.summary-label{align-items:center;color:#6b7280;display:flex;font-size:13px;gap:6px}.summary-value{color:#111827;font-size:14px;font-weight:600}.summary-value.overtime-value{color:#dc2626}.summary-value.overtime-100-value{color:#b91c1c;font-weight:700}.no-employees-message,.no-project-message,.no-rotation-message{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014;padding:60px 20px;text-align:center}.no-employees-message p,.no-project-message p,.no-rotation-message p{color:#6b7280;font-size:16px;margin:0}@media (max-width:1366px){.grafik-container{padding:16px}.grafik-header-section,.grafik-table-container{padding:20px}.day-header{max-width:70px;min-width:70px}.day-shift-info{font-size:9px;padding:3px 4px}.day-shift-info .shift-week{font-size:8px}.day-shift-info .shift-name{font-size:9px}.hours-input{font-size:11px;padding:4px 5px;width:48px}}@media (max-width:1024px){.grafik-controls{align-items:stretch;flex-direction:column}.control-group{width:100%}.control-group select{flex:1 1;min-width:0}.month-navigation{justify-content:center;margin-left:0;width:100%}.grafik-table{min-width:1000px}}@media (max-width:768px){.grafik-container{padding:12px}.grafik-header-section{padding:16px}.grafik-table-container{padding:12px}.grafik-table{min-width:800px}.day-header{max-width:60px;min-width:60px;padding:10px 4px!important}.day-header .day-number{font-size:14px}.day-header .day-name{font-size:10px}.day-shift-info{font-size:8px;margin-top:4px;padding:2px 3px}.day-shift-info .shift-week{font-size:7px}.day-shift-info .shift-name{font-size:8px}.hours-input{font-size:11px;padding:4px 5px;width:45px}.summary-grid{grid-template-columns:1fr}.absence-select{font-size:10px;padding:3px 4px}.employee-name-col{min-width:150px}}@media (max-width:480px){.grafik-table{min-width:700px}.day-header{max-width:55px;min-width:55px}.hours-input{font-size:10px;padding:3px 4px;width:40px}.summary-grid{grid-template-columns:1fr}.employee-summary-card{padding:16px}.employee-name{font-size:13px}.employee-position{font-size:11px}.summary-header{align-items:stretch;flex-direction:column;gap:12px}.generate-report-button{justify-content:center;width:100%}}.modal-overlay{background-color:#00000080}.modal-content{animation:modalSlideIn .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{background:#f9fafb;border-bottom:2px solid #e5e7eb;border-radius:16px 16px 0 0;padding:24px 32px}.modal-header h3{font-size:22px;letter-spacing:-.3px}.modal-close{background:none;border-radius:50%;color:#999;font-size:28px;height:30px;padding:0;transition:background-color .3s;width:30px}.modal-close:hover{background-color:#f0f0f0;color:#333}.modal-actions{gap:10px;margin-top:24px}.modal-actions .btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.modal-actions .btn-confirm:hover{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.modal-actions .btn-cancel{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#374151;cursor:pointer;font-size:15px;font-weight:600;letter-spacing:-.2px;padding:12px 24px;transition:all .2s ease}.modal-actions .btn-cancel:hover{background:#f9fafb;border-color:#9ca3af;transform:translateY(-1px)}.grafik-table-container-new{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow-x:auto;padding:24px}.grafik-table-wrapper-new{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible}.grafik-table-new{background:#fff;border-collapse:collapse;font-size:13px;min-width:2000px;width:100%}.grafik-table-new thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik-table-new th{background:#f9fafb;font-size:11px;font-weight:600;letter-spacing:.3px;padding:10px 8px;white-space:nowrap}.grafik-table-new td,.grafik-table-new th{border:1px solid #e5e7eb;text-align:center}.grafik-table-new td{background:#fff;color:#111827;font-size:13px;padding:8px 6px;vertical-align:middle}.project-header-row th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:14px;font-weight:700;padding:12px}.project-header,.project-name-header{padding-left:16px!important;text-align:left!important}.main-header-row th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:12px;font-weight:700;letter-spacing:.3px;padding:12px 8px;text-shadow:0 1px 2px #0003}.col-summary-header{background:linear-gradient(135deg,#10b981,#059669)!important;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.summary-header-row th{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:10px;font-weight:600;line-height:1.3;padding:8px 4px;text-align:center;white-space:normal;writing-mode:horizontal-tb}.empty-header{background:linear-gradient(135deg,#10b981,#059669)!important;border:1px solid #fff3!important}.col-no{font-size:12px;font-weight:700;left:0;max-width:50px;min-width:50px}.col-firstname,.col-lastname,.col-no{background:#e5e7eb!important;border-right:2px solid #d1d5db!important;color:#111827!important;position:-webkit-sticky;position:sticky;z-index:8}.col-firstname,.col-lastname{font-size:13px;font-weight:600;left:50px;min-width:120px;padding-left:12px!important;text-align:left!important}.col-lastname{left:170px}.col-user{left:290px;min-width:120px}.col-position,.col-user{background:#e5e7eb!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:8}.col-position{left:410px;min-width:140px}.col-contract{left:550px;min-width:120px}.col-contract,.col-shift-type{background:#e5e7eb!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:8}.col-shift-type{left:670px;min-width:200px}.col-date{font-size:11px;max-width:70px;min-width:70px;padding:10px 6px!important}.col-date .date-day-name{color:#fff;font-size:13px;font-weight:700;letter-spacing:.3px;margin-bottom:4px;text-shadow:0 1px 2px #0003}.col-date .date-day-number{color:#fff;font-size:11px;font-weight:500;opacity:.95;text-shadow:0 1px 2px #0003}.day-cell-new{background:#fff;padding:4px 2px!important;text-align:center;vertical-align:middle}.day-cell-new.weekend{background:#f9fafb}.day-cell-new.holiday{background:#fef2f2}.day-cell-new.has-absence{background:#e0f2fe}.shift-input-new{background:#fff;border:1.5px solid #d1d5db;border-radius:4px;color:#111827;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s ease;width:100%}.shift-input-new:hover{border-color:#667eea}.shift-input-new:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.absence-label-new{background:#dbeafe;border-radius:4px;color:#1e40af;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.3px;padding:6px 8px}.shift-row.shiftDay .day-cell-new:not(.has-absence){background:#f0fdf4}.shift-row.shiftAfternoon .day-cell-new:not(.has-absence){background:#fef3c7}.shift-row.shiftNight .day-cell-new:not(.has-absence){background:#e0e7ff}.shift-row.overtimeAfternoon .day-cell-new:not(.has-absence),.shift-row.overtimeDay .day-cell-new:not(.has-absence),.shift-row.overtimeNight .day-cell-new:not(.has-absence){background:#fef2f2}.summary-cell-new{background:#f0fdf4!important;color:#111827;font-size:13px;font-weight:600;min-width:90px;padding:8px 6px!important;text-align:center}.summary-col{font-size:10px;font-weight:600;line-height:1.3;min-width:110px;padding:10px 6px!important}.shift-row.employee-first-row{border-top:3px solid #9ca3af!important}.shift-row.employee-last-row{border-bottom:3px solid #9ca3af!important}.shift-row.employee-first-row td{border-top:3px solid #9ca3af!important}.shift-row.employee-last-row td{border-bottom:3px solid #9ca3af!important}.grafik-table-new tbody tr.employee-first-row{background-color:#fafafa}.grafik-table-new tbody tr.employee-first-row .col-contract,.grafik-table-new tbody tr.employee-first-row .col-firstname,.grafik-table-new tbody tr.employee-first-row .col-lastname,.grafik-table-new tbody tr.employee-first-row .col-no,.grafik-table-new tbody tr.employee-first-row .col-position,.grafik-table-new tbody tr.employee-first-row .col-shift-type,.grafik-table-new tbody tr.employee-first-row .col-user{background:#f3f4f6!important}.grafik-table-new tbody tr:hover{background-color:#f9fafb}.grafik-table-new tbody tr:hover .col-contract,.grafik-table-new tbody tr:hover .col-firstname,.grafik-table-new tbody tr:hover .col-lastname,.grafik-table-new tbody tr:hover .col-no,.grafik-table-new tbody tr:hover .col-position,.grafik-table-new tbody tr:hover .col-shift-type,.grafik-table-new tbody tr:hover .col-user{background:#d1d5db!important}.grafik-single-card-container{margin:0 auto;width:100%}.grafik-single-card{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow:hidden}.grafik-card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px}.project-header-info{align-items:center;display:flex;gap:16px}.project-header-label{color:#fff;font-size:16px;font-weight:600;opacity:.9}.project-header-name{color:#fff;font-size:20px;font-weight:700;letter-spacing:-.3px}.grafik-card-content{overflow:visible;padding:0}.grafik-table-wrapper-single{-webkit-overflow-scrolling:touch;max-height:calc(100vh - 200px);overflow-x:auto;overflow-y:auto;position:relative}.grafik-table-single{background:#fff;border-collapse:initial;border-spacing:2px;font-size:13px;min-width:2000px;width:100%}.grafik-table-single thead{display:table-header-group}.grafik-table-single th{background:#f9fafb;font-size:11px;font-weight:600;letter-spacing:.3px;padding:10px 8px;white-space:nowrap}.grafik-table-single td,.grafik-table-single th{border:1px solid #e5e7eb;border-radius:8px;margin:2px;text-align:center}.grafik-table-single td{background:#fff;box-shadow:0 1px 2px #00000008;color:#111827;font-size:13px;padding:8px 6px;transition:all .2s ease;vertical-align:middle}.project-header-row-single th{background:linear-gradient(135deg,#4f46e5,#6366f1);box-shadow:0 2px 4px #4f46e533;color:#fff;font-size:14px;font-weight:700;padding:12px}.project-header-single,.project-name-header-single{padding-left:16px!important;text-align:left!important}.main-header-row-single th{background:linear-gradient(135deg,#4f46e5,#6366f1);box-shadow:0 1px 3px #4f46e526;color:#fff;letter-spacing:.3px;padding:12px 8px;text-shadow:0 1px 2px #00000026;top:0!important;z-index:10!important}.col-summary-header-single,.main-header-row-single th{font-size:12px;font-weight:700;position:-webkit-sticky!important;position:sticky!important;will-change:transform}.col-summary-header-single{background:linear-gradient(135deg,#059669,#10b981)!important;box-shadow:0 1px 3px #05966933;letter-spacing:.5px;text-transform:uppercase}.main-header-row-single .col-summary-header-single{top:0!important;z-index:9!important}.summary-header-row-single .col-summary-header-single{top:48px!important;z-index:8!important}.summary-header-row-single th{box-shadow:0 1px 3px #05966926;color:#fff;font-size:10px;font-weight:600;line-height:1.3;padding:8px 4px;text-align:center;white-space:normal;writing-mode:horizontal-tb}.empty-header-single,.summary-header-row-single th{background:linear-gradient(135deg,#059669,#10b981)!important;position:-webkit-sticky!important;position:sticky!important;top:48px!important;will-change:transform}.empty-header-single{border:1px solid #ffffff40!important;box-shadow:0 1px 2px #0596691a;z-index:7!important}.summary-header-row-single th.empty-header-single:first-child{left:0!important;z-index:8!important}.summary-header-row-single th.empty-header-single:nth-child(2){left:50px!important;z-index:8!important}.summary-header-row-single th.empty-header-single:nth-child(3){left:170px!important;z-index:8!important}.summary-header-row-single th.empty-header-static:nth-of-type(4){left:auto!important;z-index:7!important}.summary-header-row-single th.empty-header-static:not(:nth-of-type(4)){left:290px!important;z-index:8!important}.summary-header-row-single th.empty-header-single:has(.week-number-in-cell){left:auto!important;position:-webkit-sticky!important;position:sticky!important;z-index:6!important}.empty-header-single .week-number-in-cell{color:#fff;font-size:11px;font-weight:600;letter-spacing:.2px;text-shadow:0 1px 2px #0003}.col-no-single{font-size:12px;font-weight:700;left:0;max-width:50px;min-width:50px}.col-firstname-single,.col-lastname-single,.col-no-single{background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;border-right:2px solid #e2e8f0!important;color:#1e293b!important;position:-webkit-sticky!important;position:sticky!important;top:96px!important;will-change:transform;z-index:7!important}.col-firstname-single,.col-lastname-single{font-size:13px;font-weight:600;left:50px;min-width:120px;padding-left:12px!important;text-align:left!important}.col-lastname-single{left:170px}.col-user-single{min-width:120px}.col-position-single,.col-user-single{background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;border-right:2px solid #e2e8f0!important;color:#1e293b!important;font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky!important;position:sticky!important;text-align:left!important;top:96px!important;will-change:transform;z-index:7!important}.col-position-single{min-width:140px}.col-contract-single{background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;border-right:2px solid #e2e8f0!important;color:#1e293b!important;min-width:120px}.col-contract-single,.col-shift-type-single{font-size:13px;font-weight:600;padding-left:12px!important;position:-webkit-sticky!important;position:sticky!important;text-align:left!important;top:96px!important;will-change:transform;z-index:7!important}.col-shift-type-single{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;border-right:2px solid #fbbf24!important;color:#78350f!important;left:290px;min-width:200px}.col-date-single{font-size:11px;max-width:70px;min-width:70px;padding:10px 6px!important;position:-webkit-sticky!important;position:sticky!important;will-change:transform}.main-header-row-single .col-date-single{top:0!important;z-index:9!important}.summary-header-row-single .col-date-single{top:48px!important;z-index:8!important}.col-date-single .date-week-number{color:#ffffffd9;font-size:10px;font-weight:600;letter-spacing:.2px;margin-bottom:2px;opacity:.9;text-shadow:0 1px 2px #0003}.col-date-single .date-day-name{color:#fff;font-size:13px;font-weight:700;letter-spacing:.3px;margin-bottom:4px;text-shadow:0 1px 2px #0003}.col-date-single .date-day-number{color:#fff;font-size:11px;font-weight:500;opacity:.95;text-shadow:0 1px 2px #0003}.day-cell-single{background:#fff;border-radius:8px;box-shadow:0 1px 2px #00000008;margin:2px;padding:6px 4px!important;position:relative;text-align:center;transition:all .2s ease;vertical-align:middle}.day-cell-single.weekend{background:#f9fafb}.day-cell-single.holiday{background:linear-gradient(135deg,#fee2e2,#fecaca)!important;border:2px solid #ef4444!important;box-shadow:0 2px 4px #ef444433!important}.day-cell-single.has-absence{background:#e0f2fe}.day-cell-single.has-absence.has-shift-color{background:#e0f2feb3!important}.day-cell-single.has-shift-color{z-index:1}.grafik-table-single tbody .day-cell-single.has-absence.has-shift-color{border-left-style:solid!important;border-left-width:3px!important;border-right-style:solid!important;border-right-width:3px!important}.day-cell-single.day-off{background:#f3f4f6!important;opacity:.6;position:relative}.day-cell-single.day-off:before{background:repeating-linear-gradient(45deg,#0000,#0000 5px,#00000014 0,#00000014 10px);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.day-cell-single.day-off .day-off-label,.day-cell-single.day-off .shift-input-single{position:relative;z-index:1}.day-off-label{border-radius:6px;color:#9ca3af;cursor:text;display:inline-block;font-size:14px;font-weight:600;opacity:.7;padding:4px 8px;transition:all .2s ease}.day-cell-single.has-shift-color{position:relative}.day-cell-single.has-shift-color .shift-input-single{background:#ffffffe6;font-weight:600}.day-cell-single.has-shift-color .shift-input-single:focus{background:#fff;box-shadow:0 0 0 2px #0000001a}.shift-input-single::-webkit-inner-spin-button,.shift-input-single::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.shift-input-single{-webkit-appearance:textfield;appearance:textfield;background:#fff;border:1.5px solid #d1d5db;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#111827;display:inline-block;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s ease;width:calc(100% - 28px)}.input-with-absence-button{gap:4px}.input-with-absence-button,.input-without-absence-button{align-items:center;display:flex;width:100%}.input-without-absence-button .shift-input-single{width:100%}.absence-button{border:1.5px solid #d1d5db;border-radius:6px;color:#667eea;min-height:24px;min-width:24px;padding:0}.overtime-indicator-button{align-items:center;background:#fb71851a;border:1.5px solid #fb7185;border-radius:6px;color:#be123c;cursor:pointer;display:flex;font-size:12px;font-weight:700;height:24px;justify-content:center;min-height:24px;min-width:24px;padding:0;transition:all .2s ease;width:24px}.overtime-indicator-button:hover{background:#fb718533;border-color:#be123c;transform:scale(1.05)}.has-overtime{background:#fb718533!important}.absence-button:hover{background:#667eea;box-shadow:0 2px 4px #667eea4d;color:#fff;transform:translateY(-1px)}.absence-button:active{box-shadow:0 1px 2px #667eea33;transform:translateY(0)}.absence-button svg{stroke:currentColor;height:14px;width:14px}.shift-input-single:hover{border-color:#6366f1;box-shadow:0 2px 4px #6366f126;transform:translateY(-1px)}.shift-input-single:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a,0 2px 4px #00000014;outline:none;transform:translateY(-1px)}.absence-label-single{background:#3b82f61a;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#1e40af;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.5px;padding:6px 8px;transition:all .2s ease}.absence-label-single:hover{background:#3b82f626;box-shadow:0 2px 4px #00000014;transform:translateY(-1px)}.shift-row-single.shiftAfternoon .day-cell-single:not(.has-absence),.shift-row-single.shiftDay .day-cell-single:not(.has-absence),.shift-row-single.shiftNight .day-cell-single:not(.has-absence){background:#fff}.shift-row-single.overtimeDay .day-cell-single:not(.has-absence),.shift-row-single.overtimeNight .day-cell-single:not(.has-absence){background:#fef2f2}.shift-row-single.employee-first-row-single{border-top:3px solid #9ca3af!important}.shift-row-single.employee-last-row-single{border-bottom:3px solid #9ca3af!important}.shift-row-single.employee-first-row-single td{border-top:3px solid #9ca3af!important}.shift-row-single.employee-last-row-single td{border-bottom:3px solid #9ca3af!important}.shift-row-single.overtime-first-row,.shift-row-single.overtime-first-row td{border-top:3px solid #dc2626!important;position:relative}.shift-row-single.overtime-row{background:#fef2f2}.shift-row-single.overtime-row .col-shift-label-single{background:#fee2e2!important;border-right:2px solid #dc2626!important;color:#991b1b!important;font-weight:700!important;left:290px!important;position:-webkit-sticky!important;position:sticky!important;z-index:8!important}.shift-row-single.overtime-row .day-cell-single{background:#fef2f2}.shift-row-single.overtime-row:hover,.shift-row-single.overtime-row:hover .day-cell-single{background:#fee2e2}.shift-row-single.overtime-row:hover .col-shift-label-single{background:#fecaca!important;left:290px!important;position:-webkit-sticky!important;position:sticky!important;z-index:8!important}.col-shift-label-single{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;left:290px;min-width:200px;padding-left:12px!important;position:-webkit-sticky!important;position:sticky!important;text-align:left!important;top:96px!important;will-change:transform;z-index:7!important}.summary-cell-single{background:#f0fdf4!important;color:#111827;font-size:13px;font-weight:600;min-width:90px;padding:8px 6px!important;text-align:center}.summary-col-single{font-size:10px;font-weight:600;left:auto!important;line-height:1.3;min-width:110px;padding:10px 6px!important;position:-webkit-sticky!important;position:sticky!important;z-index:6!important}.grafik-table-single tbody tr:hover{background-color:#f9fafb}.grafik-table-single tbody tr:hover .col-contract-single,.grafik-table-single tbody tr:hover .col-firstname-single,.grafik-table-single tbody tr:hover .col-lastname-single,.grafik-table-single tbody tr:hover .col-no-single,.grafik-table-single tbody tr:hover .col-position-single,.grafik-table-single tbody tr:hover .col-user-single{background:linear-gradient(135deg,#e2e8f0,#cbd5e1)!important}.grafik-table-single tbody tr:hover .col-shift-label-single{background:linear-gradient(135deg,#fde68a,#fcd34d)!important}.employee-card{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;overflow:hidden;transition:all .3s ease}.employee-card:hover{box-shadow:0 8px 32px #0000001f,0 2px 6px #00000014;transform:translateY(-2px)}.employee-card-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px}.employee-card-info{align-items:center;display:flex;gap:16px}.employee-card-number{align-items:center;background:#fff3;border-radius:12px;display:flex;flex-shrink:0;font-size:20px;font-weight:700;height:48px;justify-content:center;width:48px}.employee-card-name{flex:1 1}.employee-card-name-main{font-size:20px;font-weight:700;letter-spacing:-.3px;margin-bottom:6px}.employee-card-name-details{align-items:center;display:flex;font-size:14px;font-weight:500;gap:8px;opacity:.9}.employee-card-separator{opacity:.6}.employee-card-content{overflow-x:auto;padding:0}.grafik-table-wrapper-card{-webkit-overflow-scrolling:touch;overflow-x:auto;overflow-y:visible}.grafik-table-card{background:#fff;border-collapse:collapse;font-size:13px;min-width:1800px;width:100%}.grafik-table-card thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik-table-card th{background:#f9fafb;border:1px solid #e5e7eb;font-size:11px;font-weight:600;letter-spacing:.3px;padding:10px 8px;text-align:center;white-space:nowrap}.grafik-table-card td{background:#fff;border:1px solid #e5e7eb;color:#111827;font-size:13px;padding:8px 6px;text-align:center;vertical-align:middle}.card-header-row th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:12px;font-weight:700;letter-spacing:.3px;padding:12px 8px;text-shadow:0 1px 2px #0003}.col-shift-type-card{background:linear-gradient(135deg,#667eea,#764ba2)!important;left:0;min-width:180px;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:11}.col-date-card{font-size:11px;max-width:70px;min-width:70px;padding:10px 6px!important}.col-date-card .date-day-name{color:#fff;font-size:13px;font-weight:700;letter-spacing:.3px;margin-bottom:4px;text-shadow:0 1px 2px #0003}.col-date-card .date-day-number{color:#fff;font-size:11px;font-weight:500;opacity:.95;text-shadow:0 1px 2px #0003}.col-summary-header-card{background:linear-gradient(135deg,#10b981,#059669)!important;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.summary-header-row-card th{background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-size:10px;font-weight:600;line-height:1.3;padding:8px 4px;text-align:center;white-space:normal;writing-mode:horizontal-tb}.empty-header-card{background:linear-gradient(135deg,#10b981,#059669)!important;border:1px solid #fff3!important}.summary-col-card{font-size:10px;font-weight:600;line-height:1.3;min-width:110px;padding:10px 6px!important}.col-shift-label-card{background:#f3f4f6!important;border-right:2px solid #d1d5db!important;color:#111827!important;font-size:13px;font-weight:600;left:0;min-width:180px;padding-left:12px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:8}.day-cell-card{background:#fff;padding:6px 4px!important;text-align:center;vertical-align:middle}.day-cell-card.weekend{background:#f9fafb}.day-cell-card.holiday{background:#fef2f2}.day-cell-card.has-absence{background:#e0f2fe}.shift-input-card{background:#fff;border:1.5px solid #d1d5db;border-radius:4px;color:#111827;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s ease;width:100%}.shift-input-card:hover{border-color:#667eea}.shift-input-card:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.absence-label-card{background:#dbeafe;border-radius:4px;color:#1e40af;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.3px;padding:6px 8px}.shift-row-card.shiftDay .day-cell-card:not(.has-absence){background:#f0fdf4}.shift-row-card.shiftAfternoon .day-cell-card:not(.has-absence){background:#fef3c7}.shift-row-card.shiftNight .day-cell-card:not(.has-absence){background:#e0e7ff}.shift-row-card.overtimeDay .day-cell-card:not(.has-absence),.shift-row-card.overtimeNight .day-cell-card:not(.has-absence){background:#fef2f2}.summary-cell-card{background:#f0fdf4!important;color:#111827;font-size:13px;font-weight:600;min-width:90px;padding:8px 6px!important;text-align:center}.grafik-table-card tbody tr:hover{background-color:#f9fafb}.grafik-table-card tbody tr:hover .col-shift-label-card{background:#e5e7eb!important}.report-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.report-modal-content{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:500px;overflow:hidden;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.report-modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e5e7eb;color:#fff;display:flex;justify-content:space-between;padding:24px}.report-modal-header h3{font-size:20px;font-weight:700;margin:0}.report-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:32px}.report-modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}.report-modal-body{padding:24px}.report-modal-info{margin-bottom:24px}.report-modal-info p{color:#6b7280;font-size:14px;line-height:1.6;margin:0 0 12px}.report-modal-info p:last-child{margin-bottom:0}.report-modal-month,.report-modal-project{color:#374151;font-size:15px}.report-modal-form{display:flex;flex-direction:column;gap:16px}.report-modal-form label{color:#374151;font-size:14px;font-weight:600}.required-asterisk{color:#ef4444}.contract-type-select{background:#fff;border:1.5px solid #d1d5db;border-radius:8px;color:#111827;cursor:pointer;font-size:15px;padding:12px 16px;transition:all .2s ease}.contract-type-select:hover{border-color:#9ca3af}.contract-type-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.report-modal-preview{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin-top:8px;padding:12px 16px}.report-modal-preview p{color:#0369a1;font-size:14px;line-height:1.5;margin:0}.report-modal-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.report-modal-cancel,.report-modal-generate{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.report-modal-cancel{background:#f3f4f6;color:#374151}.report-modal-cancel:hover{background:#e5e7eb}.report-modal-generate{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d;color:#fff}.report-modal-generate:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.report-modal-generate:disabled{cursor:not-allowed;opacity:.5;transform:none}.grafik2-container{box-sizing:border-box;padding:20px;width:100%}.grafik2-header{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;padding:20px}.grafik2-filters{align-items:flex-end;display:flex;flex-wrap:wrap;gap:20px}.filter-group{gap:8px}.filter-group label{color:#374151;font-size:14px;font-weight:500}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:8px;color:#111827;min-width:200px;padding:10px 14px;transition:all .2s}.filter-select:hover{border-color:#9ca3af}.filter-select:focus{box-shadow:0 0 0 3px #667eea1a}.month-navigation{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:12px;padding:8px 12px}.month-nav-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:20px;height:32px;justify-content:center;transition:all .2s;width:32px}.month-nav-button:hover{background:#f3f4f6;border-color:#9ca3af}.month-nav-button:active{transform:scale(.95)}.month-display{color:#111827;font-size:16px;font-weight:600;min-width:180px;text-align:center}.grafik2-message{color:#6b7280;padding:40px;text-align:center}.grafik2-message,.grafik2-table-wrapper{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.grafik2-table-wrapper{overflow-x:auto;padding:20px}.grafik2-table{border-collapse:collapse;min-width:800px;width:100%}.grafik2-table thead{background:#f9fafb;position:-webkit-sticky;position:sticky;top:0;z-index:10}.grafik2-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:12px;font-weight:600;padding:12px 8px;text-align:center;white-space:nowrap}.employee-column{background:#f9fafb;left:0;max-width:400px;min-width:300px;padding-left:16px!important;position:-webkit-sticky;position:sticky;text-align:left!important;z-index:11}.day-header{max-width:80px;min-width:80px;padding:8px 4px!important}.day-header.weekend{background:#fef2f2}.day-header.empty{background:#0000;border:none}.day-header-content{display:flex;flex-direction:column;gap:4px}.day-name{color:#6b7280;font-size:11px;text-transform:uppercase}.day-number{color:#111827;font-size:16px;font-weight:700}.day-month{color:#9ca3af;font-size:10px;margin-top:2px}.summary-column{font-weight:700;min-width:100px;text-align:center;vertical-align:middle}.summary-hours-header{background:#e0f2fe!important;color:#0369a1}.summary-overtime-daily-header{background:#f3f4f6!important;border-left:2px solid #d1d5db;color:#374151}.summary-overtime-night-header{background:#f9fafb!important;border-left:2px solid #9ca3af;color:#1f2937}.summary-overtime-saturday-header{background:#fef3c7!important;border-left:2px solid #fbbf24;color:#92400e}.summary-overtime-sunday-header{background:#fee2e2!important;border-left:2px solid #ef4444;color:#991b1b}.summary-absence-header{background:#fef3c7!important;color:#92400e}.summary-label-small{color:#6b7280;display:block;font-size:10px;font-weight:400;margin-top:4px}.grafik2-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.grafik2-table tbody tr:hover{background:#f9fafb}.employee-cell{background:#fff;border-right:2px solid #e5e7eb;left:0;overflow:hidden;padding:12px 16px!important;position:-webkit-sticky;position:sticky;text-overflow:ellipsis;white-space:nowrap;z-index:9}.employee-row:hover .employee-cell{background:#f9fafb}.employee-cell.employee-cell-selected{background-color:#dbeafe!important;border-right:2px solid #3b82f6}.employee-row:hover .employee-cell.employee-cell-selected{background-color:#bfdbfe!important}.employee-info{align-items:center;display:flex!important;flex-direction:row!important;gap:8px;overflow:hidden;white-space:nowrap!important;width:100%}.employee-name{color:#111827;flex-shrink:1;font-size:14px;font-weight:600;max-width:200px;min-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.employee-separator{color:#9ca3af;flex-shrink:0;font-size:12px;text-align:center;width:6px}.employee-position{color:#6b7280;font-weight:500;max-width:100px;min-width:80px}.employee-position,.employee-user{flex-shrink:0;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.employee-user{color:#4b5563;max-width:120px;min-width:100px}.employee-contract{color:#6b7280;flex-shrink:1;font-size:12px;font-weight:500;min-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-cell{max-width:60px;min-width:60px;padding:8px 4px!important;position:relative;text-align:center;-webkit-user-select:none;user-select:none;vertical-align:middle}.day-cell.weekend{background:#fef2f2}.day-cell.has-absence{font-weight:600}.day-cell.overtime-normal-cell{background-color:#fed7aa!important}.day-cell.overtime-normal-cell:hover{background-color:#fdba74!important}.day-cell.overtime-premium-cell{background-color:#fecaca!important}.day-cell.overtime-premium-cell:hover{background-color:#fca5a5!important}.day-cell.weekend.overtime-normal-cell{background-color:#fed7aa!important}.day-cell.weekend.overtime-premium-cell{background-color:#fecaca!important}.cell-content{align-items:center;display:flex;justify-content:center;min-height:40px;-webkit-user-select:none;user-select:none}.day-cell.cell-selected{background-color:#dbeafe!important;border:none!important;border-radius:4px}.day-cell.cell-selected:hover{background-color:#bfdbfe!important}.cell-actions{align-items:center;display:flex;gap:4px;justify-content:center;width:100%}.hours-display-wrapper{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:35px}.hours-display{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#111827;cursor:pointer;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;transition:all .2s}.overtime-badge{align-items:center;background:#fee2e2;border:1px solid #fecaca;border-radius:4px;color:#dc2626;display:inline-flex;font-size:10px;font-weight:700;gap:2px;padding:2px 6px;text-align:center}.overtime-badge.overtime-premium{background-color:#8b0000;border-color:#8b0000;color:#fff}.overtime-premium-mark{color:gold;font-size:.7rem}.hours-display:hover{background:#f0f4ff;border-color:#667eea}.hours-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:13px;font-weight:500;padding:6px 4px;text-align:center;width:100%}.hours-input,.hours-input:focus{outline:none!important;outline-width:0!important}.hours-input:focus{-webkit-appearance:none;appearance:none;border:1px solid #d1d5db;box-shadow:none!important}.hours-input:focus-visible{box-shadow:none!important;outline:none!important;outline-width:0!important}.absence-button{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:16px;font-weight:600;height:24px;justify-content:center;transition:all .2s;width:24px}.absence-button:hover{background:#f0f4ff;border-color:#667eea;color:#667eea}.absence-badge{align-items:center;border:2px solid #0000;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:8px 4px;transition:all .2s;width:100%}.absence-badge:hover{border-color:#0000001a;transform:scale(1.05)}.absence-icon{font-size:18px}.summary-cell{font-size:14px;font-weight:600;padding:12px 8px!important;text-align:center}.hours-summary{background:#dbeafe!important;border-left:2px solid #3b82f6;color:#1e40af}.overtime-summary{font-weight:700}.overtime-daily-summary,.overtime-summary{background:#f3f4f6!important;border-left:2px solid #d1d5db;color:#374151}.overtime-night-summary{background:#f9fafb!important;border-left:2px solid #9ca3af;color:#1f2937}.overtime-saturday-summary{background:#fef3c7!important;border-left:2px solid #fbbf24;color:#92400e}.overtime-sunday-summary{background:#fee2e2!important;border-left:2px solid #ef4444;color:#991b1b}.absence-summary{background:#fef3c7!important}.absence-type-summary,.summary-absence-type-header{border-left:2px solid #0000001a;font-weight:600}.absence-type-summary{color:#92400e}.option-modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:100%}.option-modal-content{padding:24px}.option-modal-instruction{color:#6b7280;font-size:14px;margin:0 0 20px;text-align:center}.option-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.option-button{align-items:center;border:2px solid;border-radius:12px;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:12px;padding:16px 20px;text-align:left;transition:all .2s;width:100%}.option-button:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.option-button:active{transform:translateY(0)}.overtime-button{background:#dbeafe;border-color:#3b82f6;color:#1e40af}.overtime-button:hover{background:#bfdbfe;border-color:#2563eb}.absence-button-modal{background:#d1fae5;border-color:#10b981;color:#065f46}.absence-button-modal:hover{background:#a7f3d0;border-color:#059669}.option-icon{flex-shrink:0;font-size:24px}.option-label{font-weight:600}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.btn-cancel,.btn-confirm{border:1px solid;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-cancel{background:#fff;border-color:#d1d5db;color:#374151}.btn-cancel:hover{background:#f9fafb;border-color:#9ca3af}.btn-confirm{background:#3b82f6;border-color:#3b82f6;color:#fff}.btn-confirm:hover{background:#2563eb;border-color:#2563eb}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.absence-modal{max-height:90vh;max-width:600px;overflow-y:auto}.absence-modal,.overtime-modal{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:100%}.overtime-modal{max-width:400px}.overtime-modal-content{padding:24px}.overtime-modal-instruction{color:#6b7280;font-size:14px;margin:0 0 20px;text-align:center}.overtime-input-group{align-items:center;display:flex;gap:12px;justify-content:center;margin-bottom:24px}.overtime-split-inputs{display:flex;flex-direction:column;gap:16px;margin-bottom:16px}.overtime-split-inputs .overtime-input-group{align-items:flex-start;display:flex;flex-direction:column;gap:8px;justify-content:flex-start;margin-bottom:0}.overtime-split-inputs .overtime-input-group label{color:#374151;font-size:14px;font-weight:500}.overtime-split-inputs .overtime-input-group .overtime-input{width:100%}.overtime-input{border:2px solid #d1d5db;border-radius:8px;font-size:18px;font-weight:600;outline:none;padding:12px 16px;text-align:center;transition:all .2s;width:120px}.overtime-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.overtime-unit{color:#6b7280;font-size:16px;font-weight:500}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:12px;justify-content:space-between;padding:20px 24px}.modal-header h3{color:#111827;flex:1 1;font-size:20px;font-weight:700;margin:0;text-align:center}.modal-back{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;font-weight:600;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-back:hover{background:#e5e7eb;color:#111827}.modal-close{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;font-size:20px;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-close:hover{background:#e5e7eb;color:#111827}.absence-types-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));padding:24px}.absence-type-button{align-items:center;background:#fff;border:2px solid;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-weight:500;gap:8px;padding:16px 12px;transition:all .2s}.absence-type-button:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.absence-type-button:active{transform:translateY(0)}.absence-type-icon{font-size:24px}.absence-type-label{font-size:13px;text-align:center}.absence-type-button.remove-absence{background:#fee2e2;border-color:#ef4444;color:#dc2626;grid-column:1/-1}.absence-type-button.remove-absence:hover{background:#fecaca}@media (max-width:1366px){.grafik2-container{padding:15px}.day-cell,.day-header{max-width:70px;min-width:70px}}@media (max-width:1024px){.grafik2-filters{flex-direction:column;gap:15px}.filter-select{min-width:100%}.day-cell,.day-header{max-width:60px;min-width:60px}.absence-types-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}@media (max-width:768px){.grafik2-container{padding:10px}.grafik2-header{padding:15px}.grafik2-table-wrapper{padding:10px}.day-cell,.day-header{max-width:50px;min-width:50px;padding:6px 2px!important}.employee-column{min-width:120px}.hours-display{font-size:11px;padding:4px 6px}.absence-types-grid{grid-template-columns:repeat(2,1fr);padding:16px}}@media (max-width:480px){.month-display{font-size:14px;min-width:140px}.day-name{font-size:10px}.day-number{font-size:14px}.absence-types-grid{grid-template-columns:1fr}}.uzupelnij-raport-container{background:#1a1f2e;display:flex;flex-direction:column;height:100%;max-height:100%;min-height:100%;overflow:hidden;padding:0}.uzupelnij-raport-loading{color:#94a3b8;font-size:16px;padding:48px;text-align:center}.uzupelnij-raport-toolbar{align-items:center;background:#252d3d;border-bottom:1px solid #334155;display:flex;flex-shrink:0;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:12px 16px}.uzupelnij-raport-actions-left{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.uzupelnij-raport-actions-right{align-items:center;display:flex;gap:8px;margin-left:auto}.uzupelnij-raport-tabs-bar{align-items:flex-end;background:#252d3d;border-top:1px solid #334155;display:flex;flex-shrink:0;padding:0 16px 8px}.uzupelnij-raport-tabs{align-items:flex-end;display:flex;flex-wrap:wrap;gap:2px}.uzupelnij-raport-tab{align-items:center;background:#1e2433;border:1px solid #334155;border-bottom:none;border-radius:6px 6px 0 0;cursor:pointer;display:flex;gap:12px;justify-content:space-between;margin-bottom:-1px;min-width:80px;padding:8px 12px 8px 14px;position:relative}.uzupelnij-raport-tab.active{background:#1a1f2e;border-bottom:1px solid #1a1f2e;color:#f1f5f9;padding-bottom:9px;z-index:1}.uzupelnij-raport-tab-label{color:#cbd5e1;font-size:14px;-webkit-user-select:none;user-select:none}.uzupelnij-raport-tab.active .uzupelnij-raport-tab-label{color:#f1f5f9}.uzupelnij-raport-tab-export{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:11px;margin-left:4px;padding:2px 6px}.uzupelnij-raport-tab-export:hover{background:#22c55e33;color:#4ade80}.uzupelnij-raport-tab-rename{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:14px;margin-left:4px;padding:2px 6px}.uzupelnij-raport-tab-rename:hover{background:#3b82f633;color:#93c5fd}.uzupelnij-raport-tab-close{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:18px;line-height:1;padding:2px 6px}.uzupelnij-raport-tab-close:hover{background:#ef444433;color:#f87171}.uzupelnij-raport-add-sheet{background:#334155;border:1px solid #475569;border-radius:6px;color:#e4e8eb;cursor:pointer;font-size:13px;padding:8px 12px;transition:background .2s}.uzupelnij-raport-add-sheet:hover{background:#475569}.uzupelnij-raport-actions{align-items:center;display:flex;gap:8px}.uzupelnij-raport-btn{background:#334155;border:1px solid #475569;border-radius:6px;color:#e4e8eb;cursor:pointer;font-size:13px;padding:8px 14px;transition:background .2s}.uzupelnij-raport-btn:hover{background:#475569}.uzupelnij-raport-btn-remove{border-color:#7f1d1d;color:#f87171}.uzupelnij-raport-btn-remove:hover{background:#ef444433;border-color:#991b1b}.uzupelnij-raport-btn-save{background:#1e40af!important;border-color:#2563eb!important;color:#fff!important;margin-left:8px}.uzupelnij-raport-btn-save:hover{background:#2563eb!important;border-color:#3b82f6!important}.uzupelnij-raport-saving{color:#94a3b8;font-size:12px}.uzupelnij-raport-error{color:#f87171;font-size:12px}.uzupelnij-raport-sheet-wrap{-webkit-overflow-scrolling:touch;display:flex;flex:1 1;flex-direction:column;min-height:0;padding:16px}.uzupelnij-raport-spreadsheet-wrapper{display:flex;flex-direction:column;gap:0;min-width:100%}.uzupelnij-raport-spreadsheet-headers{background:#334155;border:1px solid #334155;border-bottom-color:#475569;display:flex;flex-wrap:nowrap;padding:0}.uzupelnij-raport-spreadsheet-header-cell{align-items:center;border-right:1px solid #475569;display:flex;flex:1 1;gap:4px;min-width:100px;padding:6px 8px}.uzupelnij-raport-spreadsheet-header-cell:last-child{border-right:none}.uzupelnij-raport-spreadsheet-header-label{color:#e2e8f0;flex:1 1;font-size:14px;font-weight:600;min-width:0;overflow:hidden;padding:6px 8px;text-overflow:ellipsis;white-space:nowrap}.uzupelnij-raport-spreadsheet-header-rename-btn{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;flex-shrink:0;font-size:14px;padding:4px 6px}.uzupelnij-raport-spreadsheet-header-rename-btn:hover{background:#3b82f633;color:#93c5fd}.uzupelnij-raport-spreadsheet{min-width:100%}.uzupelnij-raport-spreadsheet .spreadsheet-table tbody tr:first-child td,.uzupelnij-raport-spreadsheet table tbody tr:first-child td{background:#334155!important;color:#e2e8f0;font-weight:600}.uzupelnij-raport-fallback-sheet{background:#252d3d;border:1px solid #334155;border-radius:8px;flex:1 1;min-height:0;overflow:auto}.uzupelnij-raport-fallback-sheet.uzupelnij-raport-resizing{cursor:col-resize;-webkit-user-select:none;user-select:none}.uzupelnij-raport-fallback-sheet.uzupelnij-raport-resizing *{cursor:col-resize}.uzupelnij-raport-fallback-table{background:#252d3d;border-collapse:collapse;table-layout:fixed}.uzupelnij-raport-fallback-table td,.uzupelnij-raport-fallback-table th{border:1px solid #33415580;padding:0;vertical-align:top}.uzupelnij-raport-header-row{background:#334155}.uzupelnij-raport-header-cell{color:#e2e8f0;font-weight:600;padding:0;position:relative}.uzupelnij-raport-fallback-sheet .uzupelnij-raport-fallback-table thead{background:#334155;position:-webkit-sticky;position:sticky;top:0;z-index:4}.uzupelnij-raport-fallback-sheet .uzupelnij-raport-fallback-table .uzupelnij-raport-header-row{background:#334155}.uzupelnij-raport-fallback-sheet .uzupelnij-raport-fallback-table .uzupelnij-raport-header-cell{background:#334155!important;box-shadow:0 2px 4px #0000004d;position:-webkit-sticky;position:sticky;top:0;z-index:4}.uzupelnij-raport-col-resize-handle{cursor:col-resize;height:100%;position:absolute;right:0;top:0;width:8px;z-index:2}.uzupelnij-raport-col-resize-handle:before{background:#475569;content:"";height:100%;position:absolute;right:0;top:0;width:1px}.uzupelnij-raport-col-resize-handle:active:before,.uzupelnij-raport-col-resize-handle:hover:before{background:#3b82f6;width:2px}.uzupelnij-raport-col-resize-handle:hover{background:#3b82f626}.uzupelnij-raport-col-resize-handle:active{background:#3b82f640}.uzupelnij-raport-header-cell-wrap{align-items:center;display:flex;gap:4px;width:100%}.uzupelnij-raport-header-cell-wrap .uzupelnij-raport-header-input{background:#334155;color:#e2e8f0;flex:1 1;font-weight:600;min-width:0}.uzupelnij-raport-header-input::placeholder{color:#94a3b8}.uzupelnij-raport-header-input:focus{background:#475569;box-shadow:inset 0 0 0 2px #3b82f6;outline:none}.uzupelnij-raport-fallback-input{background:#1e2433;border:none;box-sizing:border-box;color:#e4e8eb;font-size:14px;min-width:80px;padding:8px 10px;width:100%}.uzupelnij-raport-fallback-input:focus{background:#252d3d;box-shadow:inset 0 0 0 2px #3b82f6;outline:none}.uzupelnij-raport-cell-selected{background:#3b82f640!important}.uzupelnij-raport-cell-selected .uzupelnij-raport-fallback-input{background:#3b82f626}.uzupelnij-raport-cell-selected.uzupelnij-raport-header-cell .uzupelnij-raport-header-input{background:#3b82f633}.uzupelnij-raport-cell-selected .uzupelnij-raport-fallback-input:focus,.uzupelnij-raport-cell-selected .uzupelnij-raport-header-input:focus{background:#252d3d;box-shadow:inset 0 0 0 2px #3b82f6}.kpi-layout{display:flex;flex:1 1;flex-direction:row;min-height:0;overflow:hidden;position:relative}.app-content .kpi-layout{flex-direction:row}.kpi-sidebar{align-items:center;background:#151720;border-right:1px solid #1e2433;bottom:0;box-sizing:border-box;display:flex;flex-direction:column;left:0;overflow:hidden;padding:16px 4px;position:absolute;top:0;transition:width .25s ease;width:72px;z-index:30}.kpi-sidebar:hover{width:240px}.kpi-sidebar-nav{align-items:stretch;display:flex;flex:1 1;flex-direction:column;gap:8px;min-width:0;width:100%}.kpi-sidebar-icon-widget{color:#a78bfa!important}.kpi-sidebar-item:hover .kpi-sidebar-icon-widget{color:#c4b5fd!important}.kpi-sidebar-item.active .kpi-sidebar-icon-widget{color:#fff!important}.kpi-sidebar-icon-raport{color:#facc15!important}.kpi-sidebar-item:hover .kpi-sidebar-icon-raport{color:#fde047!important}.kpi-sidebar-item.active .kpi-sidebar-icon-raport{color:#fff!important}.kpi-sidebar-item{align-items:center;border-radius:10px;box-sizing:border-box;color:#c4c8cc;display:flex;gap:0;height:48px;justify-content:center;margin:0 2px;min-height:48px;min-width:0;padding:0;text-decoration:none;transition:color .2s ease,background .2s ease,justify-content .2s ease,gap .2s ease,padding .2s ease;width:calc(100% - 4px)}.kpi-sidebar:hover .kpi-sidebar-item{gap:12px;justify-content:flex-start;padding-left:14px}.kpi-sidebar-item:hover{background:#ffffff0f;color:#e4e8eb}.kpi-sidebar-item.active{background:#00bcd4;color:#fff}.kpi-sidebar-item.active .kpi-sidebar-icon{color:#fff}.kpi-sidebar-item:first-child.active{background:#0000;box-shadow:0 0 0 2px #00bcd4}.kpi-sidebar-item:first-child.active .kpi-sidebar-icon{color:#00bcd4}.kpi-sidebar-icon{align-items:center;color:inherit;display:flex;flex-shrink:0;height:28px;justify-content:center;min-height:28px;min-width:28px;width:28px}.kpi-sidebar-icon svg{height:100%;width:100%}.kpi-sidebar-label{flex-shrink:0;font-size:14px;font-weight:500;max-width:0;opacity:0;overflow:hidden;transition:opacity .2s ease;white-space:nowrap}.kpi-sidebar:hover .kpi-sidebar-label{max-width:200px;opacity:1}.kpi-main{background:#1a1f2e;display:flex;flex:1 1;flex-direction:column;margin-left:72px;min-height:0;min-width:0;overflow-y:auto}.kpi-main>*{flex:1 1 auto;min-height:-webkit-min-content;min-height:min-content;min-width:0}.kpi-main.kpi-main-raport>*{height:100%;min-height:0;overflow:hidden}.kpi-date-picker-wrap{display:flex;flex-direction:column;gap:4px;position:relative}.kpi-date-picker-inline{align-items:center;flex-direction:row;gap:8px}.kpi-date-picker-inline .kpi-date-picker-label{margin:0;white-space:nowrap}.kpi-date-picker-label{color:#94a3b8;font-size:.75rem;letter-spacing:.03em;text-transform:uppercase}.kpi-date-picker-trigger{align-items:center;background:#252d3d;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;display:flex;font-size:.9375rem;gap:8px;justify-content:space-between;min-width:140px;padding:8px 12px;transition:border-color .2s,background .2s}.kpi-date-picker-trigger:hover{background:#2a3345;border-color:#00bcd4}.kpi-date-picker-trigger:focus{border-color:#00bcd4;box-shadow:0 0 0 2px #00bcd440;outline:none}.kpi-date-picker-chevron{color:#94a3b8;font-size:.7rem;transition:transform .2s}.kpi-date-picker-wrap.open .kpi-date-picker-chevron{transform:rotate(180deg)}.kpi-date-picker-dropdown{background:#252d3d;border:1px solid #334155;border-radius:12px;box-shadow:0 8px 24px #0006;margin-top:6px;min-width:260px;padding:16px;position:absolute;top:100%;z-index:100}.kpi-date-picker-dropdown-right{right:0}.kpi-date-picker-dropdown-left{left:0}.kpi-date-picker-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.kpi-date-picker-nav{align-items:center;background:#1e2433;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;transition:background .2s,border-color .2s;width:32px}.kpi-date-picker-nav:hover:not(:disabled){background:#334155;border-color:#00bcd4;color:#00bcd4}.kpi-date-picker-nav:disabled{cursor:not-allowed;opacity:.4}.kpi-date-picker-month-year{color:#f1f5f9;font-size:.95rem;font-weight:600}.kpi-date-picker-weekdays{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(7,1fr);margin-bottom:12px}.kpi-date-picker-weekday{color:#94a3b8;font-size:.7rem;text-align:center}.kpi-date-picker-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(7,1fr);margin-bottom:12px}.kpi-date-picker-cell{background:#1e2433;border:1px solid #334155;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:.8rem;padding:6px;transition:background .2s,border-color .2s,color .2s}.kpi-date-picker-cell.empty{background:#0000;border:none;cursor:default}.kpi-date-picker-cell:hover:not(.disabled):not(.empty){background:#334155;border-color:#00bcd4;color:#e2e8f0}.kpi-date-picker-cell.selected{background:#00bcd4;border-color:#00bcd4;color:#1a1f2e}.kpi-date-picker-cell.disabled{cursor:not-allowed;opacity:.4}.kpi-date-picker-actions{border-top:1px solid #334155;display:flex;gap:8px;justify-content:space-between;padding-top:8px}.kpi-date-picker-action{background:#0000;border:none;color:#00bcd4;cursor:pointer;font-size:.8rem;padding:6px 12px;transition:color .2s}.kpi-date-picker-action:hover{color:#4dd0e1;text-decoration:underline}.kpi-date-picker-dashboard .kpi-date-picker-label{color:#94a3b8;font-size:.75rem;letter-spacing:.03em;text-transform:uppercase}.kpi-date-picker-dashboard .kpi-date-picker-trigger{min-width:180px}.kpi-ps-zakres-date .kpi-date-picker-trigger{font-size:.8125rem;min-width:120px;padding:6px 10px}.kpi-ps-zakres-date .kpi-date-picker-label{color:#94a3b8;font-size:.75rem}.kpi-ps-zakres .kpi-date-picker-wrap{flex-shrink:0}.kpi-dashboard{background:#1a1f2e;min-height:100%;padding:32px}.kpi-dashboard-tremor{--tremor-background:#252d3d;--tremor-background-muted:#1e2433;--tremor-border:#334155;--tremor-content:#e2e8f0;--tremor-content-muted:#94a3b8}.kpi-dashboard-tremor .kpi-dashboard-header{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;box-shadow:0 1px 3px #00000026!important;margin-bottom:24px;padding:20px 24px}.kpi-dashboard-tremor .kpi-dashboard-page-title{color:#f1f5f9!important;font-size:1.5rem;font-weight:700;margin:0 0 6px}.kpi-dashboard-tremor .kpi-dashboard-page-subtitle{color:#94a3b8;font-size:.9375rem}.kpi-dashboard-home .kpi-dashboard-home-header .kpi-dashboard-report-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:6px}.kpi-dashboard-report-title-row-with-refresh{justify-content:space-between}.kpi-dashboard-report-title-row-three{align-items:center;display:flex;gap:24px;min-height:80px;width:100%}.kpi-dashboard-report-title-left{align-items:center;display:flex;flex-shrink:0;gap:20px}.kpi-dashboard-report-title-center{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:16px;justify-content:center;min-width:0}.kpi-dashboard-report-title-center .kpi-dashboard-page-title,.kpi-dashboard-report-title-center .kpi-stat-page-title{font-size:2.5rem!important}.kpi-dashboard-home .kpi-dashboard-report-title-center .kpi-dashboard-report-date{color:#f1f5f9!important;font-size:1.5rem!important}.kpi-dashboard-report-title-right{align-items:center;display:flex;flex-shrink:0;gap:20px}.kpi-dashboard-header-logo{display:block;height:80px;max-height:80px;object-fit:contain;width:auto}.kpi-dashboard-date-picker-wrap{display:flex;flex-direction:column;gap:4px}.kpi-dashboard-date-picker-label{color:#94a3b8;font-size:.75rem;letter-spacing:.03em;text-transform:uppercase}.kpi-dashboard-date-picker{background:#252d3d;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:.9375rem;min-width:160px;padding:8px 12px}.kpi-dashboard-date-picker:focus,.kpi-dashboard-date-picker:hover{border-color:#00bcd4;outline:none}.kpi-dashboard-date-picker::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(.8)}.kpi-dashboard-home .kpi-dashboard-report-date{background:#00bcd426;border:1px solid #00bcd466;border-radius:8px;color:#00bcd4;display:inline-block;font-size:1rem;font-weight:700;padding:6px 14px}.kpi-home-card-label-wrap{align-items:center;display:inline-flex;gap:8px}.kpi-home-status-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.kpi-home-status-dot-green{background:#66bb6a}.kpi-home-status-dot-yellow{background:#ffc107}.kpi-home-status-dot-red{background:#ef5350}.kpi-home-status-dot-blue{background:#42a5f5}.kpi-home-status-dot-gray{background:#78909c}.kpi-home-card-ab-inner{align-items:flex-start;display:flex;flex-direction:row;gap:16px;justify-content:space-between;width:100%}.kpi-home-card-ab-left{display:flex;flex-direction:column;min-width:0}.kpi-home-card-ab-left .kpi-home-metric{margin:4px 0 0!important}.kpi-home-card-ab-left .kpi-home-hourly-inline{margin-top:6px}.kpi-home-card-ab-inner .kpi-home-card-ab-block{flex-shrink:0}.kpi-home-card-ab-block{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:2px}.kpi-home-card-ab-glass{background:#ffffff1a;border:1px solid #ffffff14;border-radius:10px;padding:8px 14px}.kpi-home-card-ab-line{color:#e2e8f0;font-size:1rem;font-weight:600}.kpi-home-hourly-inline,.kpi-home-shift-inline{color:#94a3b8;font-size:.875rem;margin-top:8px}.kpi-home-hourly-inline{margin-top:6px}.kpi-home-badge-days{background:#66bb6a26;border:1px solid #66bb6a73;margin-top:8px;min-width:140px;padding:12px 16px;text-align:center}.kpi-home-badge-days .kpi-home-badge-label{color:#94a3b8;display:block;font-size:.75rem;letter-spacing:.04em;margin:0 0 4px;text-transform:uppercase}.kpi-home-badge-days-value{color:#66bb6a;display:block;font-size:1.75rem;font-weight:800;line-height:1.2;text-align:center}.kpi-home-cards{grid-gap:16px;display:grid!important;gap:16px;grid-template-columns:repeat(6,minmax(0,1fr));margin-bottom:24px}@media (max-width:1200px){.kpi-home-cards{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width:768px){.kpi-home-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:640px){.kpi-home-cards{grid-template-columns:1fr}}.kpi-home-card{background:#1e2433!important;border:1px solid #334155!important;border-left:4px solid #334155;border-radius:12px!important;box-shadow:0 2px 8px #00000026;overflow:hidden;padding:16px 20px!important;position:relative;transition:transform .2s,box-shadow .2s}.kpi-home-card-glass:before{border-radius:11px;content:"";inset:0;pointer-events:none;position:absolute;z-index:0}.kpi-home-card-glass>*{position:relative;z-index:1}.kpi-home-card-glass-green:before{background:#22c55e1f}.kpi-home-card-glass-yellow:before{background:#eab3081f}.kpi-home-card-glass-red:before{background:#ef44441f}.kpi-home-card:hover{box-shadow:0 4px 16px #00000040;transform:translateY(-2px)}.kpi-home-card-bhp{border-left-color:#78909c}.kpi-home-card-bhp-inner{align-items:flex-start;display:flex;flex-direction:row;gap:16px;justify-content:space-between;width:100%}.kpi-home-card-bhp-left{display:flex;flex-direction:column;min-width:0}.kpi-home-card-bhp-left .kpi-home-metric{margin:4px 0 0!important}.kpi-home-card-bhp .kpi-home-badge-days{flex-shrink:0;margin-top:0}.kpi-home-card-pick{border-left-color:#00bcd4}.kpi-home-card-oww{border-left-color:#ff9800}.kpi-home-card-transport{border-left-color:#26a69a}.kpi-home-card-ps{border-left-color:#42a5f5}.kpi-home-card-ps-inner{align-items:flex-start;display:flex;flex-direction:row;gap:16px;justify-content:space-between;width:100%}.kpi-home-card-ps-left{display:flex;flex-direction:column;min-width:0}.kpi-home-card-ps-left .kpi-home-metric{margin:4px 0 0!important}.kpi-home-card-ps .kpi-home-badge-days{flex-shrink:0;margin-top:0}.kpi-home-card-inbound{border-left-color:#9c27b0}.kpi-home-card-powyzej24h{border-left-color:#e65100}.kpi-home-card-najstarszy{border-left-color:#5c6bc0}.kpi-home-card-top5-najstarszych{border-left-color:#7986cb}.kpi-home-card-top5-najstarszych.kpi-home-card-span-2{grid-column:span 2}.kpi-home-card-top5-najstarszych .kpi-home-card-label{color:#f1f5f9!important;font-weight:800;text-shadow:0 0 1px #00000080}.kpi-home-top5-table-wrap{max-height:140px;overflow-y:auto}.kpi-home-top5-table-wrap table{color:#f1f5f9;font-size:.9375rem}.kpi-home-top5-table-wrap td,.kpi-home-top5-table-wrap th{border-color:#94a3b866;color:#f1f5f9!important;font-weight:500;padding:8px 10px}.kpi-home-top5-table-wrap th{background:#33415599;color:#f8fafc!important;font-size:.8125rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.kpi-home-top5-table-wrap tbody td{color:#e2e8f0!important;font-weight:500}.kpi-home-top5-table-wrap tbody tr:hover td{background:#7886cb1f;color:#f8fafc!important}.kpi-home-card-label{color:#e2e8f0!important;font-size:1.0625rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase}.kpi-home-metric{color:#f1f5f9!important;margin:4px 0 6px!important}.kpi-home-cards .kpi-home-metric,.kpi-home-metric{font-size:2rem!important;font-weight:700!important}.kpi-home-badge{background:#78909c33;border:1px solid #78909c66;border-radius:8px;display:inline-flex;flex-direction:column;gap:2px;padding:10px 14px}.kpi-home-badge-label{color:#e2e8f0;font-size:.875rem;text-transform:uppercase}.kpi-home-badge-value{color:#e2e8f0;font-size:1.25rem;font-weight:700}.kpi-home-hourly-block,.kpi-home-shift-block{border-top:1px solid #33415599;margin-top:12px;padding-top:10px}.kpi-home-hourly-block{margin-top:8px;padding-top:8px}.kpi-home-shift-row{align-items:center;display:flex;font-size:.875rem;gap:12px;justify-content:space-between;padding:4px 0}.kpi-home-shift-label{color:#94a3b8;flex-shrink:0}.kpi-home-shift-value{color:#e2e8f0;font-weight:600;text-align:right}.kpi-home-transport-total{color:#94a3b8;font-size:.875rem;margin:8px 0 12px;padding:8px 0}.kpi-home-transport-total .kpi-home-shift-value{display:inline}.kpi-home-ps-sztuki{color:#c4c8cc;font-size:.9375rem;margin-top:6px}.kpi-home-card-ps .kpi-home-metric,.kpi-home-card-transport .kpi-home-metric{margin:4px 0 0!important}.kpi-home-card-transport .kpi-home-shift-inline{margin-top:6px}.kpi-home-errors-card{background:#1e2433!important;border:1px solid #334155!important;border-radius:12px!important;box-shadow:0 2px 8px #00000026;margin-top:8px;padding:24px!important}.kpi-home-charts-row{gap:20px;margin-bottom:24px}.kpi-home-chart-card{background:#1e2433!important;border:1px solid #334155!important;border-radius:12px!important;padding:20px!important}.kpi-home-chart-title{color:#e2e8f0!important;font-size:1rem!important;margin:0 0 12px!important}.kpi-home-chart-card .recharts-legend-item-text{fill:#e2e8f0!important;font-size:12px}.kpi-home-chart-card .recharts-legend-wrapper{padding-top:12px}.kpi-home-insights-row{grid-gap:20px;align-items:stretch;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:24px}@media (max-width:768px){.kpi-home-insights-row{grid-template-columns:1fr}}.kpi-home-inbound-chart-card,.kpi-home-oww-chart-card{min-width:0}.kpi-home-insights-card{background:#1e2433!important;border:1px solid #334155!important;border-radius:12px!important;margin-bottom:24px;padding:20px 24px!important}.kpi-home-insights-title{color:#e2e8f0!important;font-size:1.125rem!important;margin:0 0 12px!important}.kpi-home-insights-list{color:#e2e8f0;font-size:.9375rem;list-style:none;margin:0;padding:0}.kpi-home-insights-list li{border-bottom:1px solid #33415580;padding:4px 0}.kpi-home-insights-list li:last-child{border-bottom:none}.kpi-home-insights-list strong{color:#00bcd4}.kpi-home-insights-empty{color:#94a3b8;font-style:italic}.kpi-home-table-empty-state{background:#252d3d;border:1px dashed #334155;border-radius:8px;padding:24px;text-align:center}.kpi-home-table-empty-msg{color:#94a3b8;display:block;margin-bottom:12px}.kpi-home-top3-psa{background:#1e2433;border:1px solid #334155;border-radius:8px;margin:0 auto 16px;max-width:280px;padding:12px 16px;text-align:left}.kpi-home-top3-title{color:#94a3b8;font-size:.8125rem;margin:0 0 8px}.kpi-home-top3-psa ul{color:#e2e8f0;font-size:.875rem;list-style:none;margin:0;padding:0}.kpi-home-top3-psa li{padding:2px 0}.kpi-home-errors-title{color:#e2e8f0!important;font-size:1.125rem!important;margin:0 0 16px!important}.kpi-home-table-wrap{border:1px solid #334155;border-radius:8px;overflow-x:auto}.kpi-home-table{font-size:.875rem}.kpi-home-table td,.kpi-home-table th{border-bottom:1px solid #334155;color:#e2e8f0;padding:10px 14px}.kpi-home-table th{background:#252d3d;color:#94a3b8;font-weight:600}.kpi-home-table-empty{color:#94a3b8!important;font-style:italic;padding:24px!important;text-align:center}.kpi-dashboard-report-header .kpi-dashboard-report-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:6px}.kpi-dashboard-report-header .kpi-dashboard-report-date{background:#00bcd426;border:1px solid #00bcd466;border-radius:8px;color:#00bcd4;display:inline-block;font-size:1rem;font-weight:700;padding:6px 14px}.kpi-dashboard-tremor .kpi-dashboard-cards{gap:20px;margin-bottom:24px}.kpi-dashboard-tremor .kpi-dashboard-cards-lastday{margin-top:0}.kpi-dashboard-tremor .kpi-dashboard-lastday-card{background:#1e2433!important;border:1px solid #334155!important;border-left:4px solid #334155;border-radius:12px!important;box-shadow:0 1px 3px #0000001f;min-height:160px;padding:20px!important;transition:border-color .2s,box-shadow .2s}.kpi-dashboard-tremor .kpi-dashboard-lastday-card:hover{border-color:#475569!important;box-shadow:0 2px 8px #0003}.kpi-dashboard-tremor .kpi-dashboard-cards-lastday .kpi-dashboard-lastday-card:first-child{border-left-color:#78909c}.kpi-dashboard-tremor .kpi-dashboard-cards-lastday .kpi-dashboard-lastday-card:nth-child(2){border-left-color:#42a5f5}.kpi-dashboard-tremor .kpi-dashboard-cards-lastday .kpi-dashboard-lastday-card:nth-child(3){border-left-color:#00bcd4}.kpi-dashboard-tremor .kpi-dashboard-cards-lastday .kpi-dashboard-lastday-card:nth-child(4){border-left-color:#26a69a}.kpi-dashboard-tremor .kpi-dashboard-cards-lastday .kpi-dashboard-lastday-card:nth-child(5){border-left-color:#ff9800}.kpi-dashboard-tremor .kpi-dashboard-detail-link{background:#00bcd4;border:1px solid #00bcd480;border-radius:8px;box-shadow:0 1px 2px #0003;color:#fff;display:inline-block;font-size:.8125rem;font-weight:600;padding:6px 14px;text-decoration:none;transition:background .2s,color .2s,box-shadow .2s}.kpi-dashboard-tremor .kpi-dashboard-detail-link:hover{background:#00acc1;box-shadow:0 2px 4px #00000040;color:#fff;text-decoration:none}.kpi-dashboard-tremor .kpi-dashboard-oww-metrics,.kpi-dashboard-tremor .kpi-dashboard-transport-metrics{display:flex;flex-direction:column;gap:10px;margin-top:12px}.kpi-dashboard-tremor .kpi-dashboard-transport-row{align-items:center;border-bottom:1px solid #33415599;display:flex;flex-wrap:wrap;gap:12px;padding:6px 0}.kpi-dashboard-tremor .kpi-dashboard-transport-row:last-child{border-bottom:none}.kpi-dashboard-tremor .kpi-dashboard-transport-label{color:#94a3b8;font-size:.8125rem;min-width:110px}.kpi-dashboard-tremor .kpi-dashboard-transport-value{color:#f1f5f9;font-size:1.125rem;font-weight:700}.kpi-dashboard-tremor .kpi-dashboard-dod{font-size:.8125rem;font-weight:600;margin-left:auto}.kpi-dashboard-tremor .kpi-dashboard-error,.kpi-dashboard-tremor .kpi-dashboard-no-data{background:#252d3d;border:1px solid #334155;border-radius:10px;color:#94a3b8;font-size:.9375rem;margin-top:20px;padding:16px 20px}.kpi-dashboard-tremor .kpi-dashboard-error{background:#ef535014;border-color:#ef535059;color:#fca5a5}.kpi-dashboard-tremor .kpi-tremor-card{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px;padding:20px}.kpi-dashboard-tremor .kpi-tremor-label{color:#94a3b8!important;font-size:.8125rem}.kpi-dashboard-tremor .kpi-dashboard-lastday-card .kpi-tremor-label{color:#e2e8f0!important;font-size:.875rem;font-weight:600}.kpi-dashboard-tremor .kpi-tremor-metric{color:#f1f5f9!important;font-size:1.75rem;margin-top:4px}.kpi-dashboard-tremor .kpi-dashboard-lastday-card .kpi-tremor-metric{color:#f1f5f9!important;font-size:2rem;font-weight:700;margin-top:8px}.kpi-dashboard-tremor .kpi-tremor-delta{color:#94a3b8;font-size:.8125rem;margin-top:8px}.kpi-dashboard-tremor .kpi-dashboard-lastday-card .kpi-tremor-delta{font-size:.875rem;margin-top:6px}.kpi-dashboard-tremor .kpi-delta-up{color:#66bb6a!important}.kpi-dashboard-tremor .kpi-delta-down{color:#ef5350!important}.kpi-dashboard-tremor .kpi-spark{height:48px;margin-top:12px}.kpi-dashboard-tremor .kpi-progress-wrap{margin:12px 0}.kpi-dashboard-tremor .kpi-progress-circle{--tw-text-opacity:1}.kpi-dashboard-tremor .kpi-dashboard-charts{gap:16px;margin-bottom:24px}.kpi-dashboard-tremor .kpi-chart-card{min-height:280px}.kpi-dashboard-tremor .kpi-chart-title{color:#e2e8f0!important;font-size:1rem;margin-bottom:16px}.kpi-dashboard-tremor .kpi-area-chart,.kpi-dashboard-tremor .kpi-bar-chart,.kpi-dashboard-tremor .kpi-donut-chart{height:220px}.kpi-dashboard-tremor .kpi-bar-full{max-width:100%}.kpi-dashboard-tremor .kpi-area-chart .recharts-area,.kpi-dashboard-tremor .kpi-area-chart .recharts-line{stroke-width:2}.kpi-dashboard-tremor .kpi-area-chart .recharts-area:first-of-type,.kpi-dashboard-tremor .kpi-area-chart .recharts-line:first-of-type{stroke:#00bcd4!important}.kpi-dashboard-tremor .kpi-area-chart .recharts-area:nth-of-type(2),.kpi-dashboard-tremor .kpi-area-chart .recharts-line:nth-of-type(2){stroke:#26a69a!important}.kpi-dashboard-tremor .kpi-area-chart linearGradient stop{stop-opacity:.5}.kpi-dashboard-tremor .kpi-area-chart linearGradient:first-of-type stop{stop-color:#00bcd4}.kpi-dashboard-tremor .kpi-area-chart linearGradient:nth-of-type(2) stop{stop-color:#26a69a}.kpi-dashboard-tremor .kpi-bar-chart .recharts-bar-rectangle{fill:#42a5f5!important}.kpi-dashboard-tremor .kpi-bar-chart .recharts-bar-rectangle:hover{fill:#5eb8ff!important}.kpi-dashboard-tremor .kpi-donut-chart .recharts-pie-sector:first-of-type{fill:#00bcd4!important;stroke:#1a1f2e;stroke-width:2}.kpi-dashboard-tremor .kpi-donut-chart .recharts-pie-sector:nth-of-type(2){fill:#26a69a!important;stroke:#1a1f2e;stroke-width:2}.kpi-dashboard-tremor .kpi-donut-chart .recharts-pie-sector:nth-of-type(3){fill:#ffa726!important;stroke:#1a1f2e;stroke-width:2}.kpi-dashboard-tremor .kpi-spark .recharts-area{fill:#00bcd466!important;stroke:#00bcd4!important}.kpi-dashboard-tremor .kpi-dashboard-cards .kpi-tremor-card:nth-child(2) .kpi-spark .recharts-area{fill:#26a69a66!important;stroke:#26a69a!important}.kpi-dashboard-tremor .kpi-progress-circle svg circle[stroke]{stroke:#00bcd4!important}.kpi-dashboard-tremor .recharts-cartesian-grid line{stroke:#475569!important;stroke-opacity:.6}.kpi-dashboard-tremor .recharts-xAxis .recharts-text,.kpi-dashboard-tremor .recharts-yAxis .recharts-text{fill:#94a3b8!important;font-size:12px}.kpi-dashboard-tremor .recharts-legend-item-text{fill:#e2e8f0!important}.kpi-dashboard-tremor .recharts-legend-item .recharts-surface{overflow:visible}.kpi-dashboard-tremor .recharts-legend-item path{fill:#00bcd4!important}.kpi-dashboard-tremor .recharts-legend-item:nth-child(2) path{fill:#26a69a!important}.kpi-dashboard-tremor .recharts-legend-item:nth-child(3) path{fill:#ffa726!important}.kpi-dashboard-card{background:#252d3d;border:1px solid #334155;border-radius:12px;box-shadow:0 4px 24px #0000004d;margin:0 auto;max-width:560px;padding:48px;text-align:center}.kpi-dashboard-title{color:#f1f5f9;font-size:32px;font-weight:700;margin:0 0 16px}.kpi-dashboard-description{color:#94a3b8;font-size:16px;line-height:1.6;margin:0 0 32px}.kpi-dashboard-btn{background:#00bcd4;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 28px;transition:background .2s,transform .2s}.kpi-dashboard-btn:hover{background:#00acc1;transform:translateY(-1px)}.kpi-dashboard-charts-section{margin-top:32px;padding-top:24px}.kpi-dashboard-charts-grid{gap:24px;margin-bottom:24px}.kpi-dashboard-chart-card{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;box-shadow:0 1px 3px #0000001f;padding:24px!important}.kpi-dashboard-chart-card:focus,.kpi-dashboard-chart-card:focus-visible,.kpi-dashboard-summary-bar-wrap:focus,.kpi-dashboard-summary-bar-wrap:focus-visible{box-shadow:0 1px 3px #0000001f!important;outline:none!important}.kpi-dashboard-chart-card :focus,.kpi-dashboard-chart-card :focus-visible{outline:none!important}.kpi-dashboard-chart-card .recharts-surface,.kpi-dashboard-chart-card .recharts-wrapper{overflow:visible!important}.kpi-dashboard-chart-card .recharts-pie-label-text{fill:#e2e8f0;font-size:12px;font-weight:500}.kpi-dashboard-donut-wrap{height:360px;position:relative;width:100%}.kpi-dashboard-donut-wrap .recharts-wrapper{filter:drop-shadow(0 4px 12px rgba(0,0,0,.25))}.kpi-dashboard-donut-center{align-items:center;bottom:0;display:flex;flex-direction:column;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;text-align:center;top:0}.kpi-dashboard-donut-center-title{color:#e2e8f0;font-size:1rem;font-weight:700;line-height:1.25;white-space:nowrap}.kpi-dashboard-donut-center-sub{color:#94a3b8;font-size:.75rem;line-height:1.2;margin-top:6px}.kpi-dashboard-chart-card .recharts-legend-wrapper{padding-top:12px!important}.kpi-dashboard-chart-card .recharts-default-legend{align-items:flex-start!important;display:flex!important;flex-direction:column!important;gap:6px!important;padding:0!important}.kpi-dashboard-chart-card .recharts-legend-item{align-items:center!important;display:inline-flex!important;gap:8px!important;margin:0!important}.kpi-dashboard-chart-card .recharts-legend-item-text{color:#e2e8f0!important;font-size:13px!important;font-weight:500!important}.kpi-dashboard-chart-title{color:#e2e8f0!important;font-size:1.125rem!important;font-weight:600!important;margin:0 0 16px!important}.kpi-dashboard-chart-empty{color:#94a3b8;font-size:.875rem;padding:32px 16px;text-align:center}.kpi-dashboard-chart-print-summary{background:#1e2433;border:1px solid #334155;border-radius:8px;color:#e2e8f0;display:flex;flex-wrap:wrap;font-size:.9375rem;gap:12px 24px;margin-top:12px;padding:12px 16px}.kpi-dashboard-chart-print-item{font-weight:600;white-space:nowrap}.kpi-dashboard-summary-bar-wrap{margin-bottom:24px}.kpi-dashboard-report-footer{background:#1e2433;border:1px solid #334155;border-radius:10px;margin-top:24px;padding:16px 20px;text-align:center}.kpi-dashboard-report-footer-text{color:#94a3b8!important;font-size:.8125rem;margin:0}.kpi-report-toolbar{align-items:center;background:#252d3d;border:1px solid #334155;border-radius:12px;display:flex;flex-wrap:wrap;gap:16px 24px;margin-bottom:20px;padding:14px 20px}.kpi-report-toolbar-group{align-items:center;display:flex;gap:10px}.kpi-report-toolbar-label{color:#94a3b8;font-size:.875rem;margin-right:4px}.kpi-report-toolbar-btn{background:#1e2433;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;font-size:.875rem;font-weight:600;padding:8px 16px;transition:background .2s,border-color .2s}.kpi-report-toolbar-btn:hover{background:#334155;border-color:#475569}.kpi-report-toolbar-btn.active{background:#00bcd4;border-color:#00bcd480;color:#fff}.kpi-report-toolbar-btn-primary{background:#0ea5e9;border-color:#0ea5e980;color:#fff}.kpi-report-toolbar-btn-primary:hover{background:#0284c7}.kpi-report-toolbar-icon{align-items:center;display:inline-flex;justify-content:center;margin-right:8px;vertical-align:middle}.kpi-report-toolbar-icon svg{display:block}.kpi-report-print-area{background:#1a1f2e;border-radius:12px;padding:24px 0}.kpi-report-print-area-landscape{max-width:100%}.kpi-report-events-section{background:#1e2433;border:1px solid #334155;border-radius:12px;margin-top:28px;padding:20px 24px}.kpi-report-events-title{color:#e2e8f0!important;font-size:1.125rem!important;font-weight:600!important;margin:0 0 16px!important}.kpi-report-events-table-wrap{overflow-x:auto}.kpi-report-events-table{border-collapse:collapse;font-size:.9375rem;width:100%}.kpi-report-events-table td,.kpi-report-events-table th{border-bottom:1px solid #334155;padding:12px 16px;text-align:left}.kpi-report-events-table th{color:#94a3b8;font-weight:600}.kpi-report-events-table td{color:#f1f5f9}.kpi-report-events-table td:last-child{font-weight:600;white-space:nowrap}.kpi-report-events-table tbody tr:last-child td{border-bottom:none}@media print{.kpi-sidebar,.kpi-sidebar *,.no-print{display:none!important}.kpi-main{margin:0!important;padding:0!important}.kpi-report-print-area{background:#1a1f2e!important;padding:16px!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.kpi-dashboard-report .kpi-dashboard-header,.kpi-dashboard-report .kpi-dashboard-lastday-card,.kpi-dashboard-report-footer,.kpi-report-events-section{break-inside:avoid;page-break-inside:avoid;-webkit-print-color-adjust:exact;print-color-adjust:exact}.kpi-dashboard-report .kpi-dashboard-detail-link{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.kpi-podsumowanie-card-clickable{cursor:pointer!important}.kpi-podsumowanie-chart-panel{animation:kpi-podsumowanie-panelIn .25s ease-out;background:#1e2433;border:1px solid #334155;border-radius:12px;box-shadow:0 4px 24px #0003;margin-top:24px;overflow:hidden;width:100%}@keyframes kpi-podsumowanie-panelIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.kpi-podsumowanie-chart-panel-header{align-items:center;border-bottom:1px solid #334155;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px}.kpi-podsumowanie-chart-panel-title{color:#f1f5f9!important;font-size:1.25rem!important;margin:0!important}.kpi-podsumowanie-chart-panel-close{align-items:center;background:#0000;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;font-size:1.25rem;height:36px;justify-content:center;transition:background .2s,color .2s;width:36px}.kpi-podsumowanie-chart-panel-close:hover{background:#334155;color:#e2e8f0}.kpi-podsumowanie-chart-panel-body{padding:24px}.kpi-podsumowanie-chart-panel-card{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;padding:20px!important}.kpi-podsumowanie-chart-panel-label{color:#94a3b8;display:block;font-size:.875rem;margin-bottom:16px}.kpi-podsumowanie-ps-charts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-top:24px}@media (max-width:768px){.kpi-podsumowanie-ps-charts-grid{grid-template-columns:1fr}}.kpi-podsumowanie-ps-mini-chart-card{background:linear-gradient(145deg,#252d3d,#1e2433)!important;border:1px solid #334155!important;border-radius:12px!important;overflow:hidden;padding:20px!important}.kpi-podsumowanie-ps-mini-chart-card:hover{border-color:#42a5f566!important;box-shadow:0 0 20px #42a5f514}.kpi-podsumowanie-ps-mini-chart-title{color:#e2e8f0;display:block;font-size:.9375rem;font-weight:700;letter-spacing:.04em;margin-bottom:16px;text-transform:uppercase}.kpi-podsumowanie-ps-mini-chart-card .recharts-yAxis .recharts-text{fill:#e2e8f0!important;font-size:12px!important;font-weight:500!important}.kpi-podsumowanie-ps-mini-chart-card .recharts-cartesian-axis-tick-value{dominant-baseline:middle}.kpi-zmagazynowane-chart-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:16px}.kpi-zmagazynowane-view-tabs{display:flex;gap:4px}.kpi-zmagazynowane-view-tab{background:#33415580;border:1px solid #334155;border-radius:8px;color:#94a3b8;cursor:pointer;font-size:.8125rem;font-weight:600;padding:8px 14px;transition:background .2s,color .2s,border-color .2s}.kpi-zmagazynowane-view-tab:hover{background:#334155cc;color:#e2e8f0}.kpi-zmagazynowane-view-tab.active{background:#9c27b040;border-color:#9c27b0;color:#e2e8f0}.kpi-zmagazynowane-dwa-charts{display:flex;flex-direction:column;gap:20px}.kpi-osobne-magazyny-charts{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.kpi-zmagazynowane-dwa-chart{background:#1e293b66;border:1px solid #334155;border-radius:8px;padding:12px}.kpi-zmagazynowane-dwa-title{color:#94a3b8;display:block;font-size:.875rem;font-weight:600;margin-bottom:8px}.kpi-podsumowanie-ps-errors-card{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;margin-top:24px;padding:24px!important}.kpi-podsumowanie-ps-errors-title{color:#e2e8f0!important;font-size:1.125rem!important;margin:0 0 16px!important}.kpi-podsumowanie-ps-table-wrap{border:1px solid #334155;border-radius:8px;max-height:320px;overflow-x:auto;overflow-y:auto}.kpi-podsumowanie-ps-table{font-size:.875rem}.kpi-podsumowanie-ps-table td,.kpi-podsumowanie-ps-table th{border-color:#33415599;color:#e2e8f0!important;padding:10px 12px}.kpi-podsumowanie-ps-table th{background:#33415580;font-weight:600}.react-grid-layout{position:relative;transition:height .2s ease}.react-grid-item{transition:all .2s ease;transition-property:left,top,width,height}.react-grid-item img{pointer-events:none;-webkit-user-select:none;user-select:none}.react-grid-item.cssTransforms{transition-property:transform,width,height}.react-grid-item.resizing{transition:none;will-change:width,height;z-index:1}.react-grid-item.react-draggable-dragging{transition:none;will-change:transform;z-index:3}.react-grid-item.dropping{visibility:hidden}.react-grid-item.react-grid-placeholder{background:red;opacity:.2;transition-duration:.1s;-webkit-user-select:none;user-select:none;z-index:2}.react-grid-item.react-grid-placeholder.placeholder-resizing{transition:none}.react-grid-item>.react-resizable-handle{height:20px;opacity:0;position:absolute;width:20px}.react-grid-item:hover>.react-resizable-handle{opacity:1}.react-grid-item>.react-resizable-handle:after{border-bottom:2px solid #0006;border-right:2px solid #0006;bottom:3px;content:"";height:5px;position:absolute;right:3px;width:5px}.react-resizable-hide>.react-resizable-handle{display:none}.react-grid-item>.react-resizable-handle.react-resizable-handle-sw{bottom:0;cursor:sw-resize;left:0;transform:rotate(90deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-se{bottom:0;cursor:se-resize;right:0}.react-grid-item>.react-resizable-handle.react-resizable-handle-nw{cursor:nw-resize;left:0;top:0;transform:rotate(180deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-ne{cursor:ne-resize;right:0;top:0;transform:rotate(270deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e,.react-grid-item>.react-resizable-handle.react-resizable-handle-w{cursor:ew-resize;margin-top:-10px;top:50%}.react-grid-item>.react-resizable-handle.react-resizable-handle-w{left:0;transform:rotate(135deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-e{right:0;transform:rotate(315deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-n,.react-grid-item>.react-resizable-handle.react-resizable-handle-s{cursor:ns-resize;left:50%;margin-left:-10px}.react-grid-item>.react-resizable-handle.react-resizable-handle-n{top:0;transform:rotate(225deg)}.react-grid-item>.react-resizable-handle.react-resizable-handle-s{bottom:0;transform:rotate(45deg)}.kpi-widget-page{background:#1a1f2e;min-height:100%;padding:24px 32px}.kpi-widget-header{align-items:center;background:#252d3d;border:1px solid #334155;border-radius:12px;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px;padding:16px 20px}.kpi-widget-header .kpi-widget-date{color:#94a3b8;font-size:.875rem;margin-top:4px}.kpi-widget-header-date-row{margin-top:6px}.kpi-widget-date-picker-label{align-items:center;display:flex;gap:8px}.kpi-widget-date-picker-text{color:#94a3b8;font-size:.8125rem}.kpi-widget-date-picker{background:#252d3d;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:.875rem;padding:6px 10px}.kpi-widget-date-picker:focus,.kpi-widget-date-picker:hover{border-color:#00bcd4;outline:none}.kpi-widget-toolbar{align-items:center;display:flex;gap:12px}.kpi-widget-add-wrap{position:relative}.kpi-widget-add-dropdown{background:#1e2433;border:1px solid #334155;border-radius:8px;box-shadow:0 4px 12px #0006;left:0;margin-top:8px;min-width:220px;padding:8px 0;position:absolute;top:100%;z-index:100}.kpi-widget-add-item{align-items:center;background:#0000;border:none;color:#e2e8f0;cursor:pointer;display:flex;font-size:.9375rem;gap:12px;padding:10px 16px;text-align:left;transition:background .15s;width:100%}.kpi-widget-add-item:hover{background:#33415599}.kpi-widget-add-icon{font-size:1.25rem}.kpi-widget-grid{min-height:400px}.kpi-widget-grid .react-grid-item{transition:all .2s ease}.kpi-widget-grid .react-grid-item.react-draggable-dragging{transition:none;z-index:100}.kpi-widget-grid .react-resize-handle{background:linear-gradient(135deg,#0000 50%,#475569 0);bottom:2px;cursor:se-resize;height:12px;position:absolute;right:2px;width:12px}.kpi-widget-card{display:flex;flex-direction:column;height:100%;overflow:hidden;padding:12px 14px!important}.kpi-widget-card-header{align-items:center;display:flex;flex-shrink:0;gap:8px;justify-content:space-between;margin-bottom:10px}.kpi-widget-card-title{color:#f1f5f9!important;font-size:.9375rem!important;margin:0!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kpi-widget-card-actions{align-items:center;display:flex;gap:4px}.kpi-widget-btn-icon{align-items:center;background:#33415599;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;font-size:14px;height:28px;justify-content:center;padding:0;transition:background .15s,color .15s;width:28px}.kpi-widget-btn-icon:hover{background:#475569cc;color:#e2e8f0}.kpi-widget-btn-remove:hover{background:#ef44444d!important;color:#f87171!important}.kpi-widget-card-body{flex:1 1;min-height:0;overflow:auto}.kpi-widget-config{background:#1e243399;border:1px solid #334155;border-radius:8px;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:10px;padding:12px}.kpi-widget-config label{color:#94a3b8;display:flex;flex-direction:column;font-size:.75rem;gap:4px;letter-spacing:.05em;text-transform:uppercase}.kpi-widget-config-input{background:#1e2433;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:.875rem;min-width:140px;padding:6px 10px}.kpi-widget-config-color{height:28px;padding:2px;width:36px}.kpi-widget-config-color,.kpi-widget-config-select{background:#1e2433;border:1px solid #334155;border-radius:6px;cursor:pointer}.kpi-widget-config-select{color:#e2e8f0;font-size:.875rem;min-width:140px;padding:6px 10px}.kpi-widget-metric-body{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:80px;padding:16px}.kpi-widget-metric-value{color:#f1f5f9!important;font-size:2rem!important;margin-bottom:4px!important}.kpi-widget-metric-label{color:#94a3b8;font-size:.8125rem}.kpi-widget-table-wrap{max-height:200px;overflow:auto}.kpi-widget-table-wrap table{font-size:.8125rem}.kpi-widget-empty{color:#94a3b8;font-style:italic;padding:16px!important;text-align:center}.kpi-widget-combo{display:flex;flex-direction:column;gap:12px;height:100%}.kpi-widget-combo-metric{flex-shrink:0}.kpi-widget-combo-metric .kpi-tremor-Metric{color:#f1f5f9!important;font-size:1.5rem!important}.kpi-widget-combo-chart{flex:1 1;min-height:60px}.kpi-widget-empty-state{background:#252d3d;border:1px dashed #334155;border-radius:12px;color:#94a3b8;padding:48px 24px;text-align:center}.kpi-widget-error{color:#f87171!important}.kpi-widget-page .kpi-tremor-Title{color:#f1f5f9!important}.kpi-widget-page .kpi-tremor-Text{color:#94a3b8}.kpi-stat-page{background:#1a1f2e;min-height:100%;padding:32px}.kpi-stat-page-header{margin-bottom:24px}.kpi-stat-page-title{color:#f1f5f9;font-size:1.5rem;font-weight:700;margin:0 0 4px}.kpi-stat-page-subtitle{color:#94a3b8;font-size:.875rem;margin:0}.kpi-month-picker-wrap{display:flex;flex-direction:column;gap:4px;position:relative}.kpi-month-picker-trigger{align-items:center;background:#252d3d;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;display:flex;font-size:.9375rem;gap:8px;justify-content:space-between;min-width:180px;padding:8px 12px;transition:border-color .2s,background .2s}.kpi-month-picker-trigger:hover{background:#2a3345;border-color:#00bcd4}.kpi-month-picker-chevron{color:#94a3b8;font-size:.7rem;transition:transform .2s}.kpi-month-picker-wrap.open .kpi-month-picker-chevron{transform:rotate(180deg)}.kpi-month-picker-dropdown{background:#252d3d;border:1px solid #334155;border-radius:12px;box-shadow:0 8px 24px #0006;margin-top:6px;min-width:220px;padding:16px;position:absolute;right:0;top:100%;z-index:100}.kpi-month-picker-year-row{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.kpi-month-picker-nav{align-items:center;background:#1e2433;border:1px solid #334155;border-radius:8px;color:#e2e8f0;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;transition:background .2s,border-color .2s;width:32px}.kpi-month-picker-nav:hover{background:#334155;border-color:#00bcd4;color:#00bcd4}.kpi-month-picker-year{color:#f1f5f9;font-size:1rem;font-weight:600}.kpi-month-picker-grid{grid-gap:6px;display:grid;gap:6px;grid-template-columns:repeat(4,1fr);margin-bottom:12px}.kpi-month-picker-cell{background:#1e2433;border:1px solid #334155;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:.8rem;padding:8px 6px;transition:background .2s,border-color .2s,color .2s}.kpi-month-picker-cell:hover:not(.disabled){background:#334155;border-color:#00bcd4;color:#e2e8f0}.kpi-month-picker-cell.selected{background:#00bcd4;border-color:#00bcd4;color:#1a1f2e}.kpi-month-picker-cell.disabled{cursor:not-allowed;opacity:.4}.kpi-month-picker-actions{border-top:1px solid #334155;display:flex;gap:8px;justify-content:space-between;padding-top:8px}.kpi-month-picker-action{background:#0000;border:none;color:#00bcd4;cursor:pointer;font-size:.8rem;padding:6px 12px;transition:color .2s}.kpi-month-picker-action:hover{color:#4dd0e1;text-decoration:underline}.kpi-podsumowanie-cards{grid-template-columns:repeat(8,minmax(0,1fr))!important}@media (max-width:1200px){.kpi-podsumowanie-cards{grid-template-columns:repeat(3,minmax(0,1fr))!important}}@media (max-width:768px){.kpi-podsumowanie-cards{grid-template-columns:repeat(2,minmax(0,1fr))!important}}@media (max-width:640px){.kpi-podsumowanie-cards{grid-template-columns:1fr!important}}.kpi-stat-page-content{background:#252d3d;border:1px solid #334155;border-radius:12px;padding:24px}.kpi-stat-page-controls{display:flex;flex-direction:column;gap:16px}.kpi-period-switch{background:#1e2433;border:1px solid #334155;border-radius:10px!important;box-shadow:inset 0 1px 2px #0003;display:inline-flex;gap:0;padding:4px}.kpi-period-switch-btn{background:#0000;border:none;border-radius:8px!important;color:#94a3b8;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:color .2s,background .2s}.kpi-period-switch-btn:hover{color:#e2e8f0}.kpi-period-switch-btn-active{background:#00bcd4;box-shadow:0 1px 3px #0003;color:#fff}.kpi-period-switch-btn-active:hover{background:#00acc1;color:#fff}.kpi-ps-day-picker{align-items:center;display:flex;gap:12px;margin-top:12px}.kpi-ps-day-picker-label{color:#94a3b8;font-size:.875rem}.kpi-ps-day-picker-input{background:#1e2433;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:.875rem;padding:8px 12px}.kpi-ps-day-picker-input:focus{border-color:#00bcd4;box-shadow:0 0 0 2px #00bcd433;outline:none}.kpi-ps-header-bar{align-items:center;background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;box-shadow:0 1px 3px #00000026!important;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px;padding:16px 20px}.kpi-ps-header-title{color:#f1f5f9!important;font-size:1.5rem;font-weight:700;margin:0}.kpi-ps-header-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.kpi-ps-zakres{align-items:center;background:#1e2433;border:1px solid #334155;border-radius:10px;display:flex;gap:12px;padding:10px 16px}.kpi-ps-zakres-title{color:#94a3b8;flex-shrink:0;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.kpi-ps-zakres-inner{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.kpi-ps-zakres-buttons{background:#252d3d;border:1px solid #334155;border-radius:8px;display:inline-flex;gap:0;padding:2px}.kpi-ps-zakres-btn{background:#94a3b81a;border:1px solid #94a3b838;border-radius:6px;color:#e2e8f0b8;cursor:pointer;font-size:.8125rem;font-weight:500;padding:6px 12px;transition:color .2s,background .2s,border-color .2s,box-shadow .2s}.kpi-ps-zakres-btn:hover{background:#94a3b829;border-color:#94a3b861;color:#e2e8f0f2}.kpi-ps-zakres-btn-active{background:#00bcd4;border-color:#00bcd48c;box-shadow:0 1px 2px #0003;color:#fff}.kpi-ps-zakres-btn-active:hover{background:#00acc1;color:#fff}.kpi-ps-zakres-field{align-items:center;display:flex;gap:8px}.kpi-ps-zakres-input{background:#252d3d;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:.8125rem;padding:6px 10px}.kpi-ps-zakres-input:focus{border-color:#00bcd4;box-shadow:0 0 0 2px #00bcd433;outline:none}.kpi-ps-zakres .kpi-ps-select-input{min-width:120px}.kpi-ps-zakres .kpi-ps-year-input{width:72px}.kpi-ps-month-picker,.kpi-ps-picker-inline,.kpi-ps-year-picker{align-items:center;display:flex;gap:8px}.kpi-ps-select-input,.kpi-ps-year-input{background:#1e2433;border:1px solid #334155;border-radius:8px;color:#e2e8f0;font-size:.875rem;min-width:0;padding:8px 12px}.kpi-ps-select-input{min-width:140px}.kpi-ps-year-input{width:80px}.kpi-ps-select-input:focus,.kpi-ps-year-input:focus{border-color:#00bcd4;box-shadow:0 0 0 2px #00bcd433;outline:none}.kpi-ps-shell{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;box-shadow:0 1px 3px #00000026!important;margin-bottom:24px;padding:24px}.kpi-ps-shell-inner{gap:16px}.kpi-ps-shell-title{color:#f1f5f9!important;font-size:1.5rem;margin:0}.kpi-ps-shell-subtitle{color:#94a3b8!important;font-size:.875rem;margin:0}.kpi-ps-cards{gap:16px;margin:0;width:100%}.kpi-ps-card-span-2{display:flex;flex-direction:column;grid-column:span 1}.kpi-ps-card-span-2>.kpi-ps-shell{flex:1 1;min-height:0}@media (min-width:672px){.kpi-ps-card-span-2{grid-column:span 2}}.kpi-ps-modules-equal{align-items:stretch;display:grid!important}.kpi-ps-modules-equal>*{align-self:stretch;min-height:360px}.kpi-ps-modules-equal .kpi-ps-shell{height:100%;min-height:360px}.kpi-ps-modules-equal .kpi-ps-card-span-2{align-self:stretch;display:flex;min-height:360px}.kpi-ps-kpi-card{background:#1e2433!important;border:1px solid #334155!important;border-radius:10px!important;cursor:pointer;min-height:80px;padding:16px;transition:border-color .2s,box-shadow .2s}.kpi-ps-kpi-card:hover{border-color:#475569!important}.kpi-ps-kpi-card-selected{border-color:#00bcd4!important;box-shadow:0 0 0 2px #00bcd459}.kpi-ps-kpi-label{color:#94a3b8!important;font-size:.75rem;font-weight:500;letter-spacing:.02em;margin:0 0 6px;text-transform:uppercase}.kpi-ps-kpi-metric{color:#f1f5f9!important;font-size:1.5rem;margin:0}.kpi-ps-charts-area{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;box-shadow:0 1px 3px #00000026!important;margin-bottom:24px;min-height:360px;padding:24px}.kpi-ps-charts-area:focus,.kpi-ps-charts-area:focus-within{box-shadow:0 1px 3px #00000026!important;outline:none!important}.kpi-ps-charts-title{color:#e2e8f0!important;font-size:1.125rem;margin:0 0 4px}.kpi-ps-charts-subtitle{color:#94a3b8;font-size:.8125rem;margin:0 0 20px}.kpi-ps-charts-area .recharts-layer,.kpi-ps-charts-area .recharts-responsive-container,.kpi-ps-charts-area .recharts-responsive-container:active,.kpi-ps-charts-area .recharts-responsive-container:focus,.kpi-ps-charts-area .recharts-surface,.kpi-ps-charts-area .recharts-surface:active,.kpi-ps-charts-area .recharts-surface:focus,.kpi-ps-charts-area .recharts-wrapper,.kpi-ps-charts-area .recharts-wrapper:active,.kpi-ps-charts-area .recharts-wrapper:focus{border:none!important;box-shadow:none!important;outline:none!important}.kpi-ps-charts-area div:active,.kpi-ps-charts-area div:focus,.kpi-ps-charts-area div:focus-visible,.kpi-ps-charts-area svg:active,.kpi-ps-charts-area svg:focus,.kpi-ps-charts-area svg:focus-visible{border:none!important;box-shadow:none!important;outline:none!important}.kpi-ps-charts-area .recharts-bar-rectangle:active,.kpi-ps-charts-area .recharts-bar-rectangle:focus,.kpi-ps-charts-area .recharts-bar-rectangle:focus-visible{stroke:none!important;stroke-width:0!important;border:none!important;box-shadow:none!important;outline:none!important}.kpi-ps-charts-area .recharts-bar-rectangle path,.kpi-ps-charts-area .recharts-bar-rectangle rect{stroke:none!important;stroke-width:0!important;outline:none!important}.kpi-ps-charts-area .recharts-bar-rectangle path:active,.kpi-ps-charts-area .recharts-bar-rectangle path:focus,.kpi-ps-charts-area .recharts-bar-rectangle path:focus-visible,.kpi-ps-charts-area .recharts-bar-rectangle rect:active,.kpi-ps-charts-area .recharts-bar-rectangle rect:focus,.kpi-ps-charts-area .recharts-bar-rectangle rect:focus-visible{stroke:none!important;stroke-width:0!important;outline:none!important}.kpi-ps-charts-area .recharts-bar :active,.kpi-ps-charts-area .recharts-bar :focus,.kpi-ps-charts-area .recharts-bar :focus-visible{stroke:none!important;stroke-width:0!important;border:none!important;box-shadow:none!important;outline:none!important;outline-width:0!important}.kpi-ps-charts-area .recharts-bar-rectangle,.kpi-ps-charts-area .recharts-bar-rectangle:active,.kpi-ps-charts-area .recharts-bar-rectangle:focus,.kpi-ps-charts-area .recharts-bar-rectangle:focus-visible{border:none!important;box-shadow:none!important;outline:none!important;outline-width:0!important}.kpi-ps-charts-area svg:focus{outline:none!important}.kpi-ps-charts-area .kpi-ps-chart-opis,.kpi-ps-charts-area .kpi-ps-chart-psa,.kpi-ps-charts-area .kpi-ps-chart-time,.kpi-ps-charts-area .kpi-ps-chart-time-block{border:none!important;outline:none!important}.kpi-ps-charts-area .kpi-ps-chart-opis:active,.kpi-ps-charts-area .kpi-ps-chart-opis:focus,.kpi-ps-charts-area .kpi-ps-chart-psa:active,.kpi-ps-charts-area .kpi-ps-chart-psa:focus,.kpi-ps-charts-area .kpi-ps-chart-time:active,.kpi-ps-charts-area .kpi-ps-chart-time:focus{border:none!important;box-shadow:none!important;outline:none!important}.kpi-ps-chart-time-block{border-bottom:1px solid #334155;margin-bottom:28px;padding-bottom:24px}.kpi-ps-chart-time-block .kpi-ps-chart-block-title{margin-bottom:4px}.kpi-ps-chart-time-block .kpi-ps-chart-block-desc{margin-bottom:12px}.kpi-ps-time-chart-breadcrumb{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.kpi-ps-time-chart-back{background:#00bcd426;border:1px solid #00bcd466;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:.8125rem;padding:6px 12px}.kpi-ps-time-chart-back:hover{background:#00bcd440;color:#e2e8f0}.kpi-ps-chart-time .recharts-bar-rectangle:hover{filter:brightness(1.15);opacity:.9}.kpi-ps-time-chart-day-hint{margin-bottom:16px;margin-top:4px}.kpi-ps-charts-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr;margin-top:16px}@media (max-width:900px){.kpi-ps-charts-grid{grid-template-columns:1fr}}.kpi-ps-chart-block{min-height:280px}.kpi-ps-chart-block-title{color:#e2e8f0!important;font-size:.9375rem;font-weight:600;margin:0 0 4px}.kpi-ps-chart-block-desc{color:#94a3b8!important;font-size:.75rem;margin:0 0 12px}.kpi-ps-chart-empty{align-items:center;background:#1e243399;border:1px dashed #475569;border-radius:10px;color:#64748b;display:flex;font-size:.9375rem;justify-content:center;min-height:240px}.kpi-ps-charts-area .recharts-cartesian-grid line{stroke:#334155;stroke-opacity:.6}.kpi-ps-charts-area .recharts-xAxis .recharts-text,.kpi-ps-charts-area .recharts-yAxis .recharts-text{fill:#94a3b8;font-size:12px}.kpi-ps-charts-area .recharts-legend-item-text{color:#94a3b8!important}.kpi-ps-charts-area .recharts-bar-rectangle{stroke:none!important;outline:none!important}.kpi-ps-charts-area .recharts-bar-rectangle:hover{filter:brightness(1.15);opacity:.9}.kpi-ps-charts-area .recharts-bar-rectangle:active,.kpi-ps-charts-area .recharts-bar-rectangle:focus{stroke:none!important;outline:none!important}.kpi-ps-chart-psa-rounded .recharts-bar-rectangle{border-radius:4px 4px 0 0}.kpi-ps-tooltip{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;box-shadow:0 4px 12px #0003!important;color:#1e293b!important;min-width:160px;padding:12px 14px!important}.kpi-ps-tooltip-header{border-bottom:1px solid #e2e8f0;color:#64748b!important;font-size:.8125rem;font-weight:600;margin-bottom:8px;padding-bottom:6px}.kpi-ps-tooltip-row{align-items:center;color:#1e293b!important;display:flex;font-size:.875rem;gap:8px}.kpi-ps-tooltip-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.kpi-ps-tooltip-dot-cyan{background:#00bcd4}.kpi-ps-tooltip-dot-teal{background:#26a69a}.kpi-ps-charts-area .recharts-tooltip-cursor,.kpi-ps-charts-area .recharts-tooltip-cursor rect{fill:#0000!important;stroke:none!important;display:none!important}.kpi-ps-charts-area .recharts-default-tooltip,.kpi-ps-charts-area .recharts-tooltip-wrapper{outline:none}.kpi-ps-charts-area .recharts-default-tooltip{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:8px!important;box-shadow:0 4px 12px #0003!important;color:#1e293b!important;padding:12px 14px!important}.kpi-ps-charts-area .recharts-default-tooltip .recharts-tooltip-label{border-bottom:1px solid #e2e8f0;color:#64748b!important;font-size:.8125rem;font-weight:600;margin-bottom:6px;padding-bottom:6px}.kpi-ps-charts-area .recharts-default-tooltip .recharts-tooltip-item{color:#1e293b!important;font-size:.875rem}.kpi-ps-table-card{background:#252d3d!important;border:1px solid #334155!important;border-radius:12px!important;box-shadow:0 1px 3px #00000026!important;padding:24px}.kpi-ps-table-title{color:#e2e8f0!important;font-size:1.125rem;margin:0 0 4px}.kpi-ps-table-subtitle{color:#94a3b8;font-size:.8125rem;margin:0 0 8px}.kpi-ps-table-filter-hint{align-items:center;background:#00bcd414;border:1px solid #00bcd440;border-radius:8px;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px;padding:10px 12px}.kpi-ps-table-filter-hint span{color:#94a3b8;font-size:.8125rem}.kpi-ps-table-clear-filter{margin-left:auto}.kpi-ps-table-error{color:#f87171;font-size:.875rem;margin:0 0 16px}.kpi-ps-table-empty,.kpi-ps-table-loading{color:#94a3b8;font-size:.9375rem;margin:0;padding:24px 0}.kpi-ps-table-empty-cell{color:#64748b;padding:24px;text-align:center}.kpi-ps-table{margin-top:8px}.kpi-ps-table-scroll{overflow-x:hidden;overflow-y:auto}.kpi-ps-table-scroll::-webkit-scrollbar{width:8px}.kpi-ps-table-scroll::-webkit-scrollbar-track{background:#1e2433;border-radius:4px}.kpi-ps-table-scroll::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}.kpi-ps-table-scroll::-webkit-scrollbar-thumb:hover{background:#64748b}.kpi-ps-table-scroll{scrollbar-color:#475569 #1e2433;scrollbar-width:thin}.kpi-ps-table table{width:100%}.kpi-ps-table td,.kpi-ps-table th{border-color:#33415573!important;border-width:1px;color:#e2e8f0!important;padding:12px 16px}.kpi-ps-table th{background:#1e2433!important;color:#cbd5e1!important;font-weight:600}.kpi-ps-table tbody tr:hover td{background:#ffffff08!important}.kpi-ps-table-actions-header{text-align:right}.kpi-ps-table-action-btn{font-size:12px}.kpi-stat-page-card{background:#1e2433!important;border:1px solid #334155!important}.kpi-stat-page-card-text{color:#94a3b8!important;margin-top:6px}.kpi-stat-page-placeholder{color:#94a3b8;font-size:.9375rem;margin:0}.quality-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:calc(100vh - 80px);padding:20px}.quality-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;margin:0 auto;max-width:1400px;padding:30px}.quality-title{color:#333;font-size:28px;font-weight:700;margin-bottom:10px}.quality-description{color:#666;font-size:16px;margin-bottom:30px}.add-alert-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin:0 auto;max-width:1200px;padding:32px}.add-alert-header{border-bottom:2px solid #e5e7eb;margin-bottom:24px;padding-bottom:16px}.add-alert-header h3{color:#1f2937;font-size:28px;font-weight:700;margin:0 0 8px}.add-alert-subtitle{color:#6b7280;font-size:15px;font-weight:400;line-height:1.5;margin:0}.quality-form{display:flex;flex-direction:column;gap:32px}.form-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:24px;transition:all .2s ease}.form-section:hover{border-color:#d1d5db;box-shadow:0 1px 3px #0000000d}.form-section-title{align-items:center;color:#374151;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0 0 20px}.form-section-title:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;content:"";display:block;height:20px;width:4px}.form-section-hint{color:#6b7280;font-size:13px;font-style:italic;margin:-12px 0 16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-row-three{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.form-label{color:#333;font-size:14px;font-weight:600}.required-asterisk{color:#e74c3c}.form-input,.form-select,.form-textarea{background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .2s ease;width:100%}.form-input:hover,.form-select:hover{border-color:#cbd5e1}.form-input::placeholder{color:#9ca3af}.content-editable:focus,.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.content-editable,.form-textarea{min-height:100px;resize:vertical}.content-editable{background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:15px;padding:12px 16px;transition:border-color .3s}.content-editable:empty:before{color:#999;content:attr(data-placeholder);pointer-events:none}.content-editable:focus{border-color:#667eea;outline:none}.form-actions{gap:15px;margin-top:10px}.btn-reset,.btn-submit{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-submit:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-reset{background:#f3f4f6;color:#333}.btn-reset:hover{background:#e5e7eb}.btn-edit-alert{align-items:center;background:#f3f4f6;border:none;border-radius:6px;color:#333;cursor:pointer;display:flex;font-size:16px;justify-content:center;line-height:1;padding:6px 12px;transition:all .3s}.btn-edit-alert:hover{background:#667eea;color:#fff;transform:scale(1.1)}.submit-status{border-radius:8px;font-size:14px;font-weight:500;padding:12px 16px}.submit-status.success{background:#d1fae5;border:1px solid #10b981;color:#065f46}.submit-status.error{background:#fee2e2;border:1px solid #ef4444;color:#991b1b}.quality-filters{display:flex;flex-wrap:wrap;gap:15px;margin-bottom:25px}.filter-group{display:flex;flex-direction:column;gap:5px}.filter-group label{color:#666;font-size:13px;font-weight:600}.filter-select{border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:14px;min-width:150px;padding:8px 12px}.filter-select:focus{border-color:#667eea;outline:none}.quality-stats{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.stat-card{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:20px;text-align:center}.stat-value{color:#333;font-size:32px;margin-bottom:5px}.stat-label{font-size:14px;font-weight:500}.alerts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.alert-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px;transition:all .3s}.alert-card:hover{border-color:#667eea;box-shadow:0 8px 24px #0000001a;transform:translateY(-4px)}.alert-header{align-items:flex-start;display:flex;gap:15px;justify-content:space-between;margin-bottom:15px}.alert-title{color:#333;flex:1 1;font-size:18px;font-weight:700;margin:0}.alert-badges{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.status-selector-wrapper{position:relative}.status-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23fff' d='M6 9 1 4h10z'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;background-size:10px;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;outline:none;padding:4px 28px 4px 12px;transition:all .3s}.status-select:hover{opacity:.9;transform:scale(1.05)}.status-select:focus{outline:2px solid #ffffff80;outline-offset:2px}.badge{border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px;white-space:nowrap}.alert-description{color:#666;font-size:14px;line-height:1.6;margin-bottom:15px}.alert-details{border-top:1px solid #e9ecef;display:flex;flex-direction:column;gap:8px;padding-top:15px}.detail-item{display:flex;font-size:13px;justify-content:space-between}.detail-label{color:#666;font-weight:500}.detail-value{color:#333;font-weight:600}.detail-value.overdue{color:#dc2626;font-weight:700}.no-alerts{color:#666;padding:60px 20px;text-align:center}.no-alerts p{font-size:18px;margin-bottom:10px}.no-alerts-hint{color:#999;font-size:14px}.category-select-wrapper{align-items:flex-start;display:flex;gap:10px}.category-select-wrapper .form-select{flex:1 1}.category-actions{display:flex;gap:5px}.btn-add-category{align-items:center;background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:36px;justify-content:center;line-height:1;transition:all .3s;width:36px}.btn-add-category:hover{background:#667eea;color:#fff;transform:scale(1.05)}.add-category-form{align-items:center;display:flex;gap:8px;margin-top:10px}.add-category-form .form-input{flex:1 1;padding:8px 12px}.btn-cancel-category,.btn-confirm-category{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .3s}.btn-confirm-category{background:#10b981;color:#fff}.btn-confirm-category:hover{background:#059669;transform:translateY(-2px)}.btn-cancel-category{background:#f3f4f6;color:#333}.btn-cancel-category:hover{background:#e5e7eb}.categories-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.category-tag{align-items:center;background:#f3f4f6;border-radius:20px;color:#333;display:inline-flex;font-size:13px;gap:6px;padding:6px 12px}.btn-remove-category{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;height:18px;justify-content:center;line-height:1;padding:0;transition:background .3s;width:18px}.btn-remove-category:hover{background:#dc2626}.images-section{margin-top:10px}.btn-add-image{align-items:center;background:#fff;border:2px dashed #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:32px;font-weight:700;height:60px;justify-content:center;line-height:1;margin-bottom:15px;transition:all .3s;width:60px}.btn-add-image:hover{background:#667eea;border-color:#667eea;color:#fff;transform:scale(1.05)}.images-preview{margin-top:15px}.images-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.image-preview-item{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:10px}.image-wrapper{background:#fff;border-radius:6px;overflow:hidden;position:relative;width:100%}.image-wrapper:before{border-color:#0000 #0000001a #0000 #0000;border-style:solid;border-width:0 30px 30px 0;content:"";height:0;pointer-events:none;position:absolute;right:0;top:0;width:0;z-index:1}.preview-image{display:block;height:150px;object-fit:cover;width:100%}.image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:70px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:70px;z-index:2}.image-status-overlay.nok{background:#dc2626}.image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:14px;font-weight:900;letter-spacing:1px;position:absolute;right:4px;text-shadow:0 1px 3px #00000080;top:18px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.image-status-overlay.ok{background:#10b981}.image-status-overlay.ok:after{color:#fff;content:"OK";font-size:14px;font-weight:900;letter-spacing:1px;position:absolute;right:16px;text-shadow:0 1px 3px #00000080;top:18px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.remove-image-btn{align-items:center;background:#dc2626e6;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:28px;justify-content:center;line-height:1;position:absolute;right:5px;top:5px;transition:background .3s;width:28px;z-index:2}.remove-image-btn:hover{background:#dc2626}.image-comment-input{border:1px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:13px;padding:8px 12px;transition:border-color .3s;width:100%}.image-comment-input:focus{border-color:#667eea;outline:none}.image-status-buttons{display:flex;gap:8px}.btn-status{border:2px solid;border-radius:6px;cursor:pointer;flex:1 1;font-size:13px;font-weight:700;padding:8px 12px;text-transform:uppercase;transition:all .3s}.btn-status.nok{background:#fff;border-color:#ef4444;color:#ef4444}.btn-status.nok.active,.btn-status.nok:hover{background:#ef4444;color:#fff}.btn-status.ok{background:#fff;border-color:#10b981;color:#10b981}.btn-status.ok.active,.btn-status.ok:hover{background:#10b981;color:#fff}.image-name{color:#666;display:block;font-size:11px;overflow:hidden;padding:5px 8px;text-align:center;text-overflow:ellipsis;white-space:nowrap}.image-arrow{filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));opacity:.85;pointer-events:none;position:absolute;z-index:4}.image-arrow svg{display:block}.remove-arrow-btn{align-items:center;background:#ffd700e6;border:2px solid orange;border-radius:50%;color:#333;cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;left:5px;line-height:1;position:absolute;top:5px;transition:background .3s;width:24px;z-index:5}.remove-arrow-btn:hover{background:gold;transform:scale(1.1)}.image-arrow-hint{color:#666;font-size:11px;font-style:italic;margin-top:5px;text-align:center}.alert-images{border-top:1px solid #e9ecef;margin-top:15px;padding-top:15px}.images-label{color:#666;font-size:13px;font-weight:600;margin-bottom:10px}.alert-images-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.alert-images-grid .alert-image-thumbnail{order:1}.alert-images-grid .alert-image-thumbnail[data-status=NOK]{order:0}.alert-images-grid .alert-image-thumbnail[data-status=OK]{order:1}.alert-image-thumbnail{aspect-ratio:1;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;min-height:120px;overflow:hidden;position:relative;transition:all .3s;width:100%}.alert-image-thumbnail:hover{border-color:#667eea;transform:scale(1.05)}.alert-image-thumbnail img{display:block;height:100%;object-fit:cover;width:100%}.alert-image-thumbnail .image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:50px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:50px;z-index:3}.alert-image-thumbnail .image-status-overlay.nok{background:#dc2626}.alert-image-thumbnail .image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:10px;font-weight:900;letter-spacing:1px;position:absolute;right:2px;text-shadow:0 1px 3px #00000080;top:12px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-image-thumbnail .image-status-overlay.ok{background:#10b981}.alert-image-thumbnail .image-status-overlay.ok:after{color:#fff;content:"OK";font-size:10px;font-weight:900;letter-spacing:1px;position:absolute;right:8px;text-shadow:0 1px 3px #00000080;top:12px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-image-thumbnail .image-comment{background:#000000d9;bottom:0;color:#fff;font-size:13px;font-weight:500;left:0;line-height:1.4;max-height:40px;overflow:hidden;padding:8px 12px;position:absolute;right:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;z-index:1}.image-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.alert-image-thumbnail:hover .image-overlay{opacity:1}.zoom-icon{color:#fff;font-size:24px}.image-modal-overlay{background:#000000e6;bottom:0;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.image-modal-content,.image-modal-overlay{align-items:center;display:flex;padding:20px}.image-modal-content{background:#fff;border-radius:12px;flex-direction:column;max-height:90vh;max-width:90vw;position:relative}.image-modal-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;font-weight:700;height:36px;justify-content:center;line-height:1;position:absolute;right:10px;top:10px;transition:background .3s;width:36px;z-index:1001}.image-modal-close:hover{background:#000000e6}.image-modal-image{border-radius:8px;display:block;max-height:80vh;max-width:100%;object-fit:contain}.image-modal-content .image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:80px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:80px;z-index:1003}.image-modal-content .image-status-overlay.nok{background:#dc2626}.image-modal-content .image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:16px;font-weight:900;letter-spacing:1px;position:absolute;right:5px;text-shadow:0 1px 3px #00000080;top:22px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.image-modal-content .image-status-overlay.ok{background:#10b981}.image-modal-content .image-status-overlay.ok:after{color:#fff;content:"OK";font-size:16px;font-weight:900;letter-spacing:1px;position:absolute;right:20px;text-shadow:0 1px 3px #00000080;top:22px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.image-modal-name{color:#666;font-size:14px;margin-top:15px;text-align:center}.image-modal-nav{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:32px;font-weight:700;height:50px;justify-content:center;line-height:1;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s;width:50px;z-index:1002}.image-modal-nav:hover{background:#000c;transform:translateY(-50%) scale(1.1)}.image-modal-nav-prev{left:20px}.image-modal-nav-next{right:20px}.image-modal-counter{background:#000000b3;border-radius:20px;color:#fff;font-size:14px;font-weight:600;left:50%;padding:8px 16px;position:absolute;top:20px;transform:translateX(-50%);z-index:1002}.alert-modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;overflow-y:auto;padding:20px;position:fixed;right:0;top:0;z-index:1000}.alert-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;padding:30px;position:relative;width:100%}.alert-modal-close{align-items:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;font-weight:700;height:36px;justify-content:center;line-height:1;position:absolute;right:15px;top:15px;transition:background .3s;width:36px;z-index:1001}.alert-modal-close:hover{background:#000000e6}.alert-modal-nav{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:32px;font-weight:700;height:50px;justify-content:center;line-height:1;position:absolute;top:50%;transform:translateY(-50%);transition:all .3s;width:50px;z-index:1002}.alert-modal-nav:hover{background:#000c;transform:translateY(-50%) scale(1.1)}.alert-modal-nav-prev{left:20px}.alert-modal-nav-next{right:20px}.btn-print{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s}.btn-print:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-print:active{transform:translateY(0)}.btn-generate-pdf{align-items:center;background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s;white-space:nowrap}.btn-generate-pdf:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.btn-generate-pdf:active{transform:translateY(0)}.alert-modal-header{border-bottom:2px solid #e9ecef;margin-bottom:25px;padding-bottom:20px}.alert-modal-title{color:#333;font-size:24px;font-weight:700;margin:0 0 15px}.alert-modal-badges{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.alert-modal-section{margin-bottom:25px}.alert-modal-section-title{color:#333;font-size:18px;font-weight:600;margin:0 0 12px}.alert-modal-description{color:#666;font-size:15px;line-height:1.7;margin:0}.alert-modal-section:has(.alert-modal-section-title:contains("Kroki zaradcze")),.alert-modal-section:has(.alert-modal-section-title:contains("Opis")){background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.alert-modal-section.corrective-actions-section,.alert-modal-section.description-section{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.alert-modal-section.description-section .alert-modal-section-title{border-bottom:2px solid #e0e0e0;color:#dc2626;margin-bottom:15px;padding-bottom:10px}.alert-modal-section.corrective-actions-section .alert-modal-section-title{border-bottom:2px solid #e0e0e0;color:#10b981;margin-bottom:15px;padding-bottom:10px}.alert-modal-section.corrective-actions-section .alert-modal-description,.alert-modal-section.description-section .alert-modal-description{background:#fff;border-left:4px solid #dc2626;border-radius:6px;color:#333;padding:15px}.alert-modal-section.corrective-actions-section .alert-modal-description{border-left-color:#10b981}.alert-modal-section.images-section{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;margin-bottom:25px;padding:20px}.alert-modal-section.images-section .alert-modal-images-grid{margin-top:0}.alert-modal-details-grid{grid-gap:15px;background:#f8f9fa;border-radius:8px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:25px;padding:20px}.alert-modal-detail-item{display:flex;flex-direction:column;gap:5px}.alert-modal-detail-item .detail-label{color:#666;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.alert-modal-detail-item .detail-value{color:#333;font-size:15px;font-weight:600}.alert-modal-images-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.alert-modal-images-grid .alert-modal-image-item{order:1}.alert-modal-images-grid .alert-modal-image-item[data-status=NOK]{order:0}.alert-modal-images-grid .alert-modal-image-item[data-status=OK]{order:1}.alert-modal-image-item{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;min-height:200px;overflow:hidden;position:relative;transition:all .3s}.alert-modal-image-item:hover{border-color:#667eea;transform:scale(1.05)}.alert-modal-image-item img{display:block;height:200px;object-fit:cover;width:100%}.alert-modal-image-item .image-status-overlay{box-shadow:0 2px 8px #0000004d;-webkit-clip-path:polygon(100% 0,100% 100%,0 0);clip-path:polygon(100% 0,100% 100%,0 0);height:60px;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0;width:60px;z-index:3}.alert-modal-image-item .image-status-overlay.nok{background:#dc2626}.alert-modal-image-item .image-status-overlay.nok:after{color:#fff;content:"NOK";font-size:12px;font-weight:900;letter-spacing:1px;position:absolute;right:3px;text-shadow:0 1px 3px #00000080;top:15px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-modal-image-item .image-status-overlay.ok{background:#10b981}.alert-modal-image-item .image-status-overlay.ok:after{color:#fff;content:"OK";font-size:12px;font-weight:900;letter-spacing:1px;position:absolute;right:12px;text-shadow:0 1px 3px #00000080;top:15px;transform:rotate(45deg);transform-origin:center;white-space:nowrap}.alert-modal-image-name{word-wrap:break-word;background:#f8f9fa;border-top:1px solid #e0e0e0;color:#333;font-size:14px;font-weight:500;line-height:1.5;overflow:visible;padding:12px;text-align:center;white-space:normal}@media (max-width:768px){.alert-modal-content{max-height:95vh;padding:20px}.alert-modal-title{font-size:20px}.alert-modal-details-grid{grid-template-columns:1fr}.alert-modal-images-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}@media (max-width:1024px){.add-alert-container{max-width:100%;padding:24px}.form-row-three{grid-template-columns:1fr 1fr}}@media (max-width:768px){.add-alert-container{margin:0 16px;padding:20px}.add-alert-header h3{font-size:24px}.form-section{padding:20px}.form-row,.form-row-three{grid-template-columns:1fr}.quality-filters{flex-direction:column}.filter-select{width:100%}.alerts-grid{grid-template-columns:1fr}.alert-header,.form-actions{flex-direction:column}.form-actions button{width:100%}}.text-editor-wrapper{background:#fff;border:1px solid #ddd;border-radius:4px;display:flex;flex-direction:column;overflow:hidden}.text-editor-toolbar{align-items:center;background:#f8f9fa;border-bottom:1px solid #ddd;display:flex;flex-wrap:wrap;gap:8px;padding:8px}.toolbar-group{align-items:center;border-right:1px solid #e0e0e0;display:flex;gap:4px;padding-right:8px}.toolbar-group:last-child{border-right:none}.toolbar-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;font-size:14px;height:32px;justify-content:center;min-width:32px;padding:6px 10px;transition:all .2s}.toolbar-btn:hover{background:#e9ecef;border-color:#adb5bd}.toolbar-btn:active{background:#dee2e6}.toolbar-btn strong{font-weight:700}.toolbar-btn em{font-style:italic}.toolbar-btn u{text-decoration:underline}.toolbar-select{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:13px;height:32px;min-width:100px;padding:6px 8px}.toolbar-select:hover{border-color:#adb5bd}.toolbar-color{background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;height:32px;padding:2px;width:40px}.toolbar-color:hover{border-color:#adb5bd}.text-editor-content{border:none;font-family:Arial,sans-serif;font-size:14px;line-height:1.5;min-height:120px;outline:none;overflow-y:auto;padding:10px}.text-editor-content:empty:before{color:#999;content:attr(data-placeholder);pointer-events:none}.text-editor-content:focus{outline:none}.text-editor-content *{margin:0;padding:0}.permissions-manager{box-sizing:border-box;margin:0 auto;max-width:1600px;padding:40px 20px}.permissions-header{margin-bottom:32px;text-align:center}.permissions-header h2{color:#1a1a1a;font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.permissions-header p{color:#6b7280;font-size:16px;font-weight:400;margin:0}.permissions-message{align-items:center;animation:slideIn .3s ease;border-left:4px solid;border-radius:10px;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:24px;padding:16px 20px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.permissions-message.error{background-color:#fef2f2;border-left-color:#ef4444;color:#dc2626}.permissions-message.success{background-color:#f0fdf4;border-left-color:#22c55e;color:#16a34a}.permissions-content{grid-gap:32px;display:grid;gap:32px;grid-template-columns:350px 1fr;min-height:600px}.permissions-sidebar{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;height:-webkit-fit-content;height:fit-content;max-height:800px;overflow-y:auto;padding:24px}.users-search{margin-bottom:24px}.search-input{border-radius:10px;box-sizing:border-box;padding:12px 16px;width:100%}.users-list h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 16px}.user-item{background:#f9fafb;border:2px solid #0000;border-radius:10px;cursor:pointer;margin-bottom:8px;padding:16px;transition:all .2s ease}.user-item:hover{background:#f3f4f6;border-color:#e5e7eb}.user-item.active{background:#eff6ff;border-color:#3b82f6}.user-info{display:flex;flex-direction:column;gap:8px}.user-name{color:#111827;font-size:15px;font-weight:600}.user-details{display:flex;flex-direction:column;font-size:13px;gap:4px}.user-role{color:#6b7280;font-weight:500}.user-email{color:#9ca3af;font-size:12px}.permissions-main{background:#fff;border:1px solid #0000000f;border-radius:16px;box-shadow:0 4px 24px #00000014,0 1px 3px #0000000d;padding:32px}.selected-user-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:24px}.selected-user-header h3{color:#111827;font-size:24px;font-weight:700;margin:0}.role-badge{border-radius:6px;font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.role-badge.role-owner{background:#fef3c7;color:#92400e}.role-badge.role-admin{background:#dbeafe;color:#1e40af}.role-badge.role-lider{background:#d1fae5;color:#065f46}.role-badge.role-user{background:#f3f4f6;color:#374151}.role-badge.role-employee{background:#fce7f3;color:#831843}.permissions-sections{display:flex;flex-direction:column;gap:32px;margin-bottom:32px}.permissions-module{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.module-title{color:#111827;font-size:20px;font-weight:700;margin:0 0 8px}.module-description{color:#6b7280;font-size:14px;margin:0 0 20px}.permissions-list{display:flex;flex-direction:column;gap:20px}.permissions-subsection{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px}.subsection-title{color:#111827;font-size:16px;font-weight:600;margin:0 0 8px}.subsection-description{color:#6b7280;font-size:13px;margin:0 0 16px}.permissions-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.permission-checkbox{align-items:flex-start;background:#fff;border:2px solid #0000;border-radius:8px;display:flex;gap:12px;padding:12px;transition:all .2s ease}.permission-checkbox:hover{background:#f9fafb;border-color:#e5e7eb}.permission-checkbox input[type=checkbox]{cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.permission-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.permission-label{font-size:14px;font-weight:600}.permission-description{font-size:12px}.permissions-actions{border-top:2px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding-top:24px}.cancel-button,.save-button{border-radius:8px;padding:12px 24px}.save-button:hover:not(:disabled){box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.save-button:disabled{opacity:.6}.cancel-button:hover{background:#e5e7eb}.no-selection{font-size:16px;text-align:center}.no-selection,.permissions-loading{align-items:center;color:#6b7280;display:flex;height:400px;justify-content:center}.permissions-loading{font-size:18px}@media (max-width:1200px){.permissions-content{grid-template-columns:300px 1fr}}@media (max-width:968px){.permissions-content{grid-template-columns:1fr}.permissions-sidebar{max-height:300px}}.permissions-grid-container{box-sizing:border-box;margin:0 auto;max-width:100%;padding:20px}.permissions-grid-header{margin-bottom:24px;text-align:center}.permissions-grid-header h2{color:#1a1a1a;font-size:28px;font-weight:700;margin:0 0 8px}.permissions-grid-header p{color:#6b7280;font-size:14px;margin:0}.owner-info-banner{align-items:center;background:linear-gradient(135deg,#fff7ed,#ffedd5);border:1px solid #fed7aa;border-radius:8px;box-shadow:0 1px 3px #fb923c1a;display:flex;gap:10px;margin-top:16px;padding:12px 16px}.owner-info-icon{flex-shrink:0;font-size:20px}.owner-info-text{color:#7c2d12;font-size:13px;line-height:1.5}.owner-info-text strong{color:#9a3412;font-weight:700}.permissions-grid-message{align-items:center;border-radius:8px;display:flex;font-size:14px;font-weight:500;gap:8px;margin-bottom:20px;padding:12px 16px}.permissions-grid-message.error{background-color:#fef2f2;border-left:4px solid #ef4444;color:#dc2626}.permissions-grid-message.success{background-color:#f0fdf4;border-left:4px solid #22c55e;color:#16a34a}.permissions-grid-toolbar{align-items:center;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:16px}.toolbar-left{flex:1 1;gap:16px;max-width:800px}.toolbar-left,.toolbar-right{align-items:center;display:flex}.toolbar-right{gap:12px}.search-input{border:2px solid #e5e7eb;border-radius:6px;flex:0 0 300px;font-size:14px;padding:10px 14px;transition:all .2s ease}.owner-info-text-inline{color:#6b7280;font-size:13px;font-style:italic;white-space:nowrap}.search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.unsaved-indicator{color:#f59e0b;font-size:13px;font-weight:500}.cancel-button,.save-button{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.save-button{background:#3b82f6;color:#fff}.save-button:hover:not(:disabled){background:#2563eb}.save-button:disabled{cursor:not-allowed;opacity:.5}.cancel-button{background:#f3f4f6;color:#374151}.cancel-button:hover:not(:disabled){background:#e5e7eb}.cancel-button:disabled{cursor:not-allowed;opacity:.5}.permissions-grid-wrapper{background:#fff;border:1px solid #e5e7eb;border-radius:8px;max-height:calc(100vh - 300px);overflow-x:auto;overflow-y:auto}.permissions-grid-table{border-collapse:initial;border-spacing:0;display:table;min-width:600px;width:100%}.permissions-grid-header-row{background:#f9fafb;display:table-row;position:-webkit-sticky;position:sticky;top:0;z-index:10}.permissions-grid-header-cell{background:#f9fafb;border-bottom:2px solid #d1d5db;border-right:1px solid #e5e7eb;display:table-cell;font-size:12px;font-weight:600;min-width:90px;padding:8px 4px;text-align:center;transition:background-color .2s ease;vertical-align:middle}.permissions-grid-header-cell-fixed{background:#f9fafb;left:0;min-width:200px;position:-webkit-sticky;position:sticky;text-align:left;z-index:11}.permissions-grid-header-cell.selected{background:#fef3c7}.header-cell-content{display:flex;flex-direction:column;gap:2px}.header-cell-label{color:#111827;font-size:11px;font-weight:600}.header-cell-label-secondary{color:#6b7280;font-size:10px;font-weight:400}.header-user-name{color:#111827;font-size:11px;font-weight:600;margin-bottom:2px}.header-user-role{color:#6b7280;font-size:10px;font-weight:500;margin-bottom:1px}.header-user-email{color:#9ca3af;font-size:9px;font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.permissions-grid-category-row{background:#f3f4f6;display:table-row}.permissions-grid-category-cell{background:#f3f4f6;border-bottom:1px solid #e5e7eb;border-right:1px solid #e5e7eb;display:table-cell;font-size:12px;font-weight:600;padding:6px 4px;transition:background-color .2s ease;vertical-align:middle}.permissions-grid-category-cell.selected{background:#fef3c7}.category-label{color:#111827;font-size:12px;font-weight:600}.permissions-grid-data-row{background:#fff;display:table-row;transition:background-color .2s ease}.permissions-grid-data-row:hover{background:#f9fafb}.permissions-grid-data-cell{border-bottom:1px solid #e5e7eb;border-right:1px solid #e5e7eb;display:table-cell;padding:6px 4px;text-align:center;transition:background-color .2s ease;vertical-align:middle}.permissions-grid-data-cell.selected{background:#fef3c7}.permission-label-cell{display:flex;flex-direction:column;gap:2px}.permission-label{color:#111827;font-size:11px;font-weight:500;text-align:left}.permission-description{color:#6b7280;font-size:9px;font-weight:400;max-width:180px;overflow:hidden;text-align:left;text-overflow:ellipsis;white-space:nowrap}.permission-checkbox-cell{align-items:center;cursor:pointer;display:flex;justify-content:center;position:relative}.permission-checkbox{cursor:pointer;height:18px;margin:0;opacity:0;position:absolute;width:18px}.checkbox-custom{align-items:center;background:#fff;border:2px solid #d1d5db;border-radius:3px;display:flex;height:18px;justify-content:center;transition:all .2s ease;width:18px}.permission-checkbox:checked+.checkbox-custom{background:#3b82f6;border-color:#3b82f6}.permission-checkbox:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:12px;font-weight:700}.permission-checkbox:hover+.checkbox-custom{border-color:#3b82f6}.permissions-grid-footer{align-items:center;background:#f9fafb;border-radius:8px;display:flex;justify-content:space-between;margin-top:20px;padding:12px 16px}.footer-info{color:#6b7280;display:flex;font-size:13px;gap:20px}.permissions-grid-loading{align-items:center;color:#6b7280;display:flex;font-size:16px;height:400px;justify-content:center}@media (max-width:1200px){.permissions-grid-header-cell-fixed{min-width:180px}.permissions-grid-header-cell{min-width:80px}}.database-viewer{background:#f5f5f5;margin:0 auto;max-width:1400px;min-height:100vh;padding:20px}.database-viewer-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;box-shadow:0 4px 6px #0000001a;color:#fff;margin-bottom:20px;padding:30px}.database-viewer-header h1{font-size:28px;margin:0 0 10px}.database-viewer-header p{margin:0;opacity:.9}.database-error{background:#fee;border:1px solid #fcc;border-radius:5px;color:#c33;margin-bottom:20px;padding:15px}.database-stats{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.database-stats h2{border-bottom:2px solid #667eea;color:#333;margin-top:0;padding-bottom:10px}.stats-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));margin-top:15px}.stat-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:5px;padding:15px;text-align:center}.stat-label{color:#666;font-size:12px;margin-bottom:5px;text-transform:uppercase}.stat-value{color:#667eea;font-size:24px;font-weight:700}.database-tables{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.database-tables h2{border-bottom:2px solid #667eea;color:#333;margin-top:0;padding-bottom:10px}.tables-list{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.table-button{background:#fff;border:2px solid #667eea;border-radius:5px;color:#667eea;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s}.table-button.active,.table-button:hover{background:#667eea;color:#fff}.table-button.active{font-weight:700}.table-count{font-size:12px;margin-left:8px;opacity:.8}.database-structure{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.database-structure h2{border-bottom:2px solid #667eea;color:#333;margin-top:0;padding-bottom:10px}.structure-table{border-collapse:collapse;margin-top:15px;width:100%}.structure-table td,.structure-table th{border-bottom:1px solid #e0e0e0;padding:10px;text-align:left}.structure-table th{background:#f8f9fa;color:#333;font-weight:700}.database-data{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.data-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:15px}.data-header h2{border-bottom:2px solid #667eea;color:#333;margin:0;padding-bottom:10px}.data-controls{align-items:center;display:flex;flex-wrap:wrap;gap:15px}.data-controls label{align-items:center;display:flex;font-size:14px;gap:8px}.data-controls input[type=number]{border:1px solid #ddd;border-radius:3px;padding:5px;width:60px}.pagination{align-items:center;display:flex;gap:10px}.pagination button{background:#fff;border:1px solid #667eea;border-radius:3px;color:#667eea;cursor:pointer;font-size:14px;padding:5px 15px}.pagination button:hover:not(:disabled){background:#667eea;color:#fff}.pagination button:disabled{cursor:not-allowed;opacity:.5}.data-table-wrapper{max-width:100%;overflow-x:auto}.data-table{border-collapse:collapse;font-size:13px;width:100%}.data-table td,.data-table th{border-bottom:1px solid #e0e0e0;padding:8px;text-align:left;word-break:break-word}.data-table th{color:#333;font-weight:700;position:-webkit-sticky;position:sticky;top:0;z-index:1}.data-table th,.data-table tr:hover{background:#f8f9fa}.json-cell{font-family:Courier New,monospace;font-size:11px;max-width:300px}.json-cell pre{margin:0;white-space:pre-wrap;word-break:break-all}.null-value{color:#999;font-style:italic}.no-data{color:#999}.loading,.no-data{font-size:16px;padding:40px;text-align:center}.loading{color:#667eea}.data-actions{margin-bottom:20px}.add-button{background:#28a745;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:14px;font-weight:700;padding:10px 20px}.add-button:hover{background:#218838}.edit-form{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:20px}.edit-form h3{color:#333;margin-top:0}.form-field{margin-bottom:15px}.form-field label{color:#555;display:block;font-weight:700;margin-bottom:5px}.form-field input,.form-field textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:14px;padding:8px;width:100%}.form-field textarea{min-height:60px;resize:vertical}.form-actions{display:flex;gap:10px;margin-top:20px}.edit-button,.save-button{background:#007bff;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:5px 15px}.edit-button:hover,.save-button:hover{background:#0056b3}.cancel-button{background:#6c757d;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;padding:5px 15px}.cancel-button:hover{background:#5a6268}.delete-button{background:#dc3545;border:none;border-radius:3px;color:#fff;cursor:pointer;font-size:12px;margin-left:5px;padding:5px 15px}.delete-button:hover{background:#c82333}.data-table td input,.data-table td textarea{border:1px solid #ddd;border-radius:3px;font-size:12px;padding:4px;width:100%}.data-table td textarea{min-height:40px;resize:vertical}@media (max-width:768px){.database-viewer{padding:10px}.data-header{align-items:flex-start;flex-direction:column}.data-table{font-size:11px}.data-table td,.data-table th{padding:5px}.form-actions{flex-direction:column}.cancel-button,.delete-button,.edit-button,.save-button{margin:5px 0;width:100%}}
/*# sourceMappingURL=main.ec70b00e.css.map*/