@charset "UTF-8";@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=Geist:wght@300;400;500;600&display=swap";*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.\!container{width:100%!important}.container{width:100%}@media (min-width: 640px){.\!container{max-width:640px!important}.container{max-width:640px}}@media (min-width: 768px){.\!container{max-width:768px!important}.container{max-width:768px}}@media (min-width: 1024px){.\!container{max-width:1024px!important}.container{max-width:1024px}}@media (min-width: 1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}@media (min-width: 1536px){.\!container{max-width:1536px!important}.container{max-width:1536px}}.pointer-events-none{pointer-events:none}.\!visible{visibility:visible!important}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.-bottom-1{bottom:-.25rem}.-top-3{top:-.75rem}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.right-0{right:0}.top-0{top:0}.isolate{isolation:isolate}.z-10{z-index:10}.z-50{z-index:50}.col-span-1{grid-column:span 1 / span 1}.mx-auto{margin-left:auto;margin-right:auto}.mb-0{margin-bottom:0}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-24{margin-bottom:6rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-7{margin-bottom:1.75rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-20{margin-top:5rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.\!grid{display:grid!important}.grid{display:grid}.hidden{display:none}.h-0\.5{height:.125rem}.h-10{height:2.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-9{height:2.25rem}.h-full{height:100%}.min-h-screen{min-height:100vh}.w-0{width:0px}.w-1{width:.25rem}.w-10{width:2.5rem}.w-2{width:.5rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-9{width:2.25rem}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-lg{max-width:32rem}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-10{gap:2.5rem}.gap-16{gap:4rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.overflow-hidden{overflow:hidden}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-0{border-width:0px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-10{padding:2.5rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-24{padding-top:6rem;padding-bottom:6rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-16{padding-bottom:4rem}.pb-24{padding-bottom:6rem}.pt-16{padding-top:4rem}.pt-2{padding-top:.5rem}.pt-28{padding-top:7rem}.pt-32{padding-top:8rem}.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.text-left{text-align:left}.text-center{text-align:center}.font-heading{font-family:Bricolage Grotesque,sans-serif}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-relaxed{line-height:1.625}.leading-snug{line-height:1.375}.leading-tight{line-height:1.25}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.no-underline{text-decoration-line:none}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.blur{--tw-blur: blur(8px);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 rgb(0 0 0 / .1)) drop-shadow(0 1px 1px rgb(0 0 0 / .06));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)}.grayscale{--tw-grayscale: grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--color-accent: #1D9E75;--color-accent-light: #25C994;--color-accent-dark: #167A5B;--color-bg: #090909}body.public-site.light-mode{--color-bg: #FAFAFA}body.public-site{overflow:auto!important;background-color:#090909}body.public-site.light-mode{background-color:#fafafa}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root{margin:0;padding:0;width:100%;height:100%;font-family:sans-serif}body{overflow:hidden;background-color:#0d0d1f}.dashboard-fadein{animation:fadeIn .35s ease forwards}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}.hover\:scale-110:hover{--tw-scale-x: 1.1;--tw-scale-y: 1.1;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-80:hover{opacity:.8}.hover\:opacity-90:hover{opacity:.9}.group:hover .group-hover\:w-full{width:100%}@media (min-width: 640px){.sm\:mb-14{margin-bottom:3.5rem}.sm\:mb-20{margin-bottom:5rem}.sm\:block{display:block}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:gap-6{gap:1.5rem}.sm\:divide-x>:not([hidden])~:not([hidden]){--tw-divide-x-reverse: 0;border-right-width:calc(1px * var(--tw-divide-x-reverse));border-left-width:calc(1px * calc(1 - var(--tw-divide-x-reverse)))}.sm\:divide-y-0>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(0px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(0px * var(--tw-divide-y-reverse))}.sm\:p-5{padding:1.25rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-20{padding-top:5rem;padding-bottom:5rem}.sm\:py-24{padding-top:6rem;padding-bottom:6rem}.sm\:pb-24{padding-bottom:6rem}.sm\:pt-32{padding-top:8rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media (min-width: 768px){.md\:col-span-2{grid-column:span 2 / span 2}.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-3{grid-column:span 3 / span 3}.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\:border-l{border-left-width:1px}.lg\:border-t-0{border-top-width:0px}.lg\:px-8{padding-left:2rem;padding-right:2rem}}.weather-show-container{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:auto;position:relative;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;margin:0;padding:0}.weather-toggle-btn{width:50px;height:50px;border-radius:50%;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:20px;cursor:pointer;box-shadow:0 4px 15px #0003;transition:all .3s ease;display:flex;align-items:center;justify-content:center;margin-bottom:10px}.weather-toggle-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #0000004d}.weather-toggle-btn:active{transform:scale(.95)}.weather-panel{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;box-shadow:0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.2);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.weather-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:20px;color:#fff;box-shadow:0 8px 32px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);min-width:300px;max-width:350px;transition:all .3s ease}.weather-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0006}.weather-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.weather-header h3{margin:0 0 8px;font-size:18px;font-weight:600;text-shadow:0 2px 4px rgba(0,0,0,.3);flex:1}.refresh-btn{background:none;border:none;font-size:16px;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;opacity:.7;color:#fff}.refresh-btn:hover{opacity:1;background-color:#ffffff1a}.refresh-btn:disabled{opacity:.3;cursor:not-allowed}.location-info{display:flex;flex-direction:column;gap:2px}.city{font-size:14px;font-weight:500;opacity:.9}.country{font-size:12px;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.timezone{font-size:10px;opacity:.6;font-style:italic}.weather-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.2)}.temperature-section{text-align:left}.temperature{font-size:36px;font-weight:700;line-height:1;margin-bottom:4px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.feels-like{font-size:12px;opacity:.8;font-weight:400}.weather-icon{display:flex;flex-direction:column;align-items:center;gap:4px}.weather-emoji{font-size:48px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));text-shadow:0 2px 4px rgba(0,0,0,.3)}.description{font-size:12px;text-align:center;opacity:.9;font-weight:500;text-transform:capitalize}.weather-details{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;max-height:200px;overflow-y:auto;padding-right:4px}.weather-details::-webkit-scrollbar{width:4px}.weather-details::-webkit-scrollbar-track{background:#ffffff1a;border-radius:2px}.weather-details::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.label{font-size:12px;opacity:.8;font-weight:500}.value{font-size:12px;font-weight:600;opacity:.9}.weather-loading,.weather-error,.weather-placeholder{background:#fffffff2;border-radius:12px;padding:20px;text-align:center;color:#333;box-shadow:0 4px 20px #00000026;min-width:200px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.weather-loading{display:flex;flex-direction:column;align-items:center;gap:12px}.loading-spinner{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.weather-error{color:#d32f2f;font-weight:500}.weather-placeholder{color:#666;font-style:italic}@media (max-width: 768px){.weather-toggle-btn{width:45px;height:45px;font-size:18px}.weather-card{min-width:260px;max-width:300px;padding:16px}.temperature{font-size:28px}.weather-emoji{font-size:36px}.weather-details{max-height:180px}.detail-item .value{font-size:11px}}@media (max-width: 480px){.weather-toggle-btn{width:40px;height:40px;font-size:16px}.weather-card{min-width:240px;max-width:280px;padding:12px}}.weather-card{animation:slideInUp .5s ease-out}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.react-datepicker-wrapper{display:inline-block;padding:0;border:0}.react-datepicker{font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;background-color:#fff;color:#000;border:1px solid #aeaeae;border-radius:.3rem;display:inline-block;position:relative;line-height:initial}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker-popper{z-index:1;line-height:0}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker__header{text-align:center;background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select){border-top-right-radius:.3rem}.react-datepicker__year-dropdown-container--select,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--scroll{display:inline-block;margin:0 15px}.react-datepicker__current-month,.react-datepicker-time__header,.react-datepicker-year-header{margin-top:0;color:#000;font-weight:700;font-size:.944rem}h2.react-datepicker__current-month{padding:0;margin:0}.react-datepicker-time__header{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.react-datepicker__navigation{align-items:center;background:none;display:flex;justify-content:center;text-align:center;cursor:pointer;position:absolute;top:2px;padding:0;border:none;z-index:1;height:32px;width:32px;text-indent:-999em;overflow:hidden}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{position:relative;top:0;display:block;margin-left:auto;margin-right:auto}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover *:before{border-color:#a6a6a6}.react-datepicker__navigation-icon{position:relative;top:-1px;font-size:20px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{transform:rotate(45deg);left:-7px}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{transform:rotate(225deg);right:-7px}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.4rem;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__month{margin:.4rem;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;width:4rem;margin:2px}.react-datepicker__input-time-container{clear:both;width:100%;float:left;margin:5px 0 10px 15px;text-align:left}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{margin-left:5px;display:inline-block}.react-datepicker__time-container{float:right;border-left:1px solid #aeaeae;width:85px}.react-datepicker__time-container--with-today-button{display:inline;border:1px solid #aeaeae;border-radius:.3rem;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{position:relative;background:#fff;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:85px;overflow-x:hidden;margin:0 auto;text-align:center;border-bottom-right-radius:.3rem}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{list-style:none;margin:0;height:calc(195px + .85rem);overflow-y:scroll;padding-right:0;padding-left:0;width:100%;box-sizing:content-box}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{cursor:pointer;background-color:#f0f0f0}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{cursor:default;background-color:transparent}.react-datepicker__week-number{color:#ccc;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__week-number--selected{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{white-space:nowrap;margin-bottom:-8px}.react-datepicker__week{white-space:nowrap}.react-datepicker__day-name,.react-datepicker__day,.react-datepicker__time-name{color:#000;display:inline-block;width:1.7rem;line-height:1.7rem;text-align:center;margin:.166rem}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{border-radius:.3rem;background-color:#f0f0f0}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{border-radius:.3rem;background-color:#3dcc4a;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{position:relative;border-radius:.3rem;background-color:#ff6803;color:#fff}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{visibility:visible;opacity:1}.react-datepicker__day--selected,.react-datepicker__day--in-selecting-range,.react-datepicker__day--in-range,.react-datepicker__month-text--selected,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--selected,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--selected,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--in-range{border-radius:.3rem;background-color:#216ba5;color:#fff}.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{border-radius:.3rem;background-color:#bad9f1;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{cursor:default;color:#ccc}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{position:absolute;bottom:70%;left:50%;transform:translate(-50%);background-color:#333;color:#fff;padding:4px;border-radius:4px;white-space:nowrap;visibility:hidden;opacity:0;transition:visibility 0s,opacity .3s ease-in-out}.react-datepicker__input-container{position:relative;display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{position:absolute;padding:.5rem;box-sizing:content-box}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__year-read-view,.react-datepicker__month-read-view,.react-datepicker__month-year-read-view{border:1px solid transparent;border-radius:.3rem;position:relative}.react-datepicker__year-read-view:hover,.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover{cursor:pointer}.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__year-read-view--down-arrow,.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow{transform:rotate(135deg);right:-16px;top:0}.react-datepicker__year-dropdown,.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown{background-color:#f0f0f0;position:absolute;width:50%;left:25%;top:30px;z-index:1;text-align:center;border-radius:.3rem;border:1px solid #aeaeae}.react-datepicker__year-dropdown:hover,.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover{cursor:pointer}.react-datepicker__year-dropdown--scrollable,.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__year-option,.react-datepicker__month-option,.react-datepicker__month-year-option{line-height:20px;width:100%;display:block;margin-left:auto;margin-right:auto}.react-datepicker__year-option:first-of-type,.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__year-option:last-of-type,.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type{-webkit-user-select:none;-moz-user-select:none;user-select:none;border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem}.react-datepicker__year-option:hover,.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover{background-color:#ccc}.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__year-option--selected,.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected{position:absolute;left:15px}.react-datepicker__close-icon{cursor:pointer;background-color:transparent;border:0;outline:0;padding:0 6px 0 0;position:absolute;top:0;right:0;height:100%;display:table-cell;vertical-align:middle}.react-datepicker__close-icon:after{cursor:pointer;background-color:#216ba5;color:#fff;border-radius:50%;height:16px;width:16px;padding:2px;font-size:12px;line-height:1;text-align:center;display:table-cell;vertical-align:middle;content:"×"}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{cursor:default;background-color:#ccc}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;cursor:pointer;text-align:center;font-weight:700;padding:5px 0;clear:left}.react-datepicker__portal{position:fixed;width:100vw;height:100vh;background-color:#000c;left:0;top:0;justify-content:center;align-items:center;display:flex;z-index:2147483647}.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:3rem;line-height:3rem}@media (max-width: 400px),(max-height: 550px){.react-datepicker__portal .react-datepicker__day-name,.react-datepicker__portal .react-datepicker__day,.react-datepicker__portal .react-datepicker__time-name{width:2rem;line-height:2rem}}.react-datepicker__portal .react-datepicker__current-month,.react-datepicker__portal .react-datepicker-time__header{font-size:1.44rem}.react-datepicker__children-container{width:13.8rem;margin:.4rem;padding-right:.2rem;padding-left:.2rem;height:auto}.react-datepicker__aria-live{position:absolute;clip-path:circle(0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;width:1px;white-space:nowrap}.react-datepicker__calendar-icon{width:1em;height:1em;vertical-align:-.125em}.ifc-planning-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;max-height:calc(100vh - 40px);overflow:hidden;z-index:1000;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.ifc-planning-panel:active{box-shadow:0 12px 40px #00ffff4d}.datepicker-wrapper,.react-datepicker-wrapper,.react-datepicker__input-container{width:100%;display:flex;align-items:stretch}.react-datepicker__input-container input{width:100%!important;height:100%!important}.datepicker-popper{z-index:10000!important}.react-datepicker__popper{padding-top:0!important;margin-top:0!important}.react-datepicker__popper[data-placement^=bottom]{padding-top:8px!important;margin-top:0!important}.react-datepicker__popper[data-placement^=bottom] .react-datepicker{margin-top:0!important}.react-datepicker{background:#1a1a2e!important;border:1px solid rgba(0,255,255,.2)!important;border-radius:8px!important;font-family:inherit!important}.react-datepicker__header{background:#00ffff1a!important;border-bottom:1px solid rgba(0,255,255,.2)!important;border-radius:8px 8px 0 0!important}.react-datepicker__current-month,.react-datepicker__day-name,.react-datepicker__day{color:#fff!important}.react-datepicker__day:hover{background:#00ffff4d!important;color:#fff!important}.react-datepicker__day--selected{background:#0ff!important;color:#000!important}.react-datepicker__day--keyboard-selected{background:#0ff3!important;color:#fff!important}.react-datepicker__day--disabled{color:#ffffff4d!important}.ifc-planning-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none;flex-shrink:0}.ifc-planning-header:active{background:#00ffff0d}.ifc-planning-header .header-title{display:flex;align-items:center;gap:10px}.ifc-planning-header .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.ifc-planning-header:hover .drag-handle{color:#0ff9}.ifc-planning-header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.ifc-planning-header .icon{font-size:24px}.ifc-planning-header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.ifc-planning-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.ifc-planning-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.ifc-planning-model-name{margin-top:8px;font-size:12px;color:#fff9}.ifc-planning-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:16px 20px;background:#0003;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.stat-item{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:#ffffffe6}.stat-color{width:12px;height:12px;border-radius:2px;flex-shrink:0}.ifc-planning-construction-slider{padding:20px 24px;background:#ffffff05;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:0;flex-shrink:0}.date-nav-button{flex-shrink:0;outline:none}.date-nav-button:not(:disabled):hover{box-shadow:0 2px 8px #00ffff4d!important}.date-nav-button:not(:disabled):active{transform:scale(.95)!important}.ifc-planning-construction-slider label{display:block;font-size:14px;font-weight:600;color:#0ff;margin-bottom:12px}.ifc-planning-construction-slider input[type=date]{width:100%;padding:10px 12px;border:1px solid rgba(0,255,255,.2);border-radius:8px;background:#00ffff0d;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.ifc-planning-construction-slider input[type=date]:hover{background:#00ffff1a;border-color:#0ff6}.ifc-planning-construction-slider input[type=date]:focus{outline:none;border-color:#0ff;box-shadow:0 0 0 2px #0ff3}.ifc-planning-parts-list{flex:1;overflow-y:auto;padding:12px 20px;min-height:0}.ifc-planning-parts-list::-webkit-scrollbar{width:6px}.ifc-planning-parts-list::-webkit-scrollbar-track{background:#0003}.ifc-planning-parts-list::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.ifc-planning-parts-list::-webkit-scrollbar-thumb:hover{background:#00ffff80}.no-parts{padding:40px 20px;text-align:center;color:#fff9;font-size:14px}.part-item{margin-bottom:8px;border:1px solid rgba(0,255,255,.2);border-radius:8px;background:#00ffff0d;overflow:hidden;transition:all .2s ease}.part-item:hover{background:#00ffff14;border-color:#00ffff4d}.part-header{display:flex;align-items:center;gap:10px;padding:12px 14px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:background-color .2s}.part-header:hover{background-color:#00ffff1a}.part-status-indicator{width:10px;height:10px;border-radius:50%;flex-shrink:0;box-shadow:0 0 4px currentColor}.part-name{flex:1;font-size:13px;font-weight:500;color:#ffffffe6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.part-toggle{font-size:12px;color:#ffffff80;flex-shrink:0}.part-details{padding:14px;border-top:1px solid rgba(0,255,255,.2);background:#0003;display:flex;flex-direction:column;gap:12px}.part-field{display:flex;flex-direction:column;gap:6px}.part-field label{font-size:12px;font-weight:500;color:#ffffffb3}.part-field span{font-size:13px;color:#ffffffe6}.status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.status-onTime{background-color:#22c55e33;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.status-nearDeadline{background-color:#eab30833;color:#eab308;border:1px solid rgba(234,179,8,.3)}.status-delayed{background-color:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.status-notStarted{background-color:#9ca3af33;color:#9ca3af;border:1px solid rgba(156,163,175,.3)}.ifc-planning-actions{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:8px;background:#0003;flex-shrink:0}.ifc-planning-actions div{font-size:11px;color:#ffffff80;text-align:center;line-height:1.6}.resize-handle{position:absolute;bottom:0;right:0;width:20px;height:20px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(0,255,255,.3) 40%,rgba(0,255,255,.3) 45%,transparent 45%,transparent 60%,rgba(0,255,255,.3) 60%,rgba(0,255,255,.3) 65%,transparent 65%);border-bottom-right-radius:16px;z-index:10;transition:background .2s ease}.resize-handle:hover{background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(0,255,255,.6) 40%,rgba(0,255,255,.6) 45%,transparent 45%,transparent 60%,rgba(0,255,255,.6) 60%,rgba(0,255,255,.6) 65%,transparent 65%)}.model-selector{margin-top:12px}.model-selector label{font-size:12px;color:#fff9;margin-right:8px}.model-selector select{width:100%;padding:8px 12px;border:1px solid rgba(0,255,255,.2);border-radius:8px;background:#00ffff0d;color:#fff;font-size:12px;cursor:pointer;transition:all .3s ease;margin-top:6px}.model-selector select:hover{background:#00ffff1a;border-color:#0ff6}.model-selector select:focus{outline:none;border-color:#0ff;box-shadow:0 0 0 2px #0ff3}.model-selector select option{background:#16213e;color:#fff}@media (max-width: 768px){.ifc-planning-panel{width:calc(100% - 40px)!important;left:20px!important;height:calc(100vh - 80px)!important}}.capas-panel{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;position:relative;z-index:9999;pointer-events:auto}.capas-panel{display:block!important;visibility:visible!important;opacity:1!important}.capas-panel-header{cursor:move;-webkit-user-select:none;-moz-user-select:none;user-select:none}.capas-panel-header:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1)!important}.close-btn{transition:all .2s ease}.close-btn:hover{background:#ffffff4d!important;transform:scale(1.1);box-shadow:0 2px 8px #0003}.group-header.clickable{cursor:pointer}.group-header.clickable:hover{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)!important;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.group-icon{transition:transform .2s ease}.group-header.clickable:hover .group-icon{transform:scale(1.1)}.action-btn:hover{background:#3b82f633!important;transform:scale(1.05);box-shadow:0 2px 8px #3b82f64d}.layer-item:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;transform:translate(2px);box-shadow:0 2px 8px #0000000a}.layer-item:hover .layer-name{color:#1f2937!important}.checkbox{cursor:pointer;transform:scale(1.1);transition:all .2s ease}.checkbox:checked{accent-color:#3b82f6;transform:scale(1.2)}.checkbox:hover{transform:scale(1.15)}.status-dot{transition:all .2s ease}.status-dot.visible{background:#10b981;box-shadow:0 0 0 2px #10b98133}.status-dot.hidden{background:#ef4444;box-shadow:0 0 0 2px #ef444433}.group-content{max-height:0;overflow:hidden;transition:max-height .3s ease;opacity:0}.group-content.expanded{max-height:300px;opacity:1}.group-badge{animation:badgePulse 3s infinite;position:relative}.group-badge:before{content:"";position:absolute;inset:-2px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:14px;z-index:-1;opacity:.3;animation:badgeGlow 2s infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes badgeGlow{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.6;transform:scale(1.1)}}.empty-state{animation:fadeIn .5s ease;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:8px;margin:8px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.content::-webkit-scrollbar,.capas-content-scroll::-webkit-scrollbar{width:8px}.content::-webkit-scrollbar-track,.capas-content-scroll::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px;margin:4px 0}.content::-webkit-scrollbar-thumb,.capas-content-scroll::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#94a3b8,#64748b);border-radius:4px;border:2px solid #f1f5f9}.content::-webkit-scrollbar-thumb:hover,.capas-content-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#64748b,#475569)}.content,.capas-content-scroll{scrollbar-width:thin;scrollbar-color:#94a3b8 #f1f5f9}@media (max-width: 768px){.capas-panel{width:100%!important;max-width:320px}.group-header{padding:10px 12px}.layer-item{padding:8px 12px}}.capas-panel *{box-sizing:border-box}.group-header,.layer-item{-webkit-user-select:none;-moz-user-select:none;user-select:none}.checkbox{cursor:pointer}.layer-name{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.subcategory-indicator{position:relative}.subcategory-indicator:before{content:"";position:absolute;left:-16px;top:50%;width:12px;height:2px;background:currentColor;opacity:.3}.capas-content-scroll{scroll-behavior:smooth}.capas-content-scroll:after{content:"";position:sticky;bottom:0;left:0;right:0;height:20px;background:linear-gradient(to top,rgba(255,255,255,.9) 0%,transparent 100%);pointer-events:none;display:block}.subcategory-border{position:relative;padding-left:8px}.subcategory-border:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:currentColor;opacity:.2;border-radius:2px}.panoramic-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.panoramic-container{width:95vw;height:90vh;background:#1a1a1a;border-radius:12px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;overflow:hidden;border:1px solid #333}.panoramic-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#2a2a2a,#1a1a1a);border-bottom:1px solid #333;flex-shrink:0}.panoramic-title{color:#fff;font-size:18px;font-weight:600;margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.panoramic-controls{display:flex;align-items:center;gap:8px}.control-btn{background:#3b82f6;color:#fff;border:none;border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:16px;font-weight:700;transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.control-btn:hover{background:#2563eb;transform:translateY(-1px)}.control-btn:active{transform:translateY(0)}.reset-btn{background:#10b981}.reset-btn:hover{background:#059669}.close-btn{background:#ef4444}.close-btn:hover{background:#dc2626}.zoom-level{color:#fff;font-size:14px;font-weight:500;min-width:50px;text-align:center;background:#374151;padding:6px 12px;border-radius:6px;border:1px solid #4b5563}.panoramic-image-container{flex:1;overflow:hidden;position:relative;background:#000;display:flex;align-items:center;justify-content:center}.panoramic-image{max-width:none;max-height:none;width:auto;height:auto;transition:transform .1s ease-out;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none}.panoramic-instructions{padding:12px 20px;background:#1a1a1a;border-top:1px solid #333;text-align:center;flex-shrink:0}.panoramic-instructions p{color:#9ca3af;font-size:12px;margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}@media (max-width: 768px){.panoramic-container{width:100vw;height:100vh;border-radius:0}.panoramic-header{padding:12px 16px}.panoramic-title{font-size:16px}.control-btn{width:28px;height:28px;font-size:14px}.zoom-level{font-size:12px;padding:4px 8px}.panoramic-instructions{padding:8px 16px}.panoramic-instructions p{font-size:11px}}@keyframes fadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.panoramic-container{animation:fadeIn .3s ease-out}.panoramic-image-container::-webkit-scrollbar{width:8px;height:8px}.panoramic-image-container::-webkit-scrollbar-track{background:#2a2a2a}.panoramic-image-container::-webkit-scrollbar-thumb{background:#4b5563;border-radius:4px}.panoramic-image-container::-webkit-scrollbar-thumb:hover{background:#6b7280}.item-panel-full-height{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:340px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.item-panel-full-height:active{box-shadow:0 12px 40px #00ffff4d}.item-panel-full-height.expanded{max-height:calc(100vh - 80px)}.item-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.item-panel .header:active{background:#00ffff0d}.item-panel .header-title{display:flex;align-items:center;gap:10px}.item-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.item-panel .header:hover .drag-handle{color:#0ff9}.item-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.item-panel .header-title .icon{font-size:24px}.item-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.item-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.item-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.item-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.item-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.item-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.item-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.item-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.item-panel .tab-content::-webkit-scrollbar{width:6px}.item-panel .tab-content::-webkit-scrollbar-track{background:#0003}.item-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.item-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.item-panel .camera-image-container{margin-bottom:16px;border-radius:12px;overflow:hidden;border:1px solid rgba(0,255,255,.2);box-shadow:0 4px 12px #00ffff1a}.item-panel .camera-image{width:100%;display:block;transition:transform .3s ease}.item-panel .camera-image:hover{transform:scale(1.02)}.item-panel .description{font-size:13px;margin-bottom:16px;color:#ffffffb3;line-height:1.5}.item-panel .section-title{margin:16px 0 12px;font-size:16px;font-weight:600;color:#0ff}.item-panel .dropdown-label{font-size:13px;margin-bottom:8px;display:block;color:#fffc;font-weight:500}.item-panel .dropdown{width:100%;padding:10px 12px;margin-bottom:16px;border-radius:8px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);color:#fff;font-size:14px;transition:all .3s ease}.item-panel .dropdown:hover{background:#00ffff1a;border-color:#0ff6}.item-panel .dropdown:focus{outline:none;border-color:#0ff;box-shadow:0 0 0 2px #0ff3}.item-panel .dropdown option{background:#16213e;color:#fff}.item-panel .actions-container{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);background:#0003;display:flex;flex-direction:column;gap:10px}.item-panel .action-button{background:#00ffff1a;color:#0ff;border:1px solid rgba(0,255,255,.3);padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.item-panel .action-button:hover{background:#0ff3;border-color:#00ffff80;transform:translateY(-1px);box-shadow:0 4px 12px #0ff3}.item-panel .action-button.primary{background:#0ff3;border-color:#0ff}.item-panel .action-button.primary:hover{background:#00ffff4d;box-shadow:0 4px 16px #0ff6}@media (max-width: 768px){.item-panel-full-height{width:calc(100% - 40px);left:20px!important;right:20px}}.maintenance-panel{background:#2a2a2a;color:#fff;padding:10px;border-radius:8px;font-size:12px;overflow-y:auto;max-height:300px}.info-grid{display:grid;grid-template-columns:1fr;gap:6px;margin-bottom:10px}.maintenance-panel table{width:100%;border-collapse:collapse;margin-bottom:10px;font-size:12px}.maintenance-panel th,.maintenance-panel td{border:1px solid #444;padding:4px;text-align:left}.maintenance-panel ul{padding-left:16px}.planning-window-wrapper{z-index:9999;position:absolute;box-shadow:0 0 20px #0009;border-radius:8px;overflow:hidden}.planning-window-content{display:flex;flex-direction:column;height:100%;width:100%;background-color:#1e1e1e;border-radius:8px}.planning-window-header{background-color:#1e1e1e;color:#fff;padding:10px;font-weight:700;display:flex;justify-content:space-between;align-items:center;cursor:move}.planning-window-body{flex:1;overflow:auto;padding:10px;background-color:#1e1e1e}.close-btn{background:#b02e2e;border:none;color:#fff;font-size:18px;cursor:pointer}.transformer-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:480px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.transformer-panel:active{box-shadow:0 12px 40px #00ffff4d}.transformer-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.transformer-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.transformer-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.transformer-panel .header:active{background:#00ffff0d}.transformer-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.transformer-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.transformer-panel .header:hover .drag-handle{color:#0ff9}.transformer-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.transformer-panel .header-title .icon{font-size:24px;animation:pulse 2s ease-in-out infinite}.transformer-panel .header h3{margin:0;font-size:16px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.transformer-panel .header-actions{display:flex;align-items:center;gap:10px}.transformer-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.transformer-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.transformer-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.transformer-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.transformer-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.transformer-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.transformer-panel .tab-content::-webkit-scrollbar{width:6px}.transformer-panel .tab-content::-webkit-scrollbar-track{background:#0003}.transformer-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.transformer-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.transformer-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.transformer-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.transformer-panel .last-update{font-size:11px;color:#ffffff80}.transformer-panel .data-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.transformer-panel .data-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;transition:all .3s ease}.transformer-panel .data-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.transformer-panel .data-label{font-size:11px;color:#fff9;margin-bottom:6px;font-weight:500}.transformer-panel .data-value{font-size:22px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.transformer-panel .data-value.temperature{color:#f59e0b}.transformer-panel .data-value .unit{font-size:13px;font-weight:500;color:#ffffff80}.transformer-panel .info-grid{display:flex;flex-direction:column;gap:12px}.transformer-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.transformer-panel .info-row:hover{background:#ffffff0d}.transformer-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.transformer-panel .info-value{font-size:14px;color:#fff;font-weight:600}.transformer-panel .info-value.maintenance{color:#f59e0b}.transformer-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.transformer-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.transformer-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.transformer-panel .documents-list{display:flex;flex-direction:column;gap:10px}.transformer-panel .document-item{display:flex;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.transformer-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.transformer-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.transformer-panel .document-info{flex:1;min-width:0}.transformer-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.transformer-panel .document-meta{display:flex;flex-direction:column;gap:2px}.transformer-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-all}.transformer-panel .file-date{font-size:11px;color:#fff6}.transformer-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.transformer-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}.transformer-panel .no-documents{text-align:center;padding:40px 20px;color:#ffffff80}.transformer-panel .no-documents p{margin:8px 0;font-size:14px}.transformer-panel .no-documents-hint{font-size:12px;color:#00ffff80;font-style:italic}.transformer-panel .no-info{text-align:center;padding:40px 20px;color:#ffffff80}.transformer-panel .no-info p{margin:8px 0;font-size:14px}.transformer-panel .no-info-hint{font-size:12px;color:#00ffff80;font-style:italic}@media (max-width: 768px){.transformer-panel{width:calc(100% - 40px);left:20px;right:20px}.transformer-panel .data-grid{grid-template-columns:1fr}}.solar-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:480px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.solar-panel:active{box-shadow:0 12px 40px #00ffff4d}.solar-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.solar-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.solar-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.solar-panel .header:active{background:#00ffff0d}.solar-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.solar-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.solar-panel .header:hover .drag-handle{color:#0ff9}.solar-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.solar-panel .header-title .icon{font-size:24px;animation:pulse 2s ease-in-out infinite}.solar-panel .header h3{margin:0;font-size:16px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.solar-panel .header-actions{display:flex;align-items:center;gap:10px}.solar-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.solar-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.solar-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.solar-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.solar-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.solar-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.solar-panel .tab-content::-webkit-scrollbar{width:6px}.solar-panel .tab-content::-webkit-scrollbar-track{background:#0003}.solar-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.solar-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.solar-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.solar-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.solar-panel .last-update{font-size:11px;color:#ffffff80}.solar-panel .data-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.solar-panel .data-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;transition:all .3s ease}.solar-panel .data-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.solar-panel .data-label{font-size:11px;color:#fff9;margin-bottom:6px;font-weight:500}.solar-panel .data-value{font-size:22px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.solar-panel .data-value.temperature{color:#f59e0b}.solar-panel .data-value.energy{color:#10b981}.solar-panel .data-value.irradiance,.solar-panel .data-value.efficiency{color:#0ff}.solar-panel .data-value .unit{font-size:13px;font-weight:500;color:#ffffff80}.solar-panel .info-grid{display:flex;flex-direction:column;gap:12px}.solar-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.solar-panel .info-row:hover{background:#ffffff0d}.solar-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.solar-panel .info-value{font-size:14px;color:#fff;font-weight:600}.solar-panel .info-value.maintenance{color:#f59e0b}.solar-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.solar-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.solar-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.solar-panel .documents-list{display:flex;flex-direction:column;gap:10px}.solar-panel .document-item{display:flex;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.solar-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.solar-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.solar-panel .document-info{flex:1;min-width:0}.solar-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.solar-panel .document-meta{display:flex;flex-direction:column;gap:2px}.solar-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-all}.solar-panel .file-date{font-size:11px;color:#fff6}.solar-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.solar-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}.solar-panel .no-documents{text-align:center;padding:40px 20px;color:#ffffff80}.solar-panel .no-documents p{margin:8px 0;font-size:14px}.solar-panel .no-documents-hint{font-size:12px;color:#00ffff80;font-style:italic}.solar-panel .no-info{text-align:center;padding:40px 20px;color:#ffffff80}.solar-panel .no-info p{margin:8px 0;font-size:14px}.solar-panel .no-info-hint{font-size:12px;color:#00ffff80;font-style:italic}.solar-panel .alert-indicator{padding:8px 16px;font-size:12px;font-weight:700;text-align:center;border-radius:8px;margin:12px 20px;animation:pulse-alert 2s ease-in-out infinite}.solar-panel .alert-indicator.alert-critical{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.5)}.solar-panel .alert-indicator.alert-warning{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.5)}@keyframes pulse-alert{0%,to{opacity:1}50%{opacity:.7}}.solar-panel .data-value.alert-critical{color:#ef4444!important}.solar-panel .data-value.alert-warning{color:#f59e0b!important}.solar-panel .alerts-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.solar-panel .alerts-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.solar-panel .alerts-subtitle{margin:0;font-size:12px;color:#ffffff80}.solar-panel .alerts-list{display:flex;flex-direction:column;gap:10px}.solar-panel .alert-item{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#ffffff08;border-radius:10px;border-left:4px solid;transition:all .3s ease}.solar-panel .alert-item.alert-critical{border-left-color:#ef4444;background:#ef44440d}.solar-panel .alert-item.alert-warning{border-left-color:#f59e0b;background:#f59e0b0d}.solar-panel .alert-item:hover{background:#ffffff0d;transform:translate(2px)}.solar-panel .alert-item.alert-critical:hover{background:#ef44441a}.solar-panel .alert-item.alert-warning:hover{background:#f59e0b1a}.solar-panel .alert-icon{font-size:24px;flex-shrink:0}.solar-panel .alert-content{flex:1;min-width:0}.solar-panel .alert-title{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.solar-panel .alert-item.alert-critical .alert-title{color:#ef4444}.solar-panel .alert-item.alert-warning .alert-title{color:#f59e0b}.solar-panel .alert-message{font-size:12px;color:#ffffffb3;margin-bottom:6px;line-height:1.4}.solar-panel .alert-timestamp{font-size:11px;color:#fff6;font-family:Courier New,monospace}.solar-panel .alert-action{font-size:20px;flex-shrink:0;color:#ffffff80}.solar-panel .alert-item.alert-critical .alert-action{color:#ef4444}.solar-panel .alert-item.alert-warning .alert-action{color:#f59e0b}.solar-panel .alert-badge{display:inline-block;background:#ef4444;color:#fff;border-radius:10px;padding:2px 6px;font-size:10px;font-weight:600;margin-left:4px}.solar-panel .no-alerts{text-align:center;padding:40px 20px;color:#ffffff80}.solar-panel .no-alerts p{margin:8px 0;font-size:14px}.solar-panel .no-alerts-hint{font-size:12px;color:#00ffff80;font-style:italic}@media (max-width: 768px){.solar-panel{width:calc(100% - 40px);left:20px;right:20px}.solar-panel .data-grid{grid-template-columns:1fr}}.pipeline-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:450px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pipeline-panel:active{box-shadow:0 12px 40px #00ffff4d}.pipeline-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.pipeline-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.pipeline-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pipeline-panel .header:active{background:#00ffff0d}.pipeline-panel .header-title{display:flex;align-items:center;gap:10px}.pipeline-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.pipeline-panel .header:hover .drag-handle{color:#0ff9}.pipeline-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.pipeline-panel .header-title .icon{font-size:24px}.pipeline-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.pipeline-panel .header-actions{display:flex;align-items:center;gap:10px}.pipeline-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.pipeline-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.pipeline-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.pipeline-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.pipeline-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.pipeline-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.pipeline-panel .tab-content::-webkit-scrollbar{width:6px}.pipeline-panel .tab-content::-webkit-scrollbar-track{background:#0003}.pipeline-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.pipeline-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.pipeline-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.pipeline-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.pipeline-panel .last-update{font-size:11px;color:#ffffff80}.pipeline-panel .sensors-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.pipeline-panel .sensor-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.pipeline-panel .sensor-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.pipeline-panel .sensor-card.alerta{background:#f59e0b1a;border-color:#f59e0b4d}.pipeline-panel .sensor-card.alerta:hover{background:#f59e0b26;box-shadow:0 4px 12px #f59e0b4d}.pipeline-panel .sensor-icon{font-size:32px;line-height:1}.pipeline-panel .sensor-info{flex:1}.pipeline-panel .sensor-label{font-size:11px;color:#fff9;margin-bottom:4px;font-weight:500}.pipeline-panel .sensor-value{font-size:20px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.pipeline-panel .sensor-card.alerta .sensor-value{color:#f59e0b}.pipeline-panel .sensor-value .unit{font-size:12px;font-weight:500;color:#ffffff80}.pipeline-panel .info-grid{display:flex;flex-direction:column;gap:12px}.pipeline-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.pipeline-panel .info-row:hover{background:#ffffff0d}.pipeline-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.pipeline-panel .info-value{font-size:14px;color:#fff;font-weight:600}.pipeline-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.pipeline-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.pipeline-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.pipeline-panel .documents-list{display:flex;flex-direction:column;gap:10px}.pipeline-panel .document-item{display:flex;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.pipeline-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.pipeline-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.pipeline-panel .document-info{flex:1;min-width:0}.pipeline-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.pipeline-panel .document-meta{display:flex;flex-direction:column;gap:2px}.pipeline-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-all}.pipeline-panel .file-date{font-size:11px;color:#fff6}.pipeline-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.pipeline-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}@media (max-width: 768px){.pipeline-panel{width:calc(100% - 40px);left:20px!important;right:20px}.pipeline-panel .sensors-grid{grid-template-columns:1fr}}.valve-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:440px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.valve-panel:active{box-shadow:0 12px 40px #00ffff4d}.valve-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.valve-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.valve-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.valve-panel .header:active{background:#00ffff0d}.valve-panel .header-title{display:flex;align-items:center;gap:10px}.valve-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.valve-panel .header:hover .drag-handle{color:#0ff9}.valve-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.valve-panel .header-title .icon{font-size:24px}.valve-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.valve-panel .header-actions{display:flex;align-items:center;gap:10px}.valve-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.valve-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.valve-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.valve-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.valve-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.valve-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.valve-panel .tab-content::-webkit-scrollbar{width:6px}.valve-panel .tab-content::-webkit-scrollbar-track{background:#0003}.valve-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.valve-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.valve-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.valve-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.valve-panel .last-update{font-size:11px;color:#ffffff80}.valve-panel .valve-position-indicator{margin-bottom:20px;padding:16px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px}.valve-panel .position-label{font-size:13px;color:#fffc;margin-bottom:10px;font-weight:600}.valve-panel .position-bar{position:relative;height:40px;background:#0000004d;border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.valve-panel .position-fill{height:100%;background:linear-gradient(90deg,#0ff,#0c9);border-radius:20px;display:flex;align-items:center;justify-content:flex-end;padding-right:16px;transition:width .5s ease;box-shadow:0 0 20px #0ff6}.valve-panel .position-value{font-size:16px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.valve-panel .position-markers{display:flex;justify-content:space-between;margin-top:6px;font-size:11px;color:#ffffff80}.valve-panel .sensors-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.valve-panel .sensor-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.valve-panel .sensor-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.valve-panel .sensor-card.full-width{grid-column:1 / -1}.valve-panel .sensor-icon{font-size:28px;line-height:1}.valve-panel .sensor-info{flex:1}.valve-panel .sensor-label{font-size:11px;color:#fff9;margin-bottom:4px;font-weight:500}.valve-panel .sensor-value{font-size:18px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.valve-panel .sensor-value.temperature{color:#f59e0b}.valve-panel .sensor-value .unit{font-size:11px;font-weight:500;color:#ffffff80}.valve-panel .info-grid{display:flex;flex-direction:column;gap:12px}.valve-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.valve-panel .info-row:hover{background:#ffffff0d}.valve-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.valve-panel .info-value{font-size:14px;color:#fff;font-weight:600;text-align:right}.valve-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.valve-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.valve-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.valve-panel .documents-list{display:flex;flex-direction:column;gap:10px}.valve-panel .document-item{display:flex;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.valve-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.valve-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.valve-panel .document-info{flex:1;min-width:0}.valve-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.valve-panel .document-meta{display:flex;flex-direction:column;gap:2px}.valve-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-all}.valve-panel .file-date{font-size:11px;color:#fff6}.valve-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.valve-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}@media (max-width: 768px){.valve-panel{width:calc(100% - 40px);left:20px!important;right:20px}.valve-panel .sensors-grid{grid-template-columns:1fr}}.bridge-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:480px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bridge-panel:active{box-shadow:0 12px 40px #00ffff4d}.bridge-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.bridge-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.bridge-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.bridge-panel .header:active{background:#00ffff0d}.bridge-panel .header-title{display:flex;align-items:center;gap:10px}.bridge-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.bridge-panel .header:hover .drag-handle{color:#0ff9}.bridge-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.bridge-panel .header-title .icon{font-size:24px}.bridge-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.bridge-panel .header-actions{display:flex;align-items:center;gap:10px}.bridge-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.bridge-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.bridge-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.bridge-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.bridge-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.bridge-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.bridge-panel .tab-content::-webkit-scrollbar{width:6px}.bridge-panel .tab-content::-webkit-scrollbar-track{background:#0003}.bridge-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.bridge-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.bridge-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.bridge-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.bridge-panel .last-update{font-size:11px;color:#ffffff80}.bridge-panel .load-indicator{margin-bottom:20px;padding:16px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px}.bridge-panel .load-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.bridge-panel .load-label{font-size:13px;color:#fffc;font-weight:600}.bridge-panel .load-value{font-size:14px;color:#0ff;font-weight:700}.bridge-panel .load-bar{position:relative;height:35px;background:#0000004d;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.bridge-panel .load-fill{height:100%;border-radius:18px;display:flex;align-items:center;justify-content:flex-end;padding-right:14px;transition:width .5s ease,background .3s ease;position:relative}.bridge-panel .load-fill.normal{background:linear-gradient(90deg,#10b981,#059669);box-shadow:0 0 15px #10b98166}.bridge-panel .load-fill.warning{background:linear-gradient(90deg,#f59e0b,#d97706);box-shadow:0 0 15px #f59e0b66;animation:pulse-warning 2s ease-in-out infinite}.bridge-panel .load-fill.critical{background:linear-gradient(90deg,#ef4444,#dc2626);box-shadow:0 0 20px #ef444480;animation:pulse-critical 1.5s ease-in-out infinite}.bridge-panel .load-percentage{font-size:14px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.bridge-panel .load-markers{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:10px;color:#ffffff80;position:relative}.bridge-panel .marker-70,.bridge-panel .marker-85{position:absolute;color:#f59e0bcc;font-weight:600}.bridge-panel .marker-70{left:70%;transform:translate(-50%)}.bridge-panel .marker-85{left:85%;transform:translate(-50%);color:#ef4444cc}.bridge-panel .sensors-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.bridge-panel .sensor-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.bridge-panel .sensor-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.bridge-panel .sensor-card.vibration{flex-direction:column;align-items:flex-start}.bridge-panel .sensor-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.bridge-panel .vibration-data{width:100%;display:flex;flex-direction:column;gap:6px}.bridge-panel .vibration-axis{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:#0003;border-radius:6px}.bridge-panel .axis-label{font-size:12px;color:#fff9;font-weight:600}.bridge-panel .axis-value{font-size:13px;color:#0ff;font-weight:600}.bridge-panel .sensor-card.full-width{grid-column:1 / -1}.bridge-panel .sensor-icon{font-size:28px;line-height:1}.bridge-panel .sensor-info{flex:1}.bridge-panel .sensor-label{font-size:11px;color:#fff9;margin-bottom:4px;font-weight:500}.bridge-panel .sensor-value{font-size:18px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.bridge-panel .sensor-value.temperature{color:#f59e0b}.bridge-panel .sensor-value.crack{color:#ef4444}.bridge-panel .sensor-value .unit{font-size:11px;font-weight:500;color:#ffffff80}.bridge-panel .info-grid{display:flex;flex-direction:column;gap:12px}.bridge-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.bridge-panel .info-row:hover{background:#ffffff0d}.bridge-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.bridge-panel .info-value{font-size:14px;color:#fff;font-weight:600;text-align:right}.bridge-panel .info-value.inspection{color:#10b981}.bridge-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.bridge-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.bridge-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.bridge-panel .documents-list{display:flex;flex-direction:column;gap:10px}.bridge-panel .document-item{display:flex;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.bridge-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.bridge-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.bridge-panel .document-info{flex:1;min-width:0}.bridge-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.bridge-panel .document-meta{display:flex;flex-direction:column;gap:2px}.bridge-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-all}.bridge-panel .file-date{font-size:11px;color:#fff6}.bridge-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.bridge-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}.bridge-panel .alert-count{background:#ef4444;color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;margin-left:4px;animation:pulse-alert 1s ease-in-out infinite}@keyframes pulse-alert{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.bridge-panel .alerts-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.bridge-panel .alerts-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.bridge-panel .alerts-subtitle{margin:0;font-size:12px;color:#ffffff80}.bridge-panel .no-alerts{text-align:center;padding:40px 20px;color:#fff9}.bridge-panel .no-alerts-icon{font-size:48px;margin-bottom:16px}.bridge-panel .no-alerts h5{margin:0 0 8px;font-size:16px;color:#10b981;font-weight:600}.bridge-panel .no-alerts p{margin:0;font-size:13px}.bridge-panel .alerts-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.bridge-panel .alert-item{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;transition:all .3s ease}.bridge-panel .alert-item.warning{border-left:4px solid #f59e0b;background:#f59e0b0d;animation:pulse-warning-border 2s ease-in-out infinite}.bridge-panel .alert-item.critical{border-left:4px solid #ef4444;background:#ef44440d;animation:pulse-critical-border 1.5s ease-in-out infinite}@keyframes pulse-warning-border{0%,to{border-left-color:#f59e0b}50%{border-left-color:#d97706}}@keyframes pulse-critical-border{0%,to{border-left-color:#ef4444}50%{border-left-color:#dc2626}}.bridge-panel .alert-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.bridge-panel .alert-icon{font-size:24px;line-height:1}.bridge-panel .alert-info{flex:1}.bridge-panel .alert-sensor{font-size:14px;font-weight:600;color:#fff;margin-bottom:2px}.bridge-panel .alert-timestamp{font-size:11px;color:#ffffff80}.bridge-panel .alert-status{font-size:11px;font-weight:700;padding:4px 8px;border-radius:6px;text-transform:uppercase}.bridge-panel .alert-item.warning .alert-status{background:#f59e0b33;color:#f59e0b}.bridge-panel .alert-item.critical .alert-status{background:#ef444433;color:#ef4444}.bridge-panel .alert-content{margin-top:8px}.bridge-panel .alert-message{font-size:13px;color:#fff;margin-bottom:8px;font-weight:500}.bridge-panel .alert-threshold{display:flex;justify-content:space-between;font-size:11px;color:#fff9;font-family:Courier New,monospace}.bridge-panel .alert-thresholds-info{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px}.bridge-panel .alert-thresholds-info h5{margin:0 0 12px;font-size:14px;font-weight:600;color:#0ff}.bridge-panel .thresholds-grid{display:flex;flex-direction:column;gap:8px}.bridge-panel .threshold-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#ffffff08;border-radius:8px}.bridge-panel .threshold-label{font-size:12px;color:#ffffffb3;font-weight:500}.bridge-panel .threshold-value{font-size:11px;color:#ffffff80;font-family:Courier New,monospace}.bridge-panel .sensor-card.warning{border-color:#f59e0b80;background:#f59e0b0d;animation:pulse-sensor-warning 2s ease-in-out infinite}.bridge-panel .sensor-card.critical{border-color:#ef444480;background:#ef44440d;animation:pulse-sensor-critical 1.5s ease-in-out infinite}@keyframes pulse-sensor-warning{0%,to{border-color:#f59e0b80;box-shadow:0 0 #f59e0b33}50%{border-color:#f59e0bcc;box-shadow:0 0 10px #f59e0b66}}@keyframes pulse-sensor-critical{0%,to{border-color:#ef444480;box-shadow:0 0 #ef444433}50%{border-color:#ef4444cc;box-shadow:0 0 15px #ef444480}}.bridge-panel .sensor-alert{position:absolute;top:8px;right:8px;font-size:16px;animation:blink 1s ease-in-out infinite}@media (max-width: 768px){.bridge-panel{width:calc(100% - 40px);left:20px!important;right:20px}.bridge-panel .sensors-grid{grid-template-columns:1fr}}.pump-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:440px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pump-panel:active{box-shadow:0 12px 40px #00ffff4d}.pump-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.pump-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.pump-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pump-panel .header:active{background:#00ffff0d}.pump-panel .header-title{display:flex;align-items:center;gap:10px}.pump-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.pump-panel .header:hover .drag-handle{color:#0ff9}.pump-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.pump-panel .header-title .icon{font-size:24px}.pump-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.pump-panel .header-actions{display:flex;align-items:center;gap:10px}.pump-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.pump-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.pump-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.pump-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.pump-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.pump-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.pump-panel .tab-content::-webkit-scrollbar{width:6px}.pump-panel .tab-content::-webkit-scrollbar-track{background:#0003}.pump-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.pump-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.pump-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.pump-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.pump-panel .last-update{font-size:11px;color:#ffffff80}.pump-panel .sensors-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.pump-panel .sensor-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.pump-panel .sensor-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.pump-panel .sensor-card.full-width{grid-column:1 / -1}.pump-panel .sensor-icon{font-size:28px;line-height:1}.pump-panel .sensor-info{flex:1}.pump-panel .sensor-label{font-size:11px;color:#fff9;margin-bottom:4px;font-weight:500}.pump-panel .sensor-value{font-size:18px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.pump-panel .sensor-value.temperature{color:#f59e0b}.pump-panel .sensor-value .unit{font-size:11px;font-weight:500;color:#ffffff80}.pump-panel .info-grid{display:flex;flex-direction:column;gap:12px}.pump-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.pump-panel .info-row:hover{background:#ffffff0d}.pump-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.pump-panel .info-value{font-size:14px;color:#fff;font-weight:600;text-align:right}.pump-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.pump-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.pump-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.pump-panel .documents-list{display:flex;flex-direction:column;gap:10px}.pump-panel .document-item{display:flex;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.pump-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.pump-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.pump-panel .document-info{flex:1;min-width:0}.pump-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.pump-panel .document-meta{display:flex;flex-direction:column;gap:2px}.pump-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-all}.pump-panel .file-date{font-size:11px;color:#fff6}.pump-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.pump-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}@media (max-width: 768px){.pump-panel{width:calc(100% - 40px);left:20px!important;right:20px}.pump-panel .sensors-grid{grid-template-columns:1fr}}.structure-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:480px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.structure-panel:active{box-shadow:0 12px 40px #00ffff4d}.structure-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.structure-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.structure-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.structure-panel .header:active{background:#00ffff0d}.structure-panel .header-title{display:flex;align-items:center;gap:10px}.structure-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.structure-panel .header:hover .drag-handle{color:#0ff9}.structure-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.structure-panel .header-title .icon{font-size:24px}.structure-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.structure-panel .header-actions{display:flex;align-items:center;gap:10px}.structure-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.structure-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.structure-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.structure-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.structure-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.structure-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.structure-panel .tab-content::-webkit-scrollbar{width:6px}.structure-panel .tab-content::-webkit-scrollbar-track{background:#0003}.structure-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.structure-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.structure-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.structure-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.structure-panel .last-update{font-size:11px;color:#ffffff80}.structure-panel .load-indicator{margin-bottom:20px;padding:16px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px}.structure-panel .load-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.structure-panel .load-label{font-size:13px;color:#fffc;font-weight:600}.structure-panel .load-value{font-size:14px;color:#0ff;font-weight:700}.structure-panel .load-bar{position:relative;height:35px;background:#0000004d;border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.structure-panel .load-fill{height:100%;border-radius:18px;display:flex;align-items:center;justify-content:flex-end;padding-right:14px;transition:width .5s ease,background .3s ease;position:relative}.structure-panel .load-fill.normal{background:linear-gradient(90deg,#10b981,#059669);box-shadow:0 0 15px #10b98166}.structure-panel .load-fill.warning{background:linear-gradient(90deg,#f59e0b,#d97706);box-shadow:0 0 15px #f59e0b66;animation:pulse-warning 2s ease-in-out infinite}.structure-panel .load-fill.critical{background:linear-gradient(90deg,#ef4444,#dc2626);box-shadow:0 0 20px #ef444480;animation:pulse-critical 1.5s ease-in-out infinite}@keyframes pulse-warning{0%,to{box-shadow:0 0 15px #f59e0b66}50%{box-shadow:0 0 25px #f59e0b99}}@keyframes pulse-critical{0%,to{box-shadow:0 0 20px #ef444480}50%{box-shadow:0 0 30px #ef4444cc}}.structure-panel .load-percentage{font-size:14px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5)}.structure-panel .load-markers{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:10px;color:#ffffff80;position:relative}.structure-panel .marker-70,.structure-panel .marker-85{position:absolute;color:#f59e0bcc;font-weight:600}.structure-panel .marker-70{left:70%;transform:translate(-50%)}.structure-panel .marker-85{left:85%;transform:translate(-50%);color:#ef4444cc}.structure-panel .sensors-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.structure-panel .sensor-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.structure-panel .sensor-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.structure-panel .sensor-icon{font-size:28px;line-height:1}.structure-panel .sensor-info{flex:1}.structure-panel .sensor-label{font-size:11px;color:#fff9;margin-bottom:4px;font-weight:500}.structure-panel .sensor-value{font-size:18px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.structure-panel .sensor-value.temperature{color:#f59e0b}.structure-panel .sensor-value .unit{font-size:11px;font-weight:500;color:#ffffff80}.structure-panel .info-grid{display:flex;flex-direction:column;gap:12px}.structure-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.structure-panel .info-row:hover{background:#ffffff0d}.structure-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.structure-panel .info-value{font-size:14px;color:#fff;font-weight:600;text-align:right}.structure-panel .info-value.inspection{color:#10b981}.structure-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.structure-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.structure-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.structure-panel .documents-list{display:flex;flex-direction:column;gap:10px}.structure-panel .document-item{display:flex;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.structure-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.structure-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.structure-panel .document-info{flex:1;min-width:0}.structure-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.structure-panel .document-meta{display:flex;flex-direction:column;gap:2px}.structure-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-all}.structure-panel .file-date{font-size:11px;color:#fff6}.structure-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.structure-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}@media (max-width: 768px){.structure-panel{width:calc(100% - 40px);left:20px!important;right:20px}.structure-panel .sensors-grid{grid-template-columns:1fr}}.water-flow-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:480px;max-height:calc(100vh - 140px);overflow:hidden;z-index:120;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.water-flow-panel:active{box-shadow:0 12px 40px #00ffff4d}.water-flow-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.water-flow-panel .close-button:hover{background:#ef44444d;transform:scale(1.08)}.water-flow-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.water-flow-panel .header:active{background:#00ffff0d}.water-flow-panel .header-title{display:flex;align-items:center;gap:10px}.water-flow-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.water-flow-panel .header:hover .drag-handle{color:#0ff9}.water-flow-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.water-flow-panel .header-title .icon{font-size:24px}.water-flow-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.water-flow-panel .header-actions{display:flex;align-items:center;gap:12px}.water-flow-panel .status-badge{padding:6px 14px;border-radius:18px;font-size:12px;font-weight:600;color:#0ff;background:#00ffff14;border:1px solid rgba(0,255,255,.3);box-shadow:0 2px 8px #00ffff26;white-space:nowrap}.water-flow-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.water-flow-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.water-flow-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.water-flow-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.water-flow-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.water-flow-panel .tab-content::-webkit-scrollbar{width:6px}.water-flow-panel .tab-content::-webkit-scrollbar-track{background:#0003}.water-flow-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.water-flow-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.water-flow-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.water-flow-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2.4s ease-in-out infinite}.water-flow-panel .last-update{font-size:11px;color:#ffffff80}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.water-flow-panel .flow-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.water-flow-panel .flow-card{background:#00ffff0d;border-radius:14px;padding:16px;display:flex;align-items:center;gap:12px;border:1px solid rgba(0,255,255,.18);transition:all .3s ease}.water-flow-panel .flow-card:hover{border-color:#0ff6;box-shadow:0 8px 18px #00ffff26;transform:translateY(-2px)}.water-flow-panel .flow-icon{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:22px;background:#00ffff26}.water-flow-panel .flow-info{display:flex;flex-direction:column;gap:4px}.water-flow-panel .flow-label{font-size:12px;color:#fff9;letter-spacing:.2px}.water-flow-panel .flow-value{font-size:20px;font-weight:600;color:#0ff}.water-flow-panel .flow-value .unit{font-size:12px;color:#0ff9;margin-left:4px}.water-flow-panel .quality-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.water-flow-panel .quality-card{background:#ffffff08;border-radius:14px;padding:16px;display:flex;align-items:center;gap:12px;border:1px solid rgba(0,255,255,.15);border-left:3px solid #00ffff;transition:transform .15s ease,box-shadow .2s ease}.water-flow-panel .quality-card:hover{transform:translateY(-2px);box-shadow:0 10px 25px #00ffff2e}.water-flow-panel .quality-card .quality-icon{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;background:#00ffff1f}.water-flow-panel .quality-info{display:flex;flex-direction:column;gap:4px}.water-flow-panel .quality-label{font-size:12px;color:#fff9}.water-flow-panel .quality-value{font-size:18px;font-weight:600;color:#fff}.water-flow-panel .quality-value .unit{font-size:11px;color:#0ff9;margin-left:4px}.water-flow-panel .quality-card.warning{border-left-color:#f59e0b;border-color:#f59e0b4d;background:#f59e0b26}.water-flow-panel .quality-card.critical{border-left-color:#ef4444;border-color:#ef444459;background:#ef44442e}.water-flow-panel .documents-header{margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.08)}.water-flow-panel .documents-header h4{margin:0;font-size:16px;font-weight:600;color:#0ff}.water-flow-panel .documents-subtitle{margin:6px 0 0;font-size:12px;color:#ffffff80}.water-flow-panel .documents-list{display:flex;flex-direction:column;gap:12px}.water-flow-panel .document-item{background:#ffffff08;border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .3s ease}.water-flow-panel .document-item:hover{transform:translate(4px);border-color:#0ff6;box-shadow:0 6px 16px #00ffff26}.water-flow-panel .document-icon{font-size:22px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#00ffff14}.water-flow-panel .document-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.water-flow-panel .document-name{font-size:14px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.water-flow-panel .document-meta{font-size:11px;color:#ffffff8c;display:flex;flex-direction:column;gap:2px}.water-flow-panel .file-path{font-family:Courier New,monospace;color:#00ffffb3;word-break:break-all}.water-flow-panel .document-action{font-size:18px;color:#00ffff80;transition:transform .3s ease,color .3s ease}.water-flow-panel .document-item:hover .document-action{transform:translate(4px);color:#0ff}.water-flow-panel .info-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.water-flow-panel .info-row{padding:12px 14px;background:#ffffff08;border-radius:10px;border:1px solid rgba(255,255,255,.08);border-left:3px solid rgba(0,255,255,.5);display:flex;flex-direction:column;gap:4px;transition:background .3s ease}.water-flow-panel .info-row:hover{background:#00ffff14}.water-flow-panel .info-label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:#ffffff80}.water-flow-panel .info-value{font-size:13px;font-weight:600;color:#fff}.water-flow-panel .info-value.status{color:#0ff}@media (max-width: 600px){.water-flow-panel{width:calc(100vw - 30px);left:15px!important;right:15px!important}.water-flow-panel .tabs-container{flex-wrap:wrap}.water-flow-panel .tab-button{flex:1 1 50%}}.mining-extraction-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:450px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mining-extraction-panel:active{box-shadow:0 12px 40px #00ffff4d}.mining-extraction-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.mining-extraction-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.mining-extraction-side-buttons{position:fixed;display:flex;flex-direction:column;gap:12px;z-index:100;pointer-events:none}.mining-extraction-side-buttons .side-button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 10px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;min-width:70px;box-shadow:0 4px 16px #0000004d;pointer-events:all;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mining-extraction-side-buttons .side-button:hover{background:linear-gradient(135deg,#252547,#1f2f4f);border-color:#fff6;transform:translate(-4px);box-shadow:0 6px 20px #0006}.mining-extraction-side-buttons .side-button-icon{font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center}.mining-extraction-side-buttons .side-button-icon svg{width:24px;height:24px;stroke:currentColor}.mining-extraction-side-buttons .side-button-label{font-size:11px;font-weight:600;color:#ffffffe6;text-align:center;white-space:nowrap}.mining-extraction-side-buttons .side-button.network-button:hover{border-color:#8b5cf680;box-shadow:0 6px 20px #8b5cf64d}.mining-extraction-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mining-extraction-panel .header:active{background:#00ffff0d}.mining-extraction-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.mining-extraction-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.mining-extraction-panel .header:hover .drag-handle{color:#0ff9}.mining-extraction-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.mining-extraction-panel .header-title .icon{font-size:24px}.mining-extraction-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.mining-extraction-panel .header-actions{display:flex;align-items:center;gap:10px}.mining-extraction-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.mining-extraction-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.mining-extraction-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.mining-extraction-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.mining-extraction-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.mining-extraction-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.mining-extraction-panel .tab-content::-webkit-scrollbar{width:6px}.mining-extraction-panel .tab-content::-webkit-scrollbar-track{background:#0003}.mining-extraction-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.mining-extraction-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.mining-extraction-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.mining-extraction-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.mining-extraction-panel .last-update{font-size:11px;color:#ffffff80}.mining-extraction-panel .progress-section{margin-bottom:24px;padding:16px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px}.mining-extraction-panel .progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.mining-extraction-panel .progress-label{font-size:14px;font-weight:600;color:#fffc}.mining-extraction-panel .progress-value{font-size:20px;font-weight:700;color:#0ff}.mining-extraction-panel .progress-bar-container{width:100%;height:24px;background:#0000004d;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.1)}.mining-extraction-panel .progress-bar{height:100%;background:linear-gradient(90deg,#0ff,#00b8d4);border-radius:12px;transition:width .5s ease;box-shadow:0 0 10px #00ffff80}.mining-extraction-panel .section-title{font-size:16px;font-weight:600;color:#0ff;margin:24px 0 16px;padding-bottom:8px;border-bottom:2px solid rgba(0,255,255,.3)}.mining-extraction-panel .section-title:first-of-type{margin-top:0}.mining-extraction-panel .data-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.mining-extraction-panel .data-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;transition:all .3s ease}.mining-extraction-panel .data-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.mining-extraction-panel .data-label{font-size:11px;color:#fff9;margin-bottom:6px;font-weight:500}.mining-extraction-panel .data-value{font-size:20px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.mining-extraction-panel .data-value.material{color:#10b981}.mining-extraction-panel .data-value.material-extracted{color:#0ff}.mining-extraction-panel .data-value.material-remaining{color:#f59e0b}.mining-extraction-panel .data-value.waste{color:#6b7280}.mining-extraction-panel .data-value.waste-extracted{color:#94a3b8}.mining-extraction-panel .data-value.waste-remaining{color:#cbd5e1}.mining-extraction-panel .data-value.production{color:#3b82f6}.mining-extraction-panel .data-value.production-current{color:#60a5fa}.mining-extraction-panel .data-value .unit{font-size:12px;font-weight:500;color:#ffffff80}.mining-extraction-panel .data-subvalue{font-size:12px;font-weight:500;color:#fff6;margin-top:4px;font-style:italic}.mining-extraction-panel .data-subvalue .unit{font-size:11px;color:#ffffff4d}.mining-extraction-panel .data-equivalency{font-size:11px;font-weight:500;color:#0ff9;margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.1)}.mining-extraction-panel .equivalencies-section{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.mining-extraction-panel .equivalency-card{display:flex;align-items:center;gap:12px;padding:14px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;transition:all .3s ease}.mining-extraction-panel .equivalency-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.mining-extraction-panel .equivalency-icon{font-size:32px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:10px;flex-shrink:0}.mining-extraction-panel .equivalency-info{flex:1;min-width:0}.mining-extraction-panel .equivalency-label{font-size:11px;color:#fff9;margin-bottom:4px;font-weight:500}.mining-extraction-panel .equivalency-value{font-size:24px;font-weight:700;color:#0ff}.estimated-card{background:#0003;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;text-align:center}.estimated-value{font-size:20px;font-weight:700;color:#0ff}.mining-extraction-panel .info-grid{display:flex;flex-direction:column;gap:12px}.mining-extraction-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.mining-extraction-panel .info-row:hover{background:#ffffff0d}.mining-extraction-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.mining-extraction-panel .info-value{font-size:14px;color:#fff;font-weight:600}.mining-extraction-panel .info-row.tag-row{background:#00ffff14;border-left:3px solid #00ffff;border-radius:8px}.mining-extraction-panel .info-row.tag-row .info-label{color:#0ff;font-weight:600;font-size:13px}.mining-extraction-panel .info-row.tag-row .info-value{color:#0ff;font-weight:700;font-size:15px;letter-spacing:.5px;text-transform:uppercase}.mining-extraction-panel .no-info{text-align:center;padding:40px 20px;color:#ffffff80}.mining-extraction-panel .no-info p{margin:8px 0;font-size:14px}.mining-extraction-panel .no-info-hint{font-size:12px;color:#00ffff80;font-style:italic}@media (max-width: 768px){.mining-extraction-panel{width:calc(100% - 40px);left:20px!important;right:20px}.mining-extraction-panel .data-grid,.mining-extraction-panel .equivalencies-section{grid-template-columns:1fr}}.quality-buttons-container{display:flex;flex-direction:column;gap:12px;margin-top:16px}.quality-button{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;text-align:left;width:100%}.quality-button:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.quality-button:active{transform:translateY(0)}.quality-button .button-icon{font-size:28px;flex-shrink:0}.quality-button .button-content{display:flex;flex-direction:column;gap:4px;flex:1}.quality-button .button-title{font-size:14px;font-weight:600;color:#0ff}.quality-button .button-subtitle{font-size:11px;color:#fff9}.quality-button.route-quality{border-color:#8b5cf64d;background:#8b5cf60d}.quality-button.route-quality:hover{background:#8b5cf61a;border-color:#8b5cf680;box-shadow:0 4px 12px #8b5cf64d}.quality-button.route-quality .button-title{color:#a78bfa}.quality-button.truck-quality{border-color:#f59e0b4d;background:#f59e0b0d}.quality-button.truck-quality:hover{background:#f59e0b1a;border-color:#f59e0b80;box-shadow:0 4px 12px #f59e0b4d}.quality-button.truck-quality .button-title{color:#fbbf24}.quality-button.finance-button{border-color:#22c55e4d;background:#22c55e0d}.quality-button.finance-button:hover{background:#22c55e1a;border-color:#22c55e80;box-shadow:0 4px 12px #22c55e4d}.quality-button.finance-button .button-title{color:#22c55e}.quality-button.particulate-button{border-color:#a855f74d;background:#a855f70d}.quality-button.particulate-button:hover{background:#a855f71a;border-color:#a855f780;box-shadow:0 4px 12px #a855f74d}.quality-button.particulate-button .button-title{color:#a855f7}.impact-section{margin-top:20px}.impact-card{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;padding:16px;margin-top:12px}.impact-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.impact-label{font-size:13px;color:#ffffffb3;font-weight:500}.impact-value{font-size:18px;font-weight:700}.impact-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#fffc}.impact-compact-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.impact-compact-card{background:#0003;border:1px solid rgba(0,255,255,.2);border-radius:10px;padding:12px;text-align:center}.impact-compact-label{font-size:12px;color:#fff9;font-weight:500;margin-bottom:6px}.impact-compact-route-quality{font-size:20px;font-weight:700;margin-bottom:8px}.impact-compact-production{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:6px;font-size:14px}.impact-compact-base{color:#ffffff80;text-decoration:line-through;font-weight:500}.impact-compact-arrow{color:#fff6;font-size:12px}.impact-compact-affected{color:#0ff;font-weight:700;font-size:16px}.impact-compact-unit{color:#ffffff80;font-size:11px;font-weight:500}.impact-compact-loss{font-size:11px;font-weight:600}.impact-row.highlight{padding-top:8px;border-top:1px solid rgba(255,255,255,.1);font-weight:600;font-size:13px}.impact-percentage{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);font-size:11px;color:#fff9;text-align:center;font-style:italic}.data-dependency-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;width:900px;max-height:calc(100vh - 100px);overflow:hidden;z-index:200;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.data-dependency-panel .panel-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.data-dependency-panel .header-actions{display:flex;align-items:center;gap:8px}.data-dependency-panel .header-action-button{background:#3b82f633;border:1px solid rgba(59,130,246,.4);color:#3b82f6;border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.data-dependency-panel .header-action-button:hover{background:#3b82f64d;transform:scale(1.1)}.data-dependency-panel .header-action-button.alerts-button{background:#ef444433;border-color:#ef444466;color:#ef4444}.data-dependency-panel .header-action-button.alerts-button:hover{background:#ef44444d}.data-dependency-panel .header-action-button.recommendations-button{background:#f59e0b33;border-color:#f59e0b66;color:#f59e0b}.data-dependency-panel .header-action-button.recommendations-button:hover{background:#f59e0b4d}.data-dependency-panel .header-title{display:flex;align-items:center;gap:10px;flex:1}.data-dependency-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.data-dependency-panel .panel-header:hover .drag-handle{color:#0ff9}.data-dependency-panel .panel-header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.data-dependency-panel .panel-header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.data-dependency-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.data-dependency-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.data-dependency-panel .panel-content{flex:1;overflow:hidden;padding:20px;position:relative;min-height:650px}.diagram-controls{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;background:#0000004d;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.control-button{background:#3b82f633;border:1px solid rgba(59,130,246,.4);color:#3b82f6;border-radius:6px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-weight:600}.control-button:hover{background:#3b82f64d;transform:scale(1.1)}.reset-button{background:#10b98133;border-color:#10b98166;color:#10b981}.reset-button:hover{background:#10b9814d}.zoom-in-button,.zoom-out-button{font-size:20px;line-height:1}.zoom-indicator{margin-left:auto;font-size:12px;color:#ffffffb3;padding:4px 8px;background:#ffffff0d;border-radius:4px}.diagram-container{position:relative;width:100%;height:650px;background:#0003;border-radius:8px;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.dependency-diagram{width:100%;height:100%}.panels-nodes-container{position:relative;width:100%;height:100%;pointer-events:none;transition:transform .05s ease-out;will-change:transform}.panel-node{position:absolute;width:220px;min-height:140px;max-height:300px;background:#1f2937f2;border:2px solid;border-radius:12px;padding:12px;cursor:grab;transition:box-shadow .2s ease,border-width .2s ease,background-color .2s ease;pointer-events:all;box-shadow:0 4px 12px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);-webkit-user-select:none;-moz-user-select:none;user-select:none;overflow-y:auto;touch-action:none;box-sizing:border-box}.panel-node::-webkit-scrollbar{width:4px}.panel-node::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.panel-node:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000080;border-width:3px;background:#1f2937fa}.panel-node.selected{border-width:3px;box-shadow:0 0 20px currentColor}.panel-node.dragging{cursor:grabbing!important;opacity:.9;z-index:1000;transform:scale(1.02);box-shadow:0 8px 24px #00000080;transition:none}.panel-node-header{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid;margin-bottom:8px}.panel-node-icon{font-size:24px}.panel-node-name{font-weight:600;font-size:14px;color:#fff;flex:1}.panel-node-dependencies{margin-bottom:8px}.dependencies-label{font-size:10px;color:#fff9;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.dependencies-list{list-style:none;padding:0;margin:0;max-height:80px;overflow-y:auto}.dependencies-list::-webkit-scrollbar{width:3px}.dependencies-list::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.dependency-item{font-size:11px;color:#fffc;padding:2px 0 2px 12px;position:relative}.dependency-item:before{content:"•";position:absolute;left:0;color:currentColor}.sensors-cards{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.sensor-card{padding:4px 8px;background:#00ffff26;border:1px solid rgba(0,255,255,.3);border-radius:4px;font-size:10px;color:#0ff;font-weight:500}.sensor-data-cards{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.sensor-data-card{padding:3px 6px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:4px;font-size:9px;color:#fca5a5}.data-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-top:6px;max-height:120px;overflow-y:auto}.data-cards-grid::-webkit-scrollbar{width:3px}.data-cards-grid::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px}.data-card{padding:6px 8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;transition:all .2s ease;cursor:pointer}.data-card:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.data-card-label{font-size:9px;color:#fff9;margin-bottom:2px;text-transform:uppercase;letter-spacing:.3px}.data-card-value{font-size:10px;color:#ffffffe6;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-card-number{border-left:3px solid #3b82f6}.data-card-rate{border-left:3px solid #10b981}.data-card-status{border-left:3px solid #f59e0b}.data-card-terrain{border-left:3px solid #8b5cf6}.data-card-distance{border-left:3px solid #06b6d4}.data-card-speed{border-left:3px solid #f97316}.data-card-calculated{border-left:3px solid #14b8a6}.data-card-height{border-left:3px solid #a855f7}.data-card-boolean{border-left:3px solid #ec4899}.data-card-mp{border-left:3px solid #ef4444}.data-card-dependency{border-left:3px solid #6366f1;background:#6366f11a}.data-card-alerts{border-left:3px solid #f59e0b}.data-card-recommendations{border-left:3px solid #10b981}.data-card-position{border-left:3px solid #06b6d4}.data-card-quality{border-left:3px solid #10b981}.data-card-roughness{border-left:3px solid #8b5cf6}.data-card-slope{border-left:3px solid #f97316}.data-card-normals{border-left:3px solid #6366f1}.data-card-chart{border-left:3px solid #ec4899}.data-card-prediction{border-left:3px solid #f59e0b}.data-card-environment{border-left:3px solid #14b8a6}.data-card-count{border-left:3px solid #3b82f6}.data-card-percentage{border-left:3px solid #10b981}.data-card-maintenance{border-left:3px solid #f59e0b}.expand-data-button{width:100%;padding:6px 10px;margin-top:8px;background:#3b82f633;border:1px solid;border-radius:6px;color:#fff;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:space-between;gap:6px}.expand-data-button:hover{background:#3b82f64d;transform:translateY(-1px)}.data-list-container{margin-top:8px;max-height:200px;overflow-y:auto;border:1px solid rgba(255,255,255,.1);border-radius:6px;background:#0003;padding:6px}.data-list-container::-webkit-scrollbar{width:4px}.data-list-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.data-list-item{padding:8px 10px;margin-bottom:6px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-left:3px solid;border-radius:6px;transition:all .2s ease;cursor:default}.data-list-item:last-child{margin-bottom:0}.data-list-item:hover{background:#ffffff14;border-color:#fff3}.data-list-label{font-size:10px;color:#ffffffe6;font-weight:600;margin-bottom:3px;line-height:1.3}.data-list-description{font-size:8px;color:#fff9;line-height:1.4;word-wrap:break-word}.panel-node-action{margin-top:8px}.open-panel-button{width:100%;padding:6px 12px;border:none;border-radius:6px;color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease}.open-panel-button:hover{opacity:.9;transform:scale(1.02)}.panel-info{margin-top:20px;padding:16px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.info-header h4{margin:0;font-size:16px;color:#0ff}.info-header button{background:transparent;border:none;color:#fff9;font-size:18px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.info-header button:hover{background:#ffffff1a;color:#fff}.info-content{font-size:13px;color:#ffffffe6}.info-section{margin-bottom:12px}.info-section strong{color:#0ff;display:block;margin-bottom:6px}.info-section ul{list-style:none;margin:0;padding:0 0 0 16px}.info-section li{padding:4px 0;position:relative}.info-section li:before{content:"→";position:absolute;left:-16px;color:#0ff9}.finance-panel-button{position:absolute;top:20px;right:20px;z-index:10;background:#10b98133;border:2px solid rgba(16,185,129,.6);color:#10b981;border-radius:12px;padding:12px 20px;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s ease;box-shadow:0 4px 12px #0000004d}.finance-panel-button:hover{background:#10b9814d;border-color:#10b981cc;transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.finance-button-icon{font-size:20px;line-height:1}.finance-button-label{font-size:14px;font-weight:600}.truck-route-quality-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:450px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;opacity:1!important}.truck-route-quality-panel:active{box-shadow:0 12px 40px #00ffff4d}.truck-route-quality-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.truck-route-quality-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.truck-route-quality-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.truck-route-quality-panel .header:active{background:#00ffff0d}.truck-route-quality-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.truck-route-quality-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.truck-route-quality-panel .header:hover .drag-handle{color:#0ff9}.truck-route-quality-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.truck-route-quality-panel .header-title .icon{font-size:24px}.truck-route-quality-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.truck-route-quality-panel .header-actions{display:flex;align-items:center;gap:10px}.truck-route-quality-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.truck-route-quality-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.truck-route-quality-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.truck-route-quality-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.truck-route-quality-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.truck-route-quality-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.truck-route-quality-panel .tab-content::-webkit-scrollbar{width:6px}.truck-route-quality-panel .tab-content::-webkit-scrollbar-track{background:#0003}.truck-route-quality-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.truck-route-quality-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.truck-route-quality-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.truck-route-quality-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.truck-route-quality-panel .last-update{font-size:11px;color:#ffffff80}.truck-route-quality-panel .quality-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.truck-route-quality-panel .quality-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;transition:all .3s ease}.truck-route-quality-panel .quality-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.truck-route-quality-panel .quality-label{font-size:11px;color:#fff9;margin-bottom:8px;font-weight:500}.truck-route-quality-panel .quality-value{font-size:24px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px;margin-bottom:8px}.truck-route-quality-panel .quality-value .unit{font-size:14px;font-weight:500;color:#ffffff80}.truck-route-quality-panel .quality-bar-container{width:100%;height:8px;background:#0000004d;border-radius:4px;overflow:hidden}.truck-route-quality-panel .quality-bar{height:100%;border-radius:4px;transition:width .5s ease}.truck-route-quality-panel .info-grid{display:flex;flex-direction:column;gap:12px}.truck-route-quality-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.truck-route-quality-panel .info-row:hover{background:#ffffff0d}.truck-route-quality-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.truck-route-quality-panel .info-value{font-size:14px;color:#fff;font-weight:600}.truck-route-quality-panel .no-info{text-align:center;padding:40px 20px;color:#ffffff80}.truck-route-quality-panel .no-info p{margin:8px 0;font-size:14px}.truck-route-quality-panel .no-info-hint{font-size:12px;color:#00ffff80;font-style:italic}.route-visualization-section{margin-bottom:20px;padding:16px;background:#0003;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.section-title-small{font-size:13px;font-weight:600;color:#fffc;margin-bottom:12px;display:flex;align-items:center;gap:6px}.route-timeline-container{position:relative;width:100%;margin-bottom:12px;padding:20px 0;overflow-x:auto;overflow-y:hidden}.route-timeline-container::-webkit-scrollbar{height:6px}.route-timeline-container::-webkit-scrollbar-track{background:#0003;border-radius:3px}.route-timeline-container::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.route-timeline-container::-webkit-scrollbar-thumb:hover{background:#00ffff80}.route-timeline-wrapper{position:relative;display:flex;align-items:center;min-width:-moz-fit-content;min-width:fit-content;width:100%;padding:0 8px}.route-timeline-item{display:flex;align-items:center;flex-shrink:0;position:relative}.route-timeline-point{width:16px;height:16px;border-radius:50%;border:3px solid;background:#fff;box-shadow:0 2px 8px #0000004d;cursor:pointer;transition:all .3s ease;z-index:3;position:relative;flex-shrink:0}.route-timeline-point:hover{transform:scale(1.4);box-shadow:0 4px 12px #00000080}.route-timeline-connector{width:calc((100% - 320px) / 19);min-width:8px;max-width:20px;height:3px;margin:0 2px;transition:all .3s ease;border-radius:2px;flex-shrink:0;border:1px solid;position:relative}.route-timeline-connector:hover{height:5px;transform:translateY(-1px);box-shadow:0 2px 8px #8b5cf680;z-index:10}.route-timeline-connector.selected{height:5px;box-shadow:0 0 12px #8b5cf6cc;z-index:10;animation:pulse-selected 2s ease-in-out infinite}@keyframes pulse-selected{0%,to{box-shadow:0 0 12px #8b5cf6cc}50%{box-shadow:0 0 20px #8b5cf6}}.quick-route-indicator{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#8b5cf61a;border:1px solid rgba(139,92,246,.2);border-radius:8px;margin-bottom:16px;font-size:13px}.quick-route-label{color:#fff9;font-weight:500}.quick-route-name{color:#a78bfa;font-weight:600}.route-selector-section{margin-bottom:20px;padding:16px;background:#0003;border-radius:12px;border:1px solid rgba(139,92,246,.2)}.route-list{display:flex;flex-direction:column;gap:12px;margin-top:12px}.route-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#0000004d;border:1px solid rgba(139,92,246,.2);border-radius:10px;cursor:pointer;transition:all .3s ease;width:100%;text-align:left;color:#fff}.route-item:hover{background:#8b5cf626;border-color:#8b5cf666;transform:translate(4px)}.route-item.active{background:#8b5cf640;border-color:#8b5cf699;box-shadow:0 4px 12px #8b5cf64d}.route-icon{font-size:24px;flex-shrink:0}.route-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.route-name{font-weight:600;font-size:15px;color:#8b5cf6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-item.active .route-name{color:#a78bfa}.route-status{font-size:13px;font-weight:500}.route-arrow{font-size:18px;color:#8b5cf680;transition:all .3s ease;flex-shrink:0}.route-item:hover .route-arrow{color:#8b5cf6cc;transform:translate(4px)}.route-item.active .route-arrow{color:#a78bfa}.route-legend{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:8px}.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#ffffffb3}.legend-color{width:16px;height:16px;border-radius:3px;border:1px solid rgba(255,255,255,.2);box-shadow:0 1px 3px #0000004d}.general-metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.general-metric-card{background:#0003;border:1px solid rgba(139,92,246,.2);border-radius:10px;padding:14px;text-align:center;transition:all .3s ease}.general-metric-card:hover{background:#8b5cf61a;border-color:#8b5cf666}.general-metric-label{font-size:12px;color:#fff9;margin-bottom:8px;font-weight:500}.general-metric-value{font-size:20px;font-weight:700;color:#8b5cf6}.segment-details-section{margin-top:20px;padding:16px;background:#8b5cf61a;border:2px solid rgba(139,92,246,.4);border-radius:12px;position:relative}.segment-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:12px}.segment-detail-card{background:#0000004d;border:1px solid rgba(139,92,246,.2);border-radius:8px;padding:12px}.segment-detail-label{font-size:11px;color:#fff9;margin-bottom:6px;font-weight:500}.segment-detail-value{font-size:18px;font-weight:700;color:#a78bfa}.close-segment-button{width:100%;padding:10px;background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;cursor:pointer;font-weight:600;font-size:13px;transition:all .3s ease;margin-top:8px}.close-segment-button:hover{background:#ef44444d;transform:scale(1.02)}.section-title{font-size:16px;font-weight:600;color:#8b5cf6;margin:24px 0 16px;padding-bottom:8px;border-bottom:2px solid rgba(139,92,246,.3)}.route-selector-inline{display:flex;gap:8px;margin-bottom:20px;padding:8px;background:#0003;border-radius:10px}.route-selector-btn{flex:1;padding:10px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#ffffffb3;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s ease}.route-selector-btn:hover{background:#ffffff1a;border-color:#8b5cf64d}.route-selector-btn.active{background:#8b5cf633;border-color:#8b5cf6;color:#a855f7;font-weight:600}.pm-metrics-main{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:24px}.pm-metric-main-card{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.pm-metric-main-card:hover{background:#a855f71a;border-color:#a855f766;transform:translateY(-2px)}.pm-metric-main-icon{font-size:32px;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#a855f71a;border-radius:10px;flex-shrink:0}.pm-metric-main-content{flex:1;min-width:0}.pm-metric-main-label{font-size:12px;color:#fff9;margin-bottom:6px;font-weight:500}.pm-metric-main-value{font-size:20px;font-weight:700;color:#a855f7;margin-bottom:4px}.pm-unit{font-size:14px;font-weight:500;color:#ffffff80}.pm-metric-main-sub{font-size:11px;color:#fff6;font-style:italic}.pm-details-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.pm-detail-card{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:16px;text-align:center;transition:all .3s ease}.pm-detail-card:hover{background:#a855f71a;border-color:#a855f766;transform:translateY(-2px)}.pm-detail-icon{font-size:24px;margin-bottom:8px}.pm-detail-label{font-size:12px;color:#fff9;margin-bottom:10px;font-weight:500}.pm-detail-value{font-size:18px;font-weight:700;color:#a855f7}.pm-unit-small{font-size:12px;font-weight:500;color:#ffffff80}.particulate-detail-button{width:100%;padding:12px;background:#a855f733;border:1px solid rgba(168,85,247,.3);border-radius:10px;color:#a855f7;cursor:pointer;font-weight:600;font-size:14px;transition:all .3s ease;margin-top:12px}.particulate-detail-button:hover{background:#a855f74d;transform:scale(1.02)}.pm-breakdown{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.pm-breakdown-item{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:16px;transition:all .3s ease}.pm-breakdown-item:hover{background:#a855f71a;border-color:#a855f766}.pm-breakdown-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-weight:600;font-size:14px;color:#a855f7}.pm-breakdown-icon{font-size:20px}.pm-breakdown-name{flex:1}.pm-breakdown-details{display:flex;flex-direction:column;gap:8px}.pm-breakdown-detail{display:flex;justify-content:space-between;font-size:13px;color:#ffffffb3;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}.pm-breakdown-detail:last-child{border-bottom:none}.pm-breakdown-detail span:first-child{color:#ffffff80}.pm-breakdown-detail span:last-child{font-weight:600;color:#a855f7}@media (max-width: 768px){.truck-route-quality-panel{width:calc(100% - 40px);left:20px!important;right:20px}.truck-route-quality-panel .quality-grid,.general-metrics-grid,.segment-details-grid,.pm-summary,.pm-details-grid{grid-template-columns:1fr}}.truck-route-quality-side-buttons{position:fixed;display:flex;flex-direction:column;gap:12px;z-index:100;pointer-events:none}.side-button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 10px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;min-width:70px;box-shadow:0 4px 16px #0000004d;pointer-events:all;-webkit-user-select:none;-moz-user-select:none;user-select:none}.side-button:hover{background:linear-gradient(135deg,#252547,#1f2f4f);border-color:#fff6;transform:translate(-4px);box-shadow:0 6px 20px #0006}.side-button:active{transform:translate(-2px)}.side-button-icon{font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center}.side-button-icon svg{width:24px;height:24px;stroke:currentColor}.side-button-label{font-size:11px;font-weight:600;color:#ffffffe6;text-align:center;white-space:nowrap}.side-button-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;border-radius:10px;padding:2px 6px;font-size:10px;font-weight:700;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;border:2px solid #1a1a2e;box-shadow:0 2px 4px #0000004d}.side-button-badge.badge-success{background:#10b981}.side-button-badge.badge-warning{background:#f59e0b}.side-button.alerts-button:hover{border-color:#ef444480;box-shadow:0 6px 20px #ef44444d}.side-button.recommendations-button:hover{border-color:#f59e0b80;box-shadow:0 6px 20px #f59e0b4d}.side-button.network-button:hover{border-color:#8b5cf680;box-shadow:0 6px 20px #8b5cf64d}.route-point-details-side-buttons{position:fixed;display:flex;flex-direction:column;gap:12px;z-index:100;pointer-events:none}.route-point-details-side-buttons .side-button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 10px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;min-width:70px;box-shadow:0 4px 16px #0000004d;pointer-events:all;-webkit-user-select:none;-moz-user-select:none;user-select:none}.route-point-details-side-buttons .side-button:hover{background:linear-gradient(135deg,#252547,#1f2f4f);border-color:#fff6;transform:translate(-4px);box-shadow:0 6px 20px #0006}.route-point-details-side-buttons .side-button-icon{font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center}.route-point-details-side-buttons .side-button-icon svg{width:24px;height:24px;stroke:currentColor}.route-point-details-side-buttons .side-button-label{font-size:11px;font-weight:600;color:#ffffffe6;text-align:center;white-space:nowrap}.route-point-details-side-buttons .side-button.network-button:hover{border-color:#8b5cf680;box-shadow:0 6px 20px #8b5cf64d}.modal-overlay{position:fixed;inset:0;background:transparent;z-index:100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #00000080;border:1px solid rgba(255,255,255,.1);width:90%;max-width:500px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease;z-index:100;position:fixed}.modal-panel.recommendations-modal{max-width:700px;width:85%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.modal-header .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.modal-header:hover .drag-handle{color:#0ff9}.modal-header:active .drag-handle{cursor:grabbing}.modal-close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.modal-close-button:hover{background:#ef44444d;transform:scale(1.1)}.modal-content{padding:12px 16px;overflow-y:auto;flex:1}.alerts-list-compact{display:flex;flex-direction:column;gap:6px}.alert-list-item{padding:8px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.1);transition:all .2s ease;cursor:pointer}.alert-list-item:hover{border-color:#ffffff4d;transform:translate(4px)}.alert-list-item.alert-critical{border-left:3px solid #ef4444}.alert-list-item.alert-warning{border-left:3px solid #f59e0b}.alert-list-header{display:flex;align-items:center;gap:6px;margin-bottom:3px}.alert-severity{font-size:14px}.alert-parameter{font-weight:600;color:#0ff;font-size:12px}.alert-message-compact{font-size:11px;color:#ffffffbf;line-height:1.3}.alert-hour-compact{font-size:9px;color:#ffffff80;margin-left:auto}.alert-back-button{padding:4px 8px;margin-bottom:8px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fffc;cursor:pointer;font-size:14px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.alert-back-button:hover{background:#ffffff1a;border-color:#fff6;color:#fff}.alert-detail-content{padding:0}.alert-item-detail{padding:10px;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.alert-item-detail.alert-critical{border-left:3px solid #ef4444}.alert-item-detail.alert-warning{border-left:3px solid #f59e0b}.alert-details-compact{display:flex;flex-direction:column;gap:4px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}.alert-detail-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:12px}.alert-detail-row span:first-child{color:#fff9}.alert-detail-row span:last-child{color:#ffffffe6;font-weight:600}.alert-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.alert-severity{font-size:18px}.alert-parameter{font-weight:600;color:#0ff;font-size:13px}.alert-hour{font-size:11px;color:#fff9;margin-left:auto}.alert-message{font-size:12px;color:#ffffffe6;margin-bottom:8px;line-height:1.4}.alert-details{display:flex;gap:16px;font-size:12px;color:#ffffffb3;margin-top:8px}.no-alerts{text-align:center;padding:40px 20px;color:#fff9}.no-alerts p{margin:8px 0;font-size:14px}.no-alerts-subtitle{font-size:12px;color:#fff6}.recommendation-card{padding:20px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0003}.recommendation-card.recommendation-warning{border-left:4px solid #ef4444;background:#ef44441a}.recommendation-card.recommendation-success{border-left:4px solid #10b981;background:#10b9811a}.recommendation-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.recommendation-icon{font-size:24px}.recommendation-title{font-size:16px;font-weight:700;color:#fff}.recommendation-card.recommendation-warning .recommendation-title{color:#ef4444}.recommendation-card.recommendation-success .recommendation-title{color:#10b981}.recommendation-reason{font-size:14px;color:#ffffffe6;line-height:1.6;margin-bottom:16px;padding:12px;background:#0003;border-radius:8px}.recommendation-details{display:flex;flex-direction:column;gap:10px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}.recommendation-detail-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.recommendation-detail-row span:first-child{color:#fff9}.recommendation-detail-row span:last-child{color:#ffffffe6;font-weight:600}.no-recommendation{text-align:center;padding:40px 20px;color:#fff9}.no-recommendation p{margin:0;font-size:14px}.recommendations-list-compact{display:flex;flex-direction:column;gap:6px}.recommendation-list-item{padding:8px 10px;border-radius:6px;border:1px solid rgba(255,255,255,.1);transition:all .2s ease;cursor:pointer}.recommendation-list-item:hover{border-color:#ffffff4d;transform:translate(4px)}.recommendation-list-item.recommendation-better{border-left:3px solid #10b981}.recommendation-list-item.recommendation-worse{border-left:3px solid #f97316}.recommendation-list-header{display:flex;align-items:center;gap:6px;margin-bottom:3px}.recommendation-list-icon{font-size:14px}.recommendation-list-title{font-weight:600;color:#ffffffe6;font-size:12px;flex:1}.recommendation-list-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.5px}.recommendation-list-badge.badge-better{background:#10b981;color:#fff}.recommendation-list-badge.badge-worse{background:#f97316;color:#fff}.recommendation-list-summary{font-size:10px;color:#ffffffb3;line-height:1.3}.recommendation-back-button{padding:4px 8px;margin-bottom:8px;background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fffc;cursor:pointer;font-size:14px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.recommendation-back-button:hover{background:#ffffff1a;border-color:#fff6;color:#fff}.recommendation-detail-content{padding:0}.recommendation-cases-container{display:flex;flex-direction:row;gap:6px}.recommendation-case-card{padding:6px;border-radius:6px;border:2px solid rgba(255,255,255,.1);transition:all .2s ease;flex:1;min-width:0}.recommendation-case-card.case-better{border-color:#10b981}.recommendation-case-card.case-worse{border-color:#f97316}.recommendation-case-header{display:flex;align-items:center;gap:6px;margin-bottom:6px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.1)}.recommendation-case-icon{font-size:14px}.recommendation-case-title{font-size:12px;font-weight:700;color:#fff;flex:1}.recommendation-case-badge{font-size:9px;font-weight:700;padding:2px 6px;border-radius:3px;background:#10b981;color:#fff;text-transform:uppercase;letter-spacing:.5px}.recommendation-case-items{display:flex;flex-direction:column;gap:4px}.recommendation-case-item{display:flex;justify-content:space-between;align-items:center;font-size:10px;padding:3px 0}.recommendation-case-item-label{color:#ffffffb3;flex:1;font-size:10px}.recommendation-case-item-value{color:#ffffffe6;font-weight:600;font-size:10px}.recommendation-case-item-value.zero-value{color:#fff6;font-style:italic}.recommendation-case-total{display:flex;justify-content:space-between;align-items:center;margin-top:6px;padding-top:6px;border-top:2px solid rgba(255,255,255,.15);font-size:11px;font-weight:700;color:#fff}.recommendation-case-total-value{font-size:12px;font-weight:800}.truck-quality-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:500px;min-width:500px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.truck-quality-panel:active{box-shadow:0 12px 40px #00ffff4d}.truck-quality-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.truck-quality-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.truck-quality-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.truck-quality-panel .header:active{background:#00ffff0d}.truck-quality-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.truck-quality-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.truck-quality-panel .header:hover .drag-handle{color:#0ff9}.truck-quality-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.truck-quality-panel .header-title .icon{font-size:24px}.truck-quality-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.truck-quality-panel .header-actions{display:flex;align-items:center;gap:10px}.truck-quality-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.truck-quality-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.truck-quality-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.truck-quality-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.truck-quality-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.truck-quality-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.truck-quality-panel .tab-content::-webkit-scrollbar{width:6px}.truck-quality-panel .tab-content::-webkit-scrollbar-track{background:#0003}.truck-quality-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.truck-quality-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.truck-quality-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.truck-quality-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.truck-quality-panel .last-update{font-size:11px;color:#ffffff80}.truck-quality-panel .quality-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.truck-quality-panel .quality-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;transition:all .3s ease}.truck-quality-panel .quality-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.truck-quality-panel .quality-label{font-size:11px;color:#fff9;margin-bottom:8px;font-weight:500}.truck-quality-panel .quality-value{font-size:24px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px;margin-bottom:8px}.truck-quality-panel .quality-value .unit{font-size:14px;font-weight:500;color:#ffffff80}.truck-quality-panel .quality-bar-container{width:100%;height:8px;background:#0000004d;border-radius:4px;overflow:hidden}.truck-quality-panel .quality-bar{height:100%;border-radius:4px;transition:width .5s ease}.truck-quality-panel .fleet-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.truck-quality-panel .fleet-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:10px;padding:10px 8px;text-align:center;transition:all .3s ease}.truck-quality-panel .fleet-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px)}.truck-quality-panel .fleet-card.operational{border-color:#10b9814d;background:#10b9810d}.truck-quality-panel .fleet-card.maintenance{border-color:#f59e0b4d;background:#f59e0b0d}.truck-quality-panel .fleet-label{font-size:11px;color:#fff9;margin-bottom:8px;font-weight:500}.truck-quality-panel .fleet-value{font-size:24px;font-weight:700;color:#0ff}.truck-quality-panel .fleet-card.operational .fleet-value{color:#10b981}.truck-quality-panel .fleet-card.maintenance .fleet-value{color:#f59e0b}.truck-quality-panel .maintenance-info{margin-top:20px}.truck-quality-panel .maintenance-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:16px;text-align:center}.truck-quality-panel .maintenance-label{font-size:12px;color:#fff9;margin-bottom:8px;font-weight:500}.truck-quality-panel .maintenance-value{font-size:28px;font-weight:700;color:#0ff;display:flex;align-items:baseline;justify-content:center;gap:4px}.truck-quality-panel .maintenance-value .unit{font-size:16px;font-weight:500;color:#ffffff80}.selected-truck-header{padding:16px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:12px;margin-bottom:20px;text-align:center}.selected-truck-name{font-size:20px;font-weight:700;color:#f59e0b;margin-bottom:6px}.selected-truck-tag{font-size:14px;color:#ffffffb3;margin-bottom:4px}.selected-truck-model{font-size:13px;color:#ffffff80}.truck-additional-info{margin-top:20px;padding:16px;background:#0003;border:1px solid rgba(245,158,11,.2);border-radius:12px}.truck-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.1)}.truck-info-row:last-child{border-bottom:none}.truck-info-label{font-size:13px;color:#fff9;font-weight:500}.truck-info-value{font-size:14px;color:#f59e0b;font-weight:600}.trucks-list{margin-top:12px}.truck-list-item-button{flex:1;display:flex;align-items:center;background:none;border:none;padding:0;cursor:pointer;color:inherit}.truck-find-button{margin-left:4px;padding:0;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;min-width:32px;width:32px;height:32px}.truck-find-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);transform:scale(1.05);box-shadow:0 2px 8px #3b82f666}.truck-find-button:active{transform:scale(.95)}.trucks-list-container{display:flex;flex-direction:column;gap:8px;margin-top:12px;max-height:calc(100vh - 450px);min-height:200px;overflow-y:auto}.trucks-list-container::-webkit-scrollbar{width:6px}.trucks-list-container::-webkit-scrollbar-track{background:#0003}.trucks-list-container::-webkit-scrollbar-thumb{background:#f59e0b4d;border-radius:3px}.truck-list-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:#0000004d;border:1px solid rgba(245,158,11,.2);border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:left;width:100%;color:#fff;box-sizing:border-box}.truck-list-item:hover{background:#f59e0b26;border-color:#f59e0b66;transform:translate(4px)}.truck-list-item.selected{background:#f59e0b40;border-color:#f59e0b99;box-shadow:0 4px 12px #f59e0b4d}.truck-list-item.maintenance{opacity:.7;border-color:#ef44444d}.truck-list-icon{font-size:22px;flex-shrink:0}.truck-list-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0;max-width:calc(100% - 120px)}.truck-list-name{font-weight:600;font-size:13px;color:#f59e0b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.truck-list-item.selected .truck-list-name{color:#fbbf24}.truck-list-tag{font-size:12px;color:#ffffff80}.truck-list-model{font-size:11px;color:#fff6}.truck-list-status{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0;margin-right:8px}.truck-list-condition{font-size:14px;font-weight:700}.truck-list-status-badge{padding:3px 8px;border-radius:10px;font-size:9px;font-weight:600;color:#fff;white-space:nowrap}.truck-quality-panel .info-grid{display:flex;flex-direction:column;gap:12px}.truck-quality-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.truck-quality-panel .info-row:hover{background:#ffffff0d}.truck-quality-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.truck-quality-panel .info-value{font-size:14px;color:#fff;font-weight:600}.truck-quality-panel .no-info{text-align:center;padding:40px 20px;color:#ffffff80}.truck-quality-panel .no-info p{margin:8px 0;font-size:14px}.truck-quality-panel .no-info-hint{font-size:12px;color:#00ffff80;font-style:italic}.truck-selector-inline{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;padding:12px;background:#0003;border-radius:10px;border:1px solid rgba(245,158,11,.2)}.truck-selector-label{font-size:12px;color:#ffffffb3;font-weight:500}.truck-selector-dropdown{width:100%;padding:10px 14px;background:#0006;border:1px solid rgba(245,158,11,.3);border-radius:8px;color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:all .3s ease;outline:none}.truck-selector-dropdown:hover{background:#00000080;border-color:#f59e0b80}.truck-selector-dropdown:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b33}.truck-selector-dropdown option{background:#1a1a2e;color:#fff;padding:8px}@media (max-width: 768px){.truck-quality-panel{width:calc(100% - 40px);left:20px!important;right:20px}.truck-quality-panel .quality-grid,.truck-quality-panel .fleet-stats{grid-template-columns:1fr}}.truck-quality-side-buttons{position:fixed;display:flex;flex-direction:column;gap:12px;z-index:100;pointer-events:none}.truck-quality-side-buttons .side-button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 10px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;min-width:70px;box-shadow:0 4px 16px #0000004d;pointer-events:all;-webkit-user-select:none;-moz-user-select:none;user-select:none}.truck-quality-side-buttons .side-button:hover{background:linear-gradient(135deg,#252547,#1f2f4f);border-color:#fff6;transform:translate(-4px);box-shadow:0 6px 20px #0006}.truck-quality-side-buttons .side-button-icon{font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center}.truck-quality-side-buttons .side-button-icon svg{width:24px;height:24px;stroke:currentColor}.truck-quality-side-buttons .side-button-label{font-size:11px;font-weight:600;color:#ffffffe6;text-align:center;white-space:nowrap}.truck-quality-side-buttons .side-button.network-button:hover{border-color:#8b5cf680;box-shadow:0 6px 20px #8b5cf64d}.mining-finance-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:450px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mining-finance-panel:active{box-shadow:0 12px 40px #22c55e4d}.mining-finance-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.mining-finance-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.mining-finance-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mining-finance-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.mining-finance-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.mining-finance-panel .header:hover .drag-handle{color:#22c55e99}.mining-finance-panel .header-title .icon{font-size:24px}.mining-finance-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#22c55e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.mining-finance-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.mining-finance-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.mining-finance-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.mining-finance-panel .tab-button.active{color:#22c55e;border-bottom-color:#22c55e;background:#22c55e0d}.mining-finance-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.mining-finance-panel .tab-content::-webkit-scrollbar{width:6px}.mining-finance-panel .tab-content::-webkit-scrollbar-track{background:#0003}.mining-finance-panel .tab-content::-webkit-scrollbar-thumb{background:#22c55e4d;border-radius:3px}.mining-finance-panel .section-title{font-size:16px;font-weight:600;color:#22c55e;margin:24px 0 16px;padding-bottom:8px;border-bottom:2px solid rgba(34,197,94,.3)}.mining-finance-panel .section-title:first-of-type{margin-top:0}.finance-section{margin-bottom:20px}.finance-card{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;transition:all .3s ease}.finance-card.revenue{border-color:#22c55e4d;background:#22c55e0d}.finance-card.expense{border-color:#ef44444d;background:#ef44440d}.finance-card.profit{border-color:#22c55e80;background:#22c55e1a}.finance-card.loss{border-color:#ef444480;background:#ef44441a}.finance-card.particulate{border-color:#a855f74d;background:#a855f70d}.finance-label{font-size:13px;color:#fff9;margin-bottom:8px;font-weight:500}.finance-value{font-size:24px;font-weight:700;color:#22c55e;margin-bottom:8px}.finance-card.expense .finance-value{color:#ef4444}.finance-card.profit .finance-value{color:#22c55e}.finance-card.loss .finance-value{color:#ef4444}.finance-detail{font-size:12px;color:#ffffff80;font-style:italic}.finance-breakdown{display:flex;flex-direction:column;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.breakdown-item{display:flex;justify-content:space-between;font-size:12px;color:#ffffffb3}.costs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.cost-card{background:#0003;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px;text-align:center;transition:all .3s ease}.cost-card:hover{background:#ffffff0d;transform:translateY(-2px)}.cost-icon{font-size:32px;margin-bottom:8px}.cost-label{font-size:12px;color:#fff9;margin-bottom:8px;font-weight:500}.cost-value{font-size:18px;font-weight:700;color:#ef4444;margin-bottom:6px}.cost-detail{font-size:11px;color:#fff6}.estimated-tons{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.estimated-card{background:#0003;border:1px solid rgba(34,197,94,.2);border-radius:12px;padding:14px;text-align:center}.estimated-label{font-size:12px;color:#fff9;margin-bottom:8px}.estimated-value{font-size:20px;font-weight:700;color:#22c55e}.particulate-button{width:100%;margin-top:12px;padding:10px;background:#a855f733;border:1px solid rgba(168,85,247,.3);border-radius:8px;color:#a855f7;cursor:pointer;font-weight:600;font-size:13px;transition:all .3s ease}.particulate-button:hover{background:#a855f74d;transform:scale(1.02)}@media (max-width: 768px){.mining-finance-panel{width:calc(100% - 40px);left:20px!important;right:20px}.costs-grid,.estimated-tons{grid-template-columns:1fr}}.mining-finance-side-buttons{position:fixed;display:flex;flex-direction:column;gap:12px;z-index:100;pointer-events:none}.mining-finance-side-buttons .side-button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 10px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;min-width:70px;box-shadow:0 4px 16px #0000004d;pointer-events:all;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mining-finance-side-buttons .side-button:hover{background:linear-gradient(135deg,#252547,#1f2f4f);border-color:#fff6;transform:translate(-4px);box-shadow:0 6px 20px #0006}.mining-finance-side-buttons .side-button-icon{font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center}.mining-finance-side-buttons .side-button-icon svg{width:24px;height:24px;stroke:currentColor}.mining-finance-side-buttons .side-button-label{font-size:11px;font-weight:600;color:#ffffffe6;text-align:center;white-space:nowrap}.mining-finance-side-buttons .side-button.network-button:hover{border-color:#8b5cf680;box-shadow:0 6px 20px #8b5cf64d}.particulate-matter-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:450px;max-height:calc(100vh - 140px);overflow:hidden;z-index:150;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.particulate-matter-panel:active{box-shadow:0 12px 40px #a855f74d}.particulate-matter-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.particulate-matter-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.particulate-matter-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.particulate-matter-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.particulate-matter-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.particulate-matter-panel .header:hover .drag-handle{color:#a855f799}.particulate-matter-panel .header-title .icon{font-size:24px}.particulate-matter-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#a855f7;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.particulate-matter-panel .header-actions{display:flex;align-items:center;gap:10px}.aqi-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.particulate-matter-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.particulate-matter-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.particulate-matter-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.particulate-matter-panel .tab-button.active{color:#a855f7;border-bottom-color:#a855f7;background:#a855f70d}.particulate-matter-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.particulate-matter-panel .tab-content::-webkit-scrollbar{width:6px}.particulate-matter-panel .tab-content::-webkit-scrollbar-track{background:#0003}.particulate-matter-panel .tab-content::-webkit-scrollbar-thumb{background:#a855f74d;border-radius:3px}.realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}.last-update{font-size:11px;color:#ffffff80}.section-title{font-size:16px;font-weight:600;color:#a855f7;margin:24px 0 16px;padding-bottom:8px;border-bottom:2px solid rgba(168,85,247,.3)}.section-title:first-of-type{margin-top:0}.section-title-small{font-size:14px;font-weight:600;color:#a855f7;margin:16px 0 12px}.pm-summary,.pm-summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.pm-summary-card{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:14px;text-align:center}.pm-summary-label{font-size:11px;color:#fff9;margin-bottom:8px}.pm-summary-value{font-size:18px;font-weight:700;color:#a855f7}.pm-summary-sub,.pm-metric-sub{font-size:10px;color:#ffffff80;margin-top:4px}.standards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}.standard-card,.standard-item{background:#a855f71a;border:1px solid rgba(168,85,247,.3);border-radius:12px;padding:14px;text-align:center}.standard-label{font-size:11px;color:#ffffffb3;margin-bottom:8px;font-weight:500}.standard-value{font-size:20px;font-weight:700;color:#a855f7;margin-bottom:4px}.standard-sub{font-size:10px;color:#ffffff80}.emission-summary,.pm-emissions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.emission-card,.pm-emission-card{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:14px;text-align:center}.emission-label,.pm-emission-label{font-size:11px;color:#fff9;margin-bottom:8px}.emission-value,.pm-emission-value{font-size:18px;font-weight:700;color:#a855f7;margin-bottom:4px}.emission-sub,.pm-emission-sub{font-size:10px;color:#ffffff80}.pm-unit{font-size:12px;font-weight:500;color:#fff9;margin-left:4px}.pm-info-box{font-size:11px;line-height:1.5}.risk-section{margin-bottom:20px}.risk-section-title{font-size:14px;font-weight:600;color:#a855f7;margin-bottom:12px}.risk-table{display:flex;flex-direction:column;gap:0;border:1px solid rgba(168,85,247,.2);border-radius:8px;overflow:hidden}.risk-row{display:grid;grid-template-columns:1fr 2fr 2fr;gap:8px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.1);font-size:12px}.risk-row:last-child{border-bottom:none}.risk-row.header{background:#a855f733;font-weight:600;color:#a855f7}.risk-cell{display:flex;align-items:center;color:#fffc}.current-risk-card{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:16px}.current-risk-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1);font-size:14px;font-weight:600}.current-risk-details{display:flex;flex-direction:column;gap:8px}.current-risk-detail{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding:6px 0}.current-risk-detail.highlight{font-weight:600;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);margin-top:4px}.current-risk-detail span:first-child{color:#ffffffb3}.current-risk-detail span:last-child{color:#a855f7}.route-quality-summary{margin-bottom:20px}.quality-main-indicator{border:2px solid;border-radius:16px;padding:20px;text-align:center;margin-bottom:16px;transition:all .3s ease}.quality-main-label{font-size:13px;color:#ffffffb3;margin-bottom:12px;font-weight:500;text-transform:uppercase}.quality-main-value{font-size:48px;font-weight:700;margin-bottom:8px;line-height:1}.quality-main-sub{font-size:12px;color:#fff9;margin-top:8px}.quality-impact-explanation{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:16px;margin-bottom:16px}.impact-title{font-size:14px;font-weight:600;color:#a855f7;margin-bottom:12px}.impact-details{display:flex;flex-direction:column;gap:8px}.impact-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:6px 0}.impact-row span:first-child{color:#ffffffb3}.impact-explanation-text{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;line-height:1.6;color:#fffc}.quality-breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.quality-breakdown-item{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:10px;padding:12px}.quality-breakdown-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;font-weight:600}.quality-breakdown-detail{display:flex;justify-content:space-between;align-items:center;font-size:12px;padding-top:6px;border-top:1px solid rgba(255,255,255,.1)}.quality-breakdown-detail span:first-child{color:#fff9}.environment-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.env-card,.env-item{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:14px;display:flex;align-items:center;gap:12px}.env-item{text-align:left}.env-card{text-align:center;flex-direction:column}.env-icon{font-size:28px;margin-bottom:8px;flex-shrink:0}.env-item .env-icon{margin-bottom:0;font-size:24px}.env-content{flex:1;display:flex;flex-direction:column;gap:4px}.env-label{font-size:11px;color:#fff9;margin-bottom:6px}.env-item .env-label{margin-bottom:0}.env-value{font-size:16px;font-weight:700;color:#a855f7}.route-pm-section{margin-bottom:20px}.route-pm-card{background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px;padding:16px}.route-pm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1);font-size:13px;font-weight:600}.route-pm-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.pm-metric{text-align:center}.pm-metric-label{font-size:11px;color:#fff9;margin-bottom:6px}.pm-metric-value{font-size:16px;font-weight:700;color:#a855f7}.aqi-legend{margin-top:20px;padding:16px;background:#0003;border:1px solid rgba(168,85,247,.2);border-radius:12px}.legend-title{font-size:13px;font-weight:600;color:#a855f7;margin-bottom:12px}.legend-items{display:flex;flex-direction:column;gap:8px}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#ffffffb3}.legend-color{width:20px;height:20px;border-radius:4px;border:1px solid rgba(255,255,255,.2)}.pm-main-indicator{border:2px solid;border-radius:16px;padding:24px;text-align:center;margin-bottom:20px;transition:all .3s ease}.pm-main-label{font-size:13px;color:#fff9;margin-bottom:12px;font-weight:500;text-transform:uppercase;letter-spacing:1px}.pm-main-aqi{font-size:48px;font-weight:700;margin-bottom:8px;line-height:1}.pm-main-status{font-size:16px;font-weight:600}.pm-standards-section,.pm-summary-section,.pm-emissions-section,.pm-environment-section,.pm-alerts-section{margin-bottom:20px}.pm-alerts-section{margin-bottom:24px}.pm-recommendations-section{margin-top:24px;padding-top:24px;border-top:2px solid rgba(255,255,255,.1)}@media (max-width: 768px){.particulate-matter-panel{width:calc(100% - 40px);left:20px!important;right:20px}.pm-summary,.environment-grid,.route-pm-metrics{grid-template-columns:1fr}}.particulate-matter-side-buttons{position:fixed;display:flex;flex-direction:column;gap:12px;z-index:150;pointer-events:none}.particulate-matter-side-buttons .side-button{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 10px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.2);border-radius:12px;color:#fff;cursor:pointer;transition:all .3s ease;min-width:70px;box-shadow:0 4px 16px #0000004d;pointer-events:all;-webkit-user-select:none;-moz-user-select:none;user-select:none}.particulate-matter-side-buttons .side-button:hover{background:linear-gradient(135deg,#252547,#1f2f4f);border-color:#fff6;transform:translate(-4px);box-shadow:0 6px 20px #0006}.particulate-matter-side-buttons .side-button-icon{font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center}.particulate-matter-side-buttons .side-button-icon svg{width:24px;height:24px;stroke:currentColor}.particulate-matter-side-buttons .side-button-label{font-size:11px;font-weight:600;color:#ffffffe6;text-align:center;white-space:nowrap}.particulate-matter-side-buttons .side-button.network-button:hover{border-color:#8b5cf680;box-shadow:0 6px 20px #8b5cf64d}.security-alerts-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:480px;max-width:calc(100vw - 40px);max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;box-sizing:border-box}.security-alerts-panel:active{box-shadow:0 12px 40px #00ffff4d}.security-alerts-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.security-alerts-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.security-alerts-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.security-alerts-panel .header:active{background:#00ffff0d}.security-alerts-panel .header-title{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.security-alerts-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.security-alerts-panel .header:hover .drag-handle{color:#0ff9}.security-alerts-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.security-alerts-panel .header-title .icon{font-size:20px;animation:pulse 2s ease-in-out infinite;display:inline-block;line-height:1.5;flex-shrink:0;padding:0;margin:0 0 0 8px;vertical-align:middle}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.security-alerts-panel .header h3{margin:0;font-size:16px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;line-height:1.5;display:flex;align-items:center}.security-alerts-panel .header-actions{display:flex;align-items:center;gap:10px}.security-alerts-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.security-alerts-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.security-alerts-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.security-alerts-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.security-alerts-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.security-alerts-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.security-alerts-panel .tab-content::-webkit-scrollbar{width:6px}.security-alerts-panel .tab-content::-webkit-scrollbar-track{background:#0003}.security-alerts-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.security-alerts-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.security-alerts-panel .summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.security-alerts-panel .data-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;transition:all .3s ease}.security-alerts-panel .data-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.security-alerts-panel .data-label{font-size:11px;color:#fff9;margin-bottom:6px;font-weight:500}.security-alerts-panel .data-value{font-size:22px;font-weight:700;color:#0ff}.security-alerts-panel .perimeter-toggle-row{margin-bottom:16px;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.security-alerts-panel .perimeter-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:13px;color:#fffc;font-weight:500}.security-alerts-panel .perimeter-toggle input{width:18px;height:18px;cursor:pointer}.security-alerts-panel .search-row{margin-bottom:16px}.security-alerts-panel .search-input{width:100%;padding:10px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:13px;transition:all .2s ease}.security-alerts-panel .search-input:focus{outline:none;background:#ffffff14;border-color:#00ffff80;box-shadow:0 0 0 3px #00ffff1a}.security-alerts-panel .search-input::-moz-placeholder{color:#fff6}.security-alerts-panel .search-input::placeholder{color:#fff6}.security-alerts-panel .sensors-list{display:flex;flex-direction:column;gap:10px}.security-alerts-panel .sensor-item{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;transition:all .3s ease}.security-alerts-panel .sensor-item.has-alert{border-color:#ef444480;background:#ef44441a}.security-alerts-panel .sensor-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.security-alerts-panel .sensor-header-row{display:flex;align-items:center;justify-content:space-between;padding:14px;cursor:pointer}.security-alerts-panel .sensor-header-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.security-alerts-panel .sensor-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px}.security-alerts-panel .sensor-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.security-alerts-panel .sensor-id{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.security-alerts-panel .sensor-header-right{display:flex;align-items:center;gap:10px}.security-alerts-panel .alert-badge{font-size:18px;animation:pulse 2s ease-in-out infinite}.security-alerts-panel .expand-icon{color:#ffffff80;font-size:14px;transition:transform .2s ease}.security-alerts-panel .sensor-header-row:hover .expand-icon{color:#0ffc}.security-alerts-panel .sensor-details{padding:0 14px 14px;animation:slideDown .3s ease-out}.security-alerts-panel .info-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.security-alerts-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.security-alerts-panel .info-row:hover{background:#ffffff0d}.security-alerts-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.security-alerts-panel .info-value{font-size:14px;color:#fff;font-weight:600}.security-alerts-panel .info-value.alert{color:#ef4444}.security-alerts-panel .info-value.active{color:#10b981}.security-alerts-panel .alert-card{padding:14px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:10px;margin-bottom:16px}.security-alerts-panel .alert-header-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}.security-alerts-panel .alert-icon{font-size:20px}.security-alerts-panel .alert-title-text{flex:1;font-size:14px;font-weight:700;color:#fff;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.security-alerts-panel .alert-time-badge{font-size:11px;font-weight:600;padding:4px 10px;background:#ef444433;border-radius:12px;color:#ef4444}.security-alerts-panel .alert-description-text{font-size:13px;color:#fffc;line-height:1.5;margin-bottom:12px;word-wrap:break-word;overflow-wrap:break-word}.security-alerts-panel .alert-actions{display:flex;gap:8px}.security-alerts-panel .action-btn{flex:1;padding:8px 12px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;border:1px solid;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis}.security-alerts-panel .action-btn.navigate{background:#00ffff1a;border-color:#00ffff4d;color:#0ff}.security-alerts-panel .action-btn.navigate:hover{background:#0ff3;transform:translateY(-1px)}.security-alerts-panel .action-btn.report{background:#8b5cf61a;border-color:#8b5cf64d}.security-alerts-panel .bitacora-report-btn{padding:8px 16px!important;font-size:12px!important;font-weight:600;background:#8b5cf626!important;border-color:#8b5cf666!important;color:#a78bfa!important;border-radius:8px;transition:all .2s ease;flex-shrink:0}.security-alerts-panel .bitacora-report-btn:hover{background:#8b5cf640!important;border-color:#8b5cf699!important;color:#c4b5fd!important;transform:translateY(-1px);box-shadow:0 2px 8px #8b5cf64d;color:#a78bfa}.security-alerts-panel .action-btn.report:hover{background:#8b5cf633;transform:translateY(-1px)}.security-alerts-panel .navigate-btn{width:100%;padding:10px 14px;background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:8px;color:#0ff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.security-alerts-panel .navigate-btn:hover{background:#0ff3;border-color:#00ffff80;transform:translateY(-1px)}.security-alerts-panel .alerts-list{display:flex;flex-direction:column;gap:12px}.security-alerts-panel .alert-item-card{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;transition:all .3s ease}.security-alerts-panel .alert-item-card:hover{background:#ef44441a;border-color:#ef44444d;transform:translate(4px);box-shadow:0 2px 12px #ef444433}.security-alerts-panel .alert-item-header{display:flex;align-items:center;justify-content:space-between;padding:14px;border-bottom:1px solid rgba(255,255,255,.1)}.security-alerts-panel .alert-item-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.security-alerts-panel .alert-item-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border-radius:8px}.security-alerts-panel .alert-item-sensor{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.security-alerts-panel .alert-item-id{font-size:11px;color:#ffffff80;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.security-alerts-panel .alert-item-badge{padding:6px 10px;border-radius:12px;font-size:16px}.security-alerts-panel .alert-item-content{padding:14px}.security-alerts-panel .alert-item-title{font-size:15px;font-weight:700;color:#fff;margin-bottom:8px}.security-alerts-panel .alert-item-description{font-size:13px;color:#ffffffb3;margin-bottom:8px;line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.security-alerts-panel .alert-item-time{font-size:12px;color:#ffffff80;margin-bottom:12px}.security-alerts-panel .alert-item-actions{display:flex;gap:8px}.security-alerts-panel .reports-section{display:flex;flex-direction:column;gap:24px}.security-alerts-panel .documents-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.security-alerts-panel .documents-header h4{margin:0 0 6px;font-size:16px;font-weight:600;color:#0ff}.security-alerts-panel .documents-subtitle{margin:0;font-size:12px;color:#ffffff80}.security-alerts-panel .documents-list{display:flex;flex-direction:column;gap:10px}.security-alerts-panel .document-item{display:flex;flex-direction:row;align-items:center;gap:14px;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;cursor:pointer;transition:all .3s ease}.security-alerts-panel .document-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.security-alerts-panel .document-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#00ffff1a;border-radius:8px;flex-shrink:0;order:-1}.security-alerts-panel .document-info{flex:1;min-width:0}.security-alerts-panel .document-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.security-alerts-panel .document-meta{display:flex;flex-direction:column;gap:2px}.security-alerts-panel .file-path{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;word-break:break-word;overflow-wrap:break-word;max-width:100%}.security-alerts-panel .file-date{font-size:11px;color:#fff6}.security-alerts-panel .document-action{font-size:18px;color:#00ffff80;transition:all .3s ease}.security-alerts-panel .document-item:hover .document-action{color:#0ff;transform:translate(4px)}.security-alerts-panel .no-sensors,.security-alerts-panel .no-alerts,.security-alerts-panel .no-documents{text-align:center;padding:40px 20px;color:#ffffff80}.security-alerts-panel .no-sensors p,.security-alerts-panel .no-alerts p,.security-alerts-panel .no-documents p{margin:8px 0;font-size:14px}.security-alerts-panel .no-alerts-hint,.security-alerts-panel .no-documents-hint{font-size:12px;color:#00ffff80;font-style:italic}.security-alerts-panel .filter-row{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.security-alerts-panel .filter-label{font-size:13px;color:#ffffffb3;font-weight:500;white-space:nowrap}.security-alerts-panel .filter-select{flex:1;padding:8px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:13px;cursor:pointer;transition:all .2s ease}.security-alerts-panel .filter-select:focus{outline:none;background:#ffffff14;border-color:#00ffff80;box-shadow:0 0 0 3px #00ffff1a}.security-alerts-panel .filter-select option{background:#1a1a2e;color:#fff}.security-alerts-panel .reports-filters{margin-bottom:20px}.security-alerts-panel .devices-report-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.security-alerts-panel .device-report-item{display:flex;align-items:center;justify-content:space-between;padding:14px;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:10px;transition:all .3s ease}.security-alerts-panel .device-report-item:hover{background:#00ffff1a;border-color:#00ffff4d;transform:translate(4px);box-shadow:0 2px 12px #0ff3}.security-alerts-panel .device-report-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.security-alerts-panel .device-report-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.security-alerts-panel .device-report-id{font-size:11px;color:#00ffffb3;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.security-alerts-panel .confirmation-dialog-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.security-alerts-panel .confirmation-dialog{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;padding:0;width:400px;max-width:90vw;box-shadow:0 8px 32px #0009;border:1px solid rgba(255,255,255,.1);overflow:hidden}.security-alerts-panel .confirmation-dialog-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff08}.security-alerts-panel .confirmation-dialog-header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.security-alerts-panel .confirmation-dialog-content{padding:24px}.security-alerts-panel .confirmation-dialog-content p{margin:0 0 16px;color:#fffc;font-size:14px}.security-alerts-panel .confirmation-dialog-content p strong{color:#0ff;font-weight:600}.security-alerts-panel .confirmation-buttons{display:flex;flex-direction:column;gap:12px;margin-top:20px}.security-alerts-panel .confirmation-btn{padding:14px 20px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;border:2px solid;width:100%}.security-alerts-panel .confirmation-btn.action-btn{background:#10b9811a;border-color:#10b98180;color:#10b981}.security-alerts-panel .confirmation-btn.action-btn:hover{background:#10b98133;border-color:#10b981cc;transform:translateY(-2px);box-shadow:0 4px 12px #10b9814d}.security-alerts-panel .confirmation-btn.false-alarm-btn{background:#f59e0b1a;border-color:#f59e0b80;color:#f59e0b}.security-alerts-panel .confirmation-btn.false-alarm-btn:hover{background:#f59e0b33;border-color:#f59e0bcc;transform:translateY(-2px);box-shadow:0 4px 12px #f59e0b4d}.security-alerts-panel .verification-panel-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.security-alerts-panel .verification-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;padding:0;width:600px;max-width:90vw;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #00000080}.security-alerts-panel .verification-panel-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08}.security-alerts-panel .verification-panel-header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.security-alerts-panel .verification-panel-content{padding:24px;overflow-y:auto;flex:1}.security-alerts-panel .verification-info{margin-bottom:24px;padding:16px;background:#ffffff08;border-radius:10px;border-left:3px solid rgba(0,255,255,.5)}.security-alerts-panel .verification-info p{margin:8px 0;font-size:14px;color:#fffc}.security-alerts-panel .verification-info p strong{color:#0ff;font-weight:600}.security-alerts-panel .cameras-section{margin-bottom:24px}.security-alerts-panel .cameras-section h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#0ff}.security-alerts-panel .cameras-container{min-height:200px;background:#0000004d;border-radius:10px;padding:20px;border:1px solid rgba(255,255,255,.1)}.security-alerts-panel .no-cameras-message{text-align:center;padding:40px 20px;color:#fff9}.security-alerts-panel .no-cameras-message p{margin:12px 0;font-size:14px}.security-alerts-panel .guard-verification-message{color:#f59e0b!important;font-weight:600;font-size:15px!important;margin-top:16px!important}.security-alerts-panel .cameras-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.security-alerts-panel .camera-feed{background:#00000080;border-radius:8px;padding:20px;border:1px solid rgba(255,255,255,.1);min-height:150px;display:flex;align-items:center;justify-content:center;color:#ffffff80}.security-alerts-panel .verification-actions{display:flex;gap:12px;margin-top:24px}.security-alerts-panel .verification-actions .action-btn{flex:1;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;color:#fff}.security-alerts-panel .confirmation-form-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1001;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.security-alerts-panel .confirmation-form-panel{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;padding:0;width:700px;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #00000080}.security-alerts-panel .confirmation-form-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08}.security-alerts-panel .confirmation-form-header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.security-alerts-panel .confirmation-form-content{padding:24px;overflow-y:auto;flex:1}.security-alerts-panel .form-section{margin-bottom:24px;padding:16px;background:#ffffff08;border-radius:10px;border-left:3px solid rgba(0,255,255,.5)}.security-alerts-panel .form-section h4{margin:0 0 16px;font-size:16px;font-weight:600;color:#0ff}.security-alerts-panel .form-group{margin-bottom:16px}.security-alerts-panel .form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:#fffc}.security-alerts-panel .form-input,.security-alerts-panel .form-textarea{width:100%;padding:10px 12px;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:14px;font-family:inherit;transition:all .2s ease;box-sizing:border-box}.security-alerts-panel .form-input:focus,.security-alerts-panel .form-textarea:focus{outline:none;border-color:#00ffff80;background:#0006}.security-alerts-panel .form-textarea{resize:vertical;min-height:80px}.security-alerts-panel .form-actions{margin-top:24px;display:flex;flex-direction:column;gap:12px}.security-alerts-panel.verification-panel-window{position:fixed!important;width:750px!important;max-width:90vw!important;max-height:85vh!important;min-height:500px!important;z-index:1000!important;background:linear-gradient(135deg,#1a1a2e,#16213e)!important;border-radius:12px!important;box-shadow:0 8px 32px #00000080!important;border:1px solid rgba(255,255,255,.1)!important;display:flex!important;flex-direction:column!important;overflow:hidden!important}.security-alerts-panel.verification-panel-window .panel-content{padding:24px!important;overflow-y:auto!important;flex:1!important;min-height:0!important}.security-alerts-panel .camera-viewer-container{display:flex;flex-direction:column;gap:16px}.security-alerts-panel .camera-selector{margin-bottom:16px}.security-alerts-panel .camera-video-container{position:relative;width:100%;background:#000c;border-radius:10px;overflow:hidden;min-height:300px;display:flex;align-items:center;justify-content:center}.security-alerts-panel .camera-video{width:100%;height:auto;max-height:500px;-o-object-fit:contain;object-fit:contain;background:#000}.security-alerts-panel .camera-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#fffc}.security-alerts-panel .loading-spinner{width:40px;height:40px;border:4px solid rgba(0,255,255,.2);border-top-color:#0ff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.security-alerts-panel .camera-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#ef4444;text-align:center}.security-alerts-panel .camera-placeholder{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:#ffffff80;text-align:center;font-size:14px}.security-alerts-panel .camera-info{position:absolute;bottom:10px;left:10px;right:10px;display:flex;justify-content:space-between;align-items:center;background:#000000b3;padding:8px 12px;border-radius:6px;font-size:11px;color:#fffc;z-index:10}.security-alerts-panel .camera-video-wrapper{position:relative;width:100%;height:100%;overflow:hidden}.security-alerts-panel .camera-video-controls{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.4) 50%,transparent 100%);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:20}.security-alerts-panel .camera-video-controls.controls-visible{opacity:1;pointer-events:auto}.security-alerts-panel .video-control-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:8px 12px;cursor:pointer;font-size:18px;color:#fff;display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.security-alerts-panel .video-control-btn:hover{background:#ffffff40;border-color:#fff6;transform:scale(1.05)}.security-alerts-panel .video-control-btn:active{transform:scale(.95)}@media (max-width: 768px){.security-alerts-panel{width:calc(100% - 40px);left:20px;right:20px}.security-alerts-panel .summary-grid{grid-template-columns:1fr}.security-alerts-panel .camera-video-container{min-height:200px}}.scene-points-panel{position:fixed;top:120px;left:24px;min-width:360px;max-width:calc(100vw - 48px);max-height:calc(100vh - 160px);background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:18px;border:1px solid rgba(255,255,255,.08);box-shadow:0 18px 48px #00000073;display:flex;flex-direction:column;overflow:hidden;z-index:80;color:#e5e7eb}.scene-points-panel .header{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid rgba(255,255,255,.08);background:#0f766e2e}.scene-points-panel .header-info{display:flex;align-items:center;gap:12px}.scene-points-panel .header-info .icon{font-size:22px}.scene-points-panel .header-info h3{margin:0;font-size:16px;font-weight:600;color:#5eead4}.scene-points-panel .header-info p{margin:2px 0 0;font-size:12px;color:#d1fae5bf}.scene-points-panel .close-button{background:#ef44442e;border:1px solid rgba(239,68,68,.28);color:#fecaca;border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.scene-points-panel .close-button:hover{background:#f8717152;transform:scale(1.05)}.scene-points-panel .list{flex:1;overflow-y:auto;padding:18px 18px 22px;display:flex;flex-direction:column;gap:12px}.scene-points-panel .list::-webkit-scrollbar{width:6px}.scene-points-panel .list::-webkit-scrollbar-track{background:#1118278c}.scene-points-panel .list::-webkit-scrollbar-thumb{background:#0ea5e973;border-radius:3px}.scene-points-panel .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;border-radius:16px;background:#1e293bb3;border:1px dashed rgba(94,234,212,.25);gap:12px;color:#e2e8f0b3;text-align:center}.scene-points-panel .empty-state span{font-size:26px}.scene-points-panel .point-card{display:flex;align-items:center;justify-content:space-between;background:#2563eb29;border-radius:16px;border:1px solid rgba(59,130,246,.25);padding:14px 16px;gap:12px;transition:transform .2s ease,box-shadow .2s ease;min-width:0;width:100%;box-sizing:border-box}.scene-points-panel .point-card:hover{transform:translateY(-2px);box-shadow:0 16px 32px #3b82f659;border-color:#bfdbfe73}.scene-points-panel .point-main{display:flex;align-items:center;gap:12px;flex:1}.scene-points-panel .color-dot{width:14px;height:14px;border-radius:50%;box-shadow:0 0 12px #bfdbfe8c}.scene-points-panel .point-info{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1;overflow:hidden}.scene-points-panel .point-name{font-size:14px;font-weight:600;color:#f9fafb;word-break:break-word;overflow-wrap:break-word;line-height:1.4}.scene-points-panel .point-meta{font-size:11px;color:#e2e8f0b3;display:flex;flex-direction:column;gap:2px}.scene-points-panel .point-meta .type{letter-spacing:.4px;text-transform:uppercase}.scene-points-panel .actions{display:flex;gap:8px;flex-shrink:0}.scene-points-panel .actions button{width:36px;height:36px;border-radius:10px;border:1px solid rgba(148,197,255,.25);background:#3b82f638;color:#e0f2fe;font-size:16px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.scene-points-panel .actions button:hover{background:#60a5fa61;transform:translateY(-1px)}.scene-points-panel .actions .open-button{background:#93c5fd38}.scene-points-panel .actions .open-button:hover{background:#818cf859}@media (max-width: 768px){.scene-points-panel{width:calc(100vw - 40px);left:20px;right:20px;top:120px}}.inventory-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;min-width:450px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.inventory-panel:active{box-shadow:0 12px 40px #00ffff4d}.inventory-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.inventory-panel .header:active{background:#00ffff0d}.inventory-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.inventory-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.inventory-panel .header:hover .drag-handle{color:#0ff9}.inventory-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.inventory-panel .header-title .icon{font-size:24px}.inventory-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px;flex:1}.inventory-panel .header-actions{display:flex;align-items:center;gap:10px}.inventory-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.inventory-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.inventory-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.inventory-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.inventory-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.inventory-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.inventory-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.inventory-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.inventory-panel .tab-content::-webkit-scrollbar{width:6px}.inventory-panel .tab-content::-webkit-scrollbar-track{background:#0003}.inventory-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.inventory-panel .tab-content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.inventory-panel .filters-section{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.inventory-panel .filter-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.inventory-panel .filter-group{flex:1;min-width:140px;display:flex;flex-direction:column;gap:6px}.inventory-panel .filter-group.full-width{flex:1 1 100%;min-width:100%}.inventory-panel .filter-group.date-range{flex:1;min-width:150px}.inventory-panel .warehouse-selector{display:flex;align-items:center;gap:10px}.inventory-panel .filter-group label{font-size:12px;color:#ffffffb3;font-weight:500;white-space:nowrap;margin-bottom:4px}.inventory-panel .filter-input,.inventory-panel .date-input{flex:1;background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:8px;padding:8px 12px;color:#fff;font-size:13px;transition:all .3s ease;min-width:150px}.inventory-panel .filter-input::-moz-placeholder,.inventory-panel .date-input::-moz-placeholder{color:#fff6}.inventory-panel .filter-input::placeholder,.inventory-panel .date-input::placeholder{color:#fff6}.inventory-panel .filter-input:hover,.inventory-panel .date-input:hover{background:#00ffff26;border-color:#00ffff80}.inventory-panel .filter-input:focus,.inventory-panel .date-input:focus{outline:none;background:#0ff3;border-color:#00ffffb3}.inventory-panel .clear-filters-btn{background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:8px 12px;color:#ef4444;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap}.inventory-panel .clear-filters-btn:hover{background:#ef44444d;border-color:#ef444480}.inventory-panel .warehouse-selector label{font-size:13px;color:#ffffffb3;font-weight:500}.inventory-panel .warehouse-select,.inventory-panel .sort-select{flex:1;background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:8px;padding:8px 12px;color:#fff;font-size:13px;cursor:pointer;transition:all .3s ease}.inventory-panel .warehouse-select:hover,.inventory-panel .sort-select:hover{background:#00ffff26;border-color:#00ffff80}.inventory-panel .warehouse-select option,.inventory-panel .sort-select option{background:#1a1a2e;color:#fff}.inventory-panel .filter-buttons{display:flex;gap:8px}.inventory-panel .filter-btn{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:8px 12px;color:#ffffffb3;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease}.inventory-panel .filter-btn:hover{background:#ffffff1a;color:#fff}.inventory-panel .filter-btn.active{background:#0ff3;border-color:#00ffff80;color:#0ff}.inventory-panel .filter-btn.filter-in.active{background:#10b98133;border-color:#10b98180;color:#10b981}.inventory-panel .filter-btn.filter-out.active{background:#ef444433;border-color:#ef444480;color:#ef4444}.inventory-panel .sort-controls{display:flex;align-items:center;gap:10px;flex:1;min-width:100%}.inventory-panel .sort-controls label{white-space:nowrap;font-size:13px;color:#ffffffb3;font-weight:500}.inventory-panel .sort-order-btn{background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:8px;padding:8px 12px;color:#0ff;font-size:16px;cursor:pointer;transition:all .3s ease;min-width:40px}.inventory-panel .sort-order-btn:hover{background:#0ff3;border-color:#00ffff80}.inventory-panel .movements-summary{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:16px;margin-bottom:16px;padding:12px;background:#0003;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.inventory-panel .summary-item{flex:0 0 auto;min-width:100px;max-width:130px;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:#ffffff08;border-radius:6px}.inventory-panel .summary-item.summary-in{border-left:3px solid #10b981}.inventory-panel .summary-item.summary-out{border-left:3px solid #ef4444}.inventory-panel .summary-label{font-size:11px;color:#fff9;font-weight:500}.inventory-panel .summary-value{font-size:18px;font-weight:700;color:#0ff}.inventory-panel .summary-item.summary-in .summary-value{color:#10b981}.inventory-panel .summary-item.summary-out .summary-value{color:#ef4444}.inventory-panel .movements-table-container{overflow-x:auto;margin-top:16px}.inventory-panel .movements-table{width:100%;border-collapse:collapse;font-size:13px}.inventory-panel .movements-table thead{background:#00ffff1a}.inventory-panel .movements-table th{padding:12px 8px;text-align:left;font-weight:600;color:#0ff;border-bottom:2px solid rgba(0,255,255,.3)}.inventory-panel .movements-table td{padding:10px 8px;border-bottom:1px solid rgba(255,255,255,.1)}.inventory-panel .movements-table tbody tr:hover{background:#00ffff0d}.inventory-panel .movements-table tbody tr.row-in{border-left:3px solid #10b981}.inventory-panel .movements-table tbody tr.row-out{border-left:3px solid #ef4444}.inventory-panel .movements-table tbody tr.row-in:hover{background:#10b9811a}.inventory-panel .movements-table tbody tr.row-out:hover{background:#ef44441a}.inventory-panel .rfid-cell{font-family:Courier New,monospace;color:#0ff;font-weight:600}.inventory-panel .movement-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600}.inventory-panel .movement-badge.in{background:#10b98133;color:#10b981;border:1px solid rgba(16,185,129,.3)}.inventory-panel .movement-badge.out{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.inventory-panel .inventory-list,.inventory-panel .transit-list{display:flex;flex-direction:column;gap:12px;margin-top:16px}.inventory-panel .inventory-item,.inventory-panel .transit-item{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:16px;transition:all .3s ease}.inventory-panel .inventory-item:hover,.inventory-panel .transit-item:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.inventory-panel .inventory-item-header,.inventory-panel .transit-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.inventory-panel .item-rfid{font-family:Courier New,monospace;font-size:14px;font-weight:700;color:#0ff}.inventory-panel .status-badge{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}.inventory-panel .status-badge-small{padding:3px 8px;border-radius:8px;font-size:10px;font-weight:600;color:#fff;display:inline-block}.inventory-panel .status-badge-small.in-bodega{background-color:#10b981}.inventory-panel .status-badge-small.in-transit{background-color:#f59e0b}.inventory-panel .inventory-item-body,.inventory-panel .transit-item-body{display:flex;flex-direction:column;gap:8px}.inventory-panel .item-row{display:flex;justify-content:space-between;align-items:center}.inventory-panel .item-label{font-size:12px;color:#fff9;font-weight:500}.inventory-panel .item-value{font-size:13px;color:#fff;font-weight:600}.inventory-panel .item-value.expiration{font-weight:700}.inventory-panel .transit-status{color:#f59e0b}.inventory-panel .transit-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.inventory-panel .transit-subtitle{margin:0;font-size:12px;color:#ffffff80}.inventory-panel .config-section{padding:20px 0}.inventory-panel .config-section h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#0ff}.inventory-panel .config-hint{margin:0;font-size:12px;color:#ffffff80}.inventory-panel .no-data{text-align:center;padding:40px 20px;color:#ffffff80;font-size:14px}.inventory-panel .resize-handle{position:absolute;bottom:0;right:0;width:20px;height:20px;cursor:nwse-resize;z-index:10;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(0,255,255,.3) 40%,rgba(0,255,255,.3) 45%,transparent 45%,transparent 55%,rgba(0,255,255,.3) 55%,rgba(0,255,255,.3) 60%,transparent 60%);transition:background .2s ease}.inventory-panel .resize-handle:hover{background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(0,255,255,.6) 40%,rgba(0,255,255,.6) 45%,transparent 45%,transparent 55%,rgba(0,255,255,.6) 55%,rgba(0,255,255,.6) 60%,transparent 60%)}.status-badge-small.in-transit{background-color:#f59e0b}.logistics-dashboard{min-width:500px;min-height:500px}.dashboard-content{padding:20px;overflow-y:auto;height:calc(100% - 80px)}.dashboard-section{margin-bottom:30px}.dashboard-section:last-child{margin-bottom:0}.section-title{font-size:16px;font-weight:600;color:#0ff;margin:0 0 15px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:15px}.stat-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:15px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.stat-card:hover{background:#ffffff14;border-color:#00ffff4d;transform:translateY(-2px)}.stat-card.warning{border-color:#f59e0b80;background:#f59e0b1a}.stat-icon{font-size:32px;line-height:1}.stat-info{flex:1}.stat-label{font-size:11px;color:#fff9;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:24px;font-weight:700;color:#0ff}.stat-card.warning .stat-value{color:#f59e0b}.movements-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.movement-summary-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:15px;transition:all .3s ease}.movement-summary-card:hover{background:#ffffff14;border-color:#00ffff4d;transform:translateY(-2px)}.movement-warehouse{font-size:18px;font-weight:600;color:#0ff;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.movement-stats{display:flex;flex-direction:column;gap:8px}.movement-stat{display:flex;justify-content:space-between;align-items:center;font-size:13px}.movement-label{color:#ffffffb3}.movement-value{font-weight:600;color:#fff}.movement-stat.in .movement-value{color:#10b981}.movement-stat.out .movement-value{color:#ef4444}.alerts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px}.alert-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:15px;display:flex;align-items:center;gap:12px;transition:all .3s ease}.alert-card:hover{transform:translateY(-2px)}.alert-card.critical{border-color:#ef444480;background:#ef44441a}.alert-card.warning{border-color:#f59e0b80;background:#f59e0b1a}.alert-card.info{border-color:#3b82f680;background:#3b82f61a}.alert-card.success{border-color:#10b98180;background:#10b9811a}.alert-icon{font-size:32px;line-height:1}.alert-info{flex:1}.alert-label{font-size:11px;color:#ffffffb3;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.alert-value{font-size:20px;font-weight:700;color:#fff}.alert-card.critical .alert-value{color:#ef4444}.alert-card.warning .alert-value{color:#f59e0b}.alert-card.info .alert-value{color:#3b82f6}.alert-card.success .alert-value{color:#10b981}.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:15px}.tool-button{background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:12px;padding:20px;color:#fff;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:10px;font-size:13px;font-weight:500}.tool-button:hover{background:#0ff3;border-color:#00ffff80;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.tool-button:active{transform:translateY(0)}.tool-icon{font-size:32px;line-height:1}.tool-label{text-align:center;color:#ffffffe6}.alerts-panel{min-width:500px;min-height:500px}.alerts-content{padding:20px;overflow-y:auto;height:calc(100% - 80px)}.alert-badge-header{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;border-radius:12px;font-size:12px;font-weight:700;color:#fff;margin-right:10px}.alerts-summary-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:30px}.alert-summary-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;display:flex;align-items:center;gap:15px;transition:all .3s ease}.alert-summary-card:hover{background:#ffffff14;transform:translateY(-2px)}.alert-summary-card.critical{border-color:#ef444480;background:#ef44441a}.alert-summary-card.warning{border-color:#f59e0b80;background:#f59e0b1a}.alert-summary-icon{font-size:40px;line-height:1}.alert-summary-info{flex:1}.alert-summary-label{font-size:12px;color:#ffffffb3;margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.alert-summary-value{font-size:28px;font-weight:700;color:#fff}.alerts-section{margin-bottom:30px}.alerts-section:last-child{margin-bottom:0}.alerts-list{display:flex;flex-direction:column;gap:15px}.alert-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:15px;transition:all .3s ease}.alert-item:hover{background:#ffffff14;transform:translate(4px)}.alert-item.critical{border-left:4px solid #ef4444;background:#ef44441a}.alert-item.warning{border-left:4px solid #f59e0b;background:#f59e0b1a}.alert-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.1)}.alert-item-rfid{font-size:14px;font-weight:600;color:#0ff;font-family:Courier New,monospace}.alert-item-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;color:#fff}.alert-item-body{display:flex;flex-direction:column;gap:8px}.alert-item-row{display:flex;justify-content:space-between;align-items:center;font-size:13px}.alert-item-label{color:#fff9;font-weight:500}.alert-item-value{color:#fff;font-weight:500}.expiration-critical{color:#ef4444!important;font-weight:700!important}.no-alerts{text-align:center;padding:40px 20px;color:#ffffff80;font-size:14px;background:#ffffff08;border-radius:12px;border:1px dashed rgba(255,255,255,.1)}.alerts-list-container{max-height:calc(100vh - 400px);overflow-y:auto;padding-right:5px}.alerts-list-container::-webkit-scrollbar{width:6px}.alerts-list-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.alerts-list-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.alerts-list-container::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.alert-item-compact{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px;margin-bottom:10px;transition:all .2s ease;cursor:pointer}.alert-item-compact:hover{background:#ffffff14;transform:translate(4px);border-color:#fff3}.alert-item-compact.critical{border-left:4px solid #ef4444;background:#ef444414}.alert-item-compact.warning{border-left:4px solid #f59e0b;background:#f59e0b14}.alert-item-compact-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.alert-item-compact-left{display:flex;align-items:center;gap:10px;flex:1}.alert-item-rfid-compact{font-size:13px;font-weight:600;color:#0ff;font-family:Courier New,monospace}.alert-item-type-badge{display:inline-block;padding:3px 8px;border-radius:8px;font-size:10px;font-weight:600;color:#fffc;background:#ffffff1a}.alert-item-badge-compact{display:inline-block;padding:4px 10px;border-radius:12px;font-size:10px;font-weight:600;color:#fff;white-space:nowrap}.alert-item-compact-body{display:flex;flex-direction:column;gap:8px}.alert-item-compact-main{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.alert-item-compact-material{font-size:14px;font-weight:600;color:#fff;flex:1}.alert-item-compact-quantity{font-size:13px;color:#ffffffb3;font-weight:500}.alert-item-compact-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;font-size:11px}.alert-detail-item{display:flex;flex-direction:column;gap:2px}.alert-detail-label{color:#ffffff80;font-size:10px;text-transform:uppercase;letter-spacing:.5px}.alert-detail-value{color:#fff;font-weight:500;font-size:12px}.alert-detail-value.expiration-critical{color:#ef4444;font-weight:700}.alerts-filters{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid rgba(255,255,255,.1)}.alerts-filters .filter-row{display:flex;align-items:center;gap:15px;margin-bottom:12px}.filter-info-note{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:8px;font-size:12px;color:#ffffffb3}.filter-info-note .info-icon{font-size:14px;color:#0ff}.alerts-filters .filter-group{display:flex;flex-direction:column;gap:6px}.alerts-filters .filter-group label{font-size:11px;color:#fff9;font-weight:500}.alerts-filters .clear-filters-btn{background:#ef4444;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .3s ease;width:100%}.alerts-filters .clear-filters-btn:hover{background:#dc2626}.alerts-tab-content{padding:20px;display:flex;flex-direction:column;gap:20px;flex:1;overflow:hidden;min-height:0}.alerts-summary-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-bottom:0}.alert-summary-card-modern{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:18px;display:flex;align-items:center;gap:15px;transition:all .3s ease;position:relative;overflow:hidden}.alert-summary-card-modern:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:#fff3;transition:all .3s ease}.alert-summary-card-modern.critical:before{background:#ef4444;box-shadow:0 0 10px #ef444480}.alert-summary-card-modern.warning:before{background:#f59e0b;box-shadow:0 0 10px #f59e0b80}.alert-summary-card-modern.info:before{background:#3b82f6}.alert-summary-card-modern:hover{background:#ffffff14;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.alert-summary-icon-modern{flex-shrink:0}.alert-icon-circle{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}.critical-icon{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef444466}.warning-icon{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px #f59e0b66}.info-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 4px 12px #3b82f666}.alert-summary-info-modern{flex:1;min-width:0}.alert-summary-label-modern{font-size:11px;color:#fff9;margin-bottom:6px;text-transform:uppercase;letter-spacing:.8px;font-weight:600}.alert-summary-value-modern{font-size:28px;font-weight:700;color:#fff;line-height:1}.alert-summary-card-modern.critical .alert-summary-value-modern{color:#ef4444}.alert-summary-card-modern.warning .alert-summary-value-modern{color:#f59e0b}.alert-summary-card-modern.info .alert-summary-value-modern{color:#3b82f6}.alerts-list-container-modern{flex:1;overflow-y:auto;overflow-x:hidden;padding-right:8px;min-height:0}.alerts-list-container-modern::-webkit-scrollbar{width:8px}.alerts-list-container-modern::-webkit-scrollbar-track{background:#0003;border-radius:4px}.alerts-list-container-modern::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:4px}.alerts-list-container-modern::-webkit-scrollbar-thumb:hover{background:#00ffff80}.alerts-list-modern{display:flex;flex-direction:column;gap:12px}.alert-card-modern{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;overflow:hidden;transition:all .3s ease;position:relative;display:flex;cursor:pointer}.alert-card-modern:hover{background:#ffffff14;transform:translate(4px);box-shadow:0 4px 16px #0000004d;border-color:#fff3}.alert-card-modern.critical{border-left:4px solid #ef4444;background:#ef44440d}.alert-card-modern.warning{border-left:4px solid #f59e0b;background:#f59e0b0d}.alert-severity-indicator{width:4px;min-height:100%;flex-shrink:0}.critical-indicator{background:linear-gradient(180deg,#ef4444,#dc2626);box-shadow:0 0 8px #ef444499}.warning-indicator{background:linear-gradient(180deg,#f59e0b,#d97706);box-shadow:0 0 8px #f59e0b99}.alert-card-content{flex:1;padding:16px;display:flex;flex-direction:column;gap:12px}.alert-card-header-modern{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.alert-card-header-left{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.alert-type-icon-modern{flex-shrink:0}.alert-icon-wrapper{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15)}.expiring-icon{background:#ef444426;border-color:#ef44444d}.transit-icon{background:#f59e0b26;border-color:#f59e0b4d}.alert-card-title-section{flex:1;min-width:0}.alert-rfid-modern{font-size:13px;font-weight:700;color:#0ff;font-family:Courier New,monospace;margin-bottom:4px;letter-spacing:.5px}.alert-material-modern{font-size:15px;font-weight:600;color:#fff;line-height:1.3}.alert-severity-badge-modern{padding:6px 12px;border-radius:8px;font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.critical-badge{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.4);box-shadow:0 2px 8px #ef44444d}.warning-badge{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.4);box-shadow:0 2px 8px #f59e0b4d}.alert-card-body-modern{padding-top:4px}.alert-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.alert-info-item-modern{display:flex;flex-direction:column;gap:4px}.alert-info-label-modern{font-size:10px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.alert-info-value-modern{font-size:13px;color:#fff;font-weight:500;line-height:1.4}.alert-info-value-modern.critical-text{color:#ef4444;font-weight:700}.alert-info-value-modern.warning-text{color:#f59e0b;font-weight:600}.no-alerts-modern{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:16px;background:#ffffff08;border-radius:12px;border:1px dashed rgba(255,255,255,.1)}.no-alerts-icon{font-size:48px;opacity:.5}.no-alerts-text{color:#fff9;font-size:14px;font-weight:500;max-width:300px;line-height:1.6}@media (max-width: 768px){.inventory-panel{width:calc(100% - 40px)!important;height:calc(100vh - 100px)!important;left:20px!important;right:20px!important;min-width:unset;max-width:unset}.inventory-panel .movements-table{font-size:11px}.inventory-panel .movements-table th,.inventory-panel .movements-table td{padding:8px 4px}.inventory-panel .filter-row{flex-direction:column}.inventory-panel .filter-group{min-width:100%}}.antennas-inventory-panel,.antenna-detail-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;min-width:450px;max-height:calc(100vh - 140px);overflow:hidden;z-index:100;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.antenna-detail-panel{min-width:400px;max-width:500px}.antennas-inventory-panel .header,.antenna-detail-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.antennas-inventory-panel .header-title,.antenna-detail-panel .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.antennas-inventory-panel .drag-handle,.antenna-detail-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.antennas-inventory-panel .header:hover .drag-handle,.antenna-detail-panel .header:hover .drag-handle{color:#0ff9}.antennas-inventory-panel .header-title .icon,.antenna-detail-panel .header-title .icon{font-size:24px}.antennas-inventory-panel .header h3,.antenna-detail-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.count-badge{background:#0ff3;border:1px solid rgba(0,255,255,.3);border-radius:12px;padding:4px 10px;font-size:12px;font-weight:600;color:#0ff}.antenna-navigation{display:flex;align-items:center;gap:8px;margin-right:10px}.antenna-counter{font-size:12px;color:#ffffffb3;min-width:50px;text-align:center}.nav-button{background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:6px;width:28px;height:28px;color:#0ff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:14px}.nav-button:hover:not(:disabled){background:#0ff3;border-color:#00ffff80}.nav-button:disabled{opacity:.3;cursor:not-allowed}.header-actions{display:flex;align-items:center;gap:8px}.edit-button,.save-button,.cancel-button,.close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.edit-button{background:#3b82f633;color:#3b82f6;border-color:#3b82f64d}.save-button{background:#10b98133;color:#10b981;border-color:#10b9814d}.edit-button:hover,.save-button:hover,.cancel-button:hover,.close-button:hover{transform:scale(1.1);opacity:.8}.antennas-inventory-panel .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.antennas-inventory-panel .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 8px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s ease;border-bottom:2px solid transparent}.antennas-inventory-panel .tab-button:hover{color:#ffffffe6;background:#ffffff0d}.antennas-inventory-panel .tab-button.active{color:#0ff;border-bottom-color:#0ff;background:#00ffff0d}.antennas-inventory-panel .tab-content{flex:1;overflow-y:auto;padding:20px}.antennas-inventory-panel .tab-content::-webkit-scrollbar{width:6px}.antennas-inventory-panel .tab-content::-webkit-scrollbar-track{background:#0003}.antennas-inventory-panel .tab-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.filters-section{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.search-container{position:relative;display:flex;align-items:center}.search-input{width:100%;background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:8px;padding:8px 12px 8px 36px;color:#fff;font-size:13px;transition:all .3s ease}.search-input::-moz-placeholder{color:#fff6}.search-input::placeholder{color:#fff6}.search-input:hover{background:#00ffff26;border-color:#00ffff80}.search-input:focus{outline:none;background:#0ff3;border-color:#00ffffb3}.search-icon{position:absolute;left:12px;font-size:16px;pointer-events:none}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:12px;color:#ffffffb3;font-weight:500}.group-select{background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:8px;padding:8px 12px;color:#fff;font-size:13px;cursor:pointer;transition:all .3s ease}.group-select:hover{background:#00ffff26;border-color:#00ffff80}.group-select option{background:#1a1a2e;color:#fff}.antennas-list-container{display:flex;flex-direction:column;gap:12px}.antenna-group{display:flex;flex-direction:column;gap:8px}.equipment-category{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.category-header{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#00ffff0d;border-radius:8px;border:1px solid rgba(0,255,255,.2)}.category-toggle{flex-shrink:0}.category-title{flex:1;display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.category-name{font-size:14px;font-weight:600;color:#0ff}.category-arrow{font-size:12px;color:#fff9;transition:transform .3s ease;margin-left:8px}.category-arrow.collapsed{transform:rotate(-90deg)}.category-parts{display:flex;flex-direction:column;gap:6px;margin-left:20px;margin-top:8px}.part-item{background:#00ffff08;border:1px solid rgba(0,255,255,.15);border-radius:8px;padding:10px 12px;transition:all .3s ease;cursor:pointer}.part-item:hover{background:#00ffff14;border-color:#00ffff4d;transform:translate(4px)}.part-item.selected{background:#00ffff1f;border-color:#00ffff80;box-shadow:0 2px 8px #0ff3}.part-info{display:flex;flex-direction:column;gap:4px}.part-name{font-size:13px;font-weight:600;color:#fff}.part-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:#fff9}.part-tenant{color:#fffc;font-weight:500}.part-separator{color:#fff6}.part-height{color:#ffffffb3}.group-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:#00ffff0d;border-radius:8px;border:1px solid rgba(0,255,255,.2)}.group-title{font-size:14px;font-weight:600;color:#0ff}.antenna-item{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:12px;transition:all .3s ease;cursor:pointer}.antenna-item:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.antenna-item.selected{background:#00ffff26;border-color:#0ff9;box-shadow:0 4px 16px #00ffff4d}.antenna-item-main{display:flex;align-items:center;gap:12px}.antenna-toggle{flex-shrink:0}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#6b7280;transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#10b981}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.antenna-info{flex:1;min-width:0}.antenna-name{font-size:14px;font-weight:600;color:#fff;margin-bottom:4px}.antenna-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:#fff9}.antenna-tenant{color:#fffc;font-weight:500}.antenna-separator{color:#fff6}.antenna-height{color:#ffffffb3}.antenna-status{flex-shrink:0}.status-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 8px currentColor}.no-antennas{text-align:center;padding:60px 20px;display:flex;flex-direction:column;align-items:center;gap:16px;color:#ffffff80}.no-antennas-icon{font-size:48px;opacity:.5}.no-antennas-text{font-size:14px}.detail-content{flex:1;overflow-y:auto;padding:20px}.detail-content::-webkit-scrollbar{width:6px}.detail-content::-webkit-scrollbar-track{background:#0003}.detail-content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:3px}.detail-section{margin-bottom:24px}.detail-section:last-child{margin-bottom:0}.section-title{font-size:14px;font-weight:600;color:#0ff;margin:0 0 16px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05)}.detail-row:last-child{border-bottom:none}.detail-label{font-size:13px;color:#ffffffb3;font-weight:500}.detail-value{font-size:13px;color:#fff;font-weight:600;text-align:right}.editable-field-group{display:flex;align-items:center;gap:8px}.editable-field{background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:6px;padding:6px 10px;color:#fff;font-size:13px;width:120px;transition:all .3s ease}.editable-field:hover{background:#00ffff26;border-color:#00ffff80}.editable-field:focus{outline:none;background:#0ff3;border-color:#00ffffb3}.field-unit{font-size:12px;color:#fff9;font-weight:500}.detail-actions{padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end}.delete-button{background:#ef444433;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:10px 20px;color:#ef4444;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease}.delete-button:hover{background:#ef44444d;border-color:#ef444480;transform:translateY(-2px)}.antenna-3d-controls{background:#1a1a2ef2;border:1px solid rgba(0,255,255,.3);border-radius:12px;padding:12px;min-width:180px;box-shadow:0 8px 24px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.controls-header{margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.controls-title{font-size:13px;font-weight:600;color:#0ff}.controls-buttons{display:flex;align-items:center;gap:8px;margin-bottom:10px}.controls-buttons:last-child{margin-bottom:0}.control-button{background:#00ffff1a;border:1px solid rgba(0,255,255,.3);border-radius:6px;padding:6px 10px;color:#0ff;font-size:11px;cursor:pointer;transition:all .2s ease;min-width:60px;text-align:center}.control-button:hover{background:#0ff3;border-color:#00ffff80}.control-value{flex:1;text-align:center;font-size:12px;font-weight:600;color:#fff;min-width:50px}.resize-handle{position:absolute;bottom:0;right:0;width:20px;height:20px;cursor:nwse-resize;z-index:10;background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(0,255,255,.3) 40%,rgba(0,255,255,.3) 45%,transparent 45%,transparent 55%,rgba(0,255,255,.3) 55%,rgba(0,255,255,.3) 60%,transparent 60%);transition:background .2s ease}.resize-handle:hover{background:linear-gradient(135deg,transparent 0%,transparent 40%,rgba(0,255,255,.6) 40%,rgba(0,255,255,.6) 45%,transparent 45%,transparent 55%,rgba(0,255,255,.6) 55%,rgba(0,255,255,.6) 60%,transparent 60%)}.panel-3d-label{background:#1a1a2ef2;border:1px solid rgba(0,255,255,.3);border-radius:8px;padding:6px 12px;color:#0ff;font-size:12px;font-weight:600;white-space:nowrap;box-shadow:0 4px 12px #00000080;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none}.simulation-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;background:#0ff3;border-radius:4px;outline:none;transition:all .3s ease;cursor:pointer}.simulation-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:#0ff;border-radius:50%;cursor:pointer;border:2px solid rgba(255,255,255,.8);box-shadow:0 2px 8px #00ffff80;-webkit-transition:all .2s ease;transition:all .2s ease}.simulation-slider::-webkit-slider-thumb:hover{background:#0df;transform:scale(1.2);box-shadow:0 4px 12px #00ffffb3}.simulation-slider::-moz-range-thumb{width:20px;height:20px;background:#0ff;border-radius:50%;cursor:pointer;border:2px solid rgba(255,255,255,.8);box-shadow:0 2px 8px #00ffff80;-moz-transition:all .2s ease;transition:all .2s ease}.simulation-slider::-moz-range-thumb:hover{background:#0df;transform:scale(1.2);box-shadow:0 4px 12px #00ffffb3}@media (max-width: 768px){.antennas-inventory-panel,.antenna-detail-panel{width:calc(100% - 40px)!important;height:calc(100vh - 100px)!important;left:20px!important;right:20px!important;min-width:unset;max-width:unset}}.antennas-inventory-panel .realtime-header,.antenna-detail-panel .realtime-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.antennas-inventory-panel .live-indicator,.antenna-detail-panel .live-indicator{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#ef4444;animation:blink 2s ease-in-out infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.5}}.antennas-inventory-panel .last-update,.antenna-detail-panel .last-update{font-size:11px;color:#ffffff80}.antennas-inventory-panel .data-grid,.antenna-detail-panel .data-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.antennas-inventory-panel .data-card,.antenna-detail-panel .data-card{background:#00ffff0d;border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:14px;transition:all .3s ease}.antennas-inventory-panel .data-card:hover,.antenna-detail-panel .data-card:hover{background:#00ffff1a;border-color:#0ff6;transform:translateY(-2px);box-shadow:0 4px 12px #0ff3}.antennas-inventory-panel .data-label,.antenna-detail-panel .data-label{font-size:11px;color:#fff9;margin-bottom:6px;font-weight:500}.antennas-inventory-panel .data-value,.antenna-detail-panel .data-value{font-size:22px;font-weight:700;color:#0ff;display:flex;align-items:baseline;gap:4px}.antennas-inventory-panel .data-value .unit,.antenna-detail-panel .data-value .unit{font-size:13px;font-weight:500;color:#ffffff80}.antennas-inventory-panel .data-description,.antenna-detail-panel .data-description{font-size:10px;color:#fff6;margin-top:4px;font-style:italic}.antennas-inventory-panel .status-badge,.antenna-detail-panel .status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;color:#fff;box-shadow:0 2px 8px #0003;white-space:nowrap}.antennas-inventory-panel .info-grid,.antenna-detail-panel .info-grid{display:flex;flex-direction:column;gap:12px}.antennas-inventory-panel .info-row,.antenna-detail-panel .info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px;border-left:3px solid rgba(0,255,255,.5)}.antennas-inventory-panel .info-row:hover,.antenna-detail-panel .info-row:hover{background:#ffffff0d}.antennas-inventory-panel .info-label,.antenna-detail-panel .info-label{font-size:13px;color:#fff9;font-weight:500}.antennas-inventory-panel .info-value,.antenna-detail-panel .info-value{font-size:14px;color:#fff;font-weight:600}.first-person-button-container{position:relative;display:inline-block}.first-person-button{width:48px;height:48px;background:#fff;border:2px solid #ccc;border-radius:8px;cursor:grab;position:relative;overflow:hidden;box-shadow:0 2px 6px #00000026;transition:all .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.first-person-button:hover{border-color:#4285f4;box-shadow:0 4px 12px #4285f44d;transform:translateY(-1px)}.first-person-button.active{background:#4285f4;border-color:#4285f4;color:#fff}.first-person-button.dragging{cursor:grabbing;transform:scale(1.05);box-shadow:0 6px 20px #4285f466;border-color:#2563eb}.first-person-button.dragging .person-drag-indicator{transform:translate(-50%,-50%) scale(1.3);filter:drop-shadow(0 3px 6px rgba(0,0,0,.5))}.first-person-button.dragging.outside .person-drag-indicator{transform:translate(-50%,-50%) scale(1.5);filter:drop-shadow(0 4px 8px rgba(66,133,244,.6));color:#2563eb}.button-background{width:100%;height:100%;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.first-person-button.active .button-background{background:linear-gradient(135deg,#4285f4,#3367d6)}.street-view-icon{width:24px;height:24px;color:#666;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1}.first-person-button.active .street-view-icon{color:#fff}.person-drag-indicator{width:24px;height:24px;color:#4285f4;position:absolute;transform:translate(-50%,-50%);z-index:2;pointer-events:none;transition:all .1s ease;filter:drop-shadow(0 1px 2px rgba(0,0,0,.3))}.first-person-button.active .person-drag-indicator{color:#fff}.first-person-button.dragging .person-drag-indicator{transform:translate(-50%,-50%) scale(1.2);filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.tooltip{position:absolute;top:-40px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;white-space:nowrap;z-index:1000;pointer-events:none;animation:fadeIn .2s ease}.tooltip:before{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid rgba(0,0,0,.8)}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (max-width: 768px){.first-person-button{width:44px;height:44px}.street-view-icon{width:20px;height:20px}.person-drag-indicator{width:22px;height:22px}.tooltip{font-size:11px;padding:6px 10px}}.first-person-indicator{position:absolute;top:-8px;right:-8px;width:16px;height:16px;background:#4285f4;border:2px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:pulse 2s infinite}.indicator-dot{width:6px;height:6px;background:#fff;border-radius:50%}@keyframes pulse{0%{transform:scale(1);box-shadow:0 0 #4285f4b3}70%{transform:scale(1.1);box-shadow:0 0 0 10px #4285f400}to{transform:scale(1);box-shadow:0 0 #4285f400}}.first-person-drag-indicator{position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);animation:indicatorAppear .3s ease-out}.indicator-circle{width:60px;height:60px;background:linear-gradient(135deg,#4285f4,#3367d6);border:3px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #4285f466;animation:pulse 2s infinite}.person-icon{width:32px;height:32px;color:#fff;animation:bounce 1s infinite}.indicator-shadow{position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:40px;height:8px;background:#0003;border-radius:50%;filter:blur(2px)}.position-text{position:absolute;top:70px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;animation:textFadeIn .3s ease-out .1s both}.position-text:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:4px solid rgba(0,0,0,.8)}@keyframes indicatorAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.5)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes pulse{0%{transform:scale(1);box-shadow:0 4px 20px #4285f466}50%{transform:scale(1.05);box-shadow:0 6px 25px #4285f499}to{transform:scale(1);box-shadow:0 4px 20px #4285f466}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-3px)}60%{transform:translateY(-1px)}}@keyframes textFadeIn{0%{opacity:0;transform:translate(-50%) translateY(5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.first-person-drag-indicator.success .indicator-circle{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 20px #10b98166;animation:successPulse .6s ease-out}.first-person-drag-indicator.success .person-icon{animation:successBounce .6s ease-out}.first-person-drag-indicator.error .indicator-circle{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 20px #ef444466;animation:errorShake .6s ease-out}.first-person-drag-indicator.error .person-icon{animation:errorShake .6s ease-out}@keyframes successPulse{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}@keyframes successBounce{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}@keyframes errorShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@media (max-width: 768px){.indicator-circle{width:50px;height:50px}.person-icon{width:28px;height:28px}.position-text{font-size:11px;padding:6px 10px}}.volume-calculation-panel{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;box-shadow:0 8px 32px #0006;color:#fff;padding:0;width:360px;max-height:calc(100vh - 140px);overflow:hidden;z-index:10000;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:box-shadow .3s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none}.volume-calculation-panel:active{box-shadow:0 12px 40px #00ffff4d}.volume-calculation-panel .header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;-webkit-user-select:none;-moz-user-select:none;user-select:none}.volume-calculation-panel .header:active{background:#00ffff0d}.volume-calculation-panel .header-title{display:flex;align-items:center;gap:10px}.volume-calculation-panel .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.volume-calculation-panel .header:hover .drag-handle{color:#0ff9}.volume-calculation-panel .header:active .drag-handle{cursor:grabbing;color:#00ffffe6}.volume-calculation-panel .header-title .icon{font-size:24px}.volume-calculation-panel .header h3{margin:0;font-size:18px;font-weight:600;color:#0ff}.volume-calculation-panel .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.volume-calculation-panel .close-button:hover{background:#ef44444d;transform:scale(1.1)}.volume-calculation-panel .content{padding:20px 24px;overflow-y:auto;flex:1}.volume-calculation-panel .content::-webkit-scrollbar{width:8px}.volume-calculation-panel .content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.volume-calculation-panel .content::-webkit-scrollbar-thumb{background:#00ffff4d;border-radius:4px}.volume-calculation-panel .content::-webkit-scrollbar-thumb:hover{background:#00ffff80}.volume-calculation-panel .section-group{margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.1)}.volume-calculation-panel .section-group:last-child{margin-bottom:0;border-bottom:none;padding-bottom:0}.volume-calculation-panel .section-group-title{font-size:16px;font-weight:700;color:#0ff;margin-bottom:16px;text-transform:uppercase;letter-spacing:1px;padding-bottom:8px;border-bottom:2px solid rgba(0,255,255,.3)}.volume-calculation-panel .section{margin-bottom:20px}.volume-calculation-panel .section:last-child{margin-bottom:0}.volume-calculation-panel .section-title{font-size:14px;font-weight:600;color:#0ff;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}.volume-calculation-panel .point-count-badge{background:#0ff3;color:#0ff;padding:4px 12px;border-radius:12px;font-size:14px;font-weight:700;border:1px solid rgba(0,255,255,.3)}.volume-calculation-panel .warning-box{background:#f59e0b26;border:1px solid rgba(245,158,11,.3);color:#fbbf24;padding:12px;border-radius:8px;font-size:13px;margin-top:8px}.volume-calculation-panel .success-box{background:#10b98126;border:1px solid rgba(16,185,129,.3);color:#10b981;padding:12px;border-radius:8px;font-size:13px;margin-top:8px;font-weight:600}.volume-calculation-panel .radio-group{display:flex;flex-direction:column;gap:8px}.volume-calculation-panel .radio-option{display:flex;align-items:center;gap:10px;padding:12px;border-radius:8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);cursor:pointer;transition:all .2s ease}.volume-calculation-panel .radio-option:hover{background:#ffffff14;border-color:#00ffff4d}.volume-calculation-panel .radio-option.active{background:#00ffff26;border-color:#00ffff80}.volume-calculation-panel .radio-option input[type=radio]{margin:0;cursor:pointer;accent-color:#00ffff}.volume-calculation-panel .radio-option span{font-size:14px;color:#fff;flex:1}.volume-calculation-panel .calculate-button{width:100%;padding:16px;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.volume-calculation-panel .calculate-button.enabled{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 16px #10b98166}.volume-calculation-panel .calculate-button.enabled:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98199}.volume-calculation-panel .calculate-button.disabled{background:#6b72804d;color:#ffffff80;cursor:not-allowed}.volume-calculation-panel .progress-container{margin-top:12px}.volume-calculation-panel .progress-bar{width:100%;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.volume-calculation-panel .progress-fill{height:100%;background:linear-gradient(90deg,#10b981,#059669);transition:width .1s ease;border-radius:4px}.volume-calculation-panel .progress-text{text-align:center;font-size:12px;color:#ffffffb3;margin-top:6px}.volume-calculation-panel .volume-result{background:#10b98126;border:2px solid rgba(16,185,129,.5);border-radius:12px;padding:20px;text-align:center}.volume-calculation-panel .volume-value.remove{color:#ef4444}.volume-calculation-panel .volume-value.fill{color:#3b82f6}.volume-calculation-panel .volume-label{font-size:12px;color:#ffffffb3;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.volume-calculation-panel .volume-value{font-size:32px;font-weight:700;color:#10b981}.volume-calculation-panel .action-buttons{display:flex;gap:8px}.volume-calculation-panel .action-button{flex:1;padding:10px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.volume-calculation-panel .action-button.remove{background:#f59e0b33;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.volume-calculation-panel .action-button.remove:hover:not(:disabled){background:#f59e0b4d;transform:translateY(-1px)}.volume-calculation-panel .action-button.clear{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.volume-calculation-panel .action-button.clear:hover:not(:disabled){background:#ef44444d;transform:translateY(-1px)}.volume-calculation-panel .action-button.export{background:#3b82f633;border-color:#3b82f666;color:#60a5fa}.volume-calculation-panel .action-button.export:hover:not(:disabled){background:#3b82f64d;transform:translateY(-1px)}.volume-calculation-panel .action-button.import{background:#a855f733;border-color:#a855f766;color:#a78bfa}.volume-calculation-panel .action-button.import:hover:not(:disabled){background:#a855f74d;transform:translateY(-1px)}.volume-calculation-panel .action-button:disabled{opacity:.5;cursor:not-allowed}.volume-calculation-panel .points-list{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:8px;font-family:Courier New,monospace}.volume-calculation-panel .points-list::-webkit-scrollbar{width:6px}.volume-calculation-panel .points-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.volume-calculation-panel .points-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.volume-calculation-panel .points-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.volume-calculation-panel .click-mode-button{width:100%;padding:14px;border:2px solid rgba(0,255,255,.3);border-radius:10px;background:#00ffff1a;color:#0ff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-bottom:12px;text-align:center}.volume-calculation-panel .click-mode-button:hover{background:#0ff3;border-color:#00ffff80;transform:translateY(-1px)}.volume-calculation-panel .click-mode-button.active{background:#10b98133;border-color:#10b98180;color:#10b981;box-shadow:0 4px 12px #10b9814d}.volume-calculation-panel .info-box{background:#3b82f626;border:1px solid rgba(59,130,246,.3);color:#60a5fa;padding:10px;border-radius:8px;font-size:12px;margin-bottom:12px;text-align:center}.volume-calculation-panel .instructions{background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px}.volume-calculation-panel .instructions-title{font-size:13px;font-weight:600;color:#fffc;margin-bottom:12px}.volume-calculation-panel .instructions-list{margin:0;padding-left:20px;font-size:12px;color:#ffffffb3;line-height:1.8}.volume-calculation-panel .instructions-list li{margin-bottom:6px}.volume-calculation-panel .dem-config-content{transition:max-height .3s ease-out,margin-top .3s ease-out;overflow:hidden}.volume-calculation-panel .dem-config-content>div{animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.volume-finance-modal-overlay{position:fixed;inset:0;background:transparent;z-index:10000;pointer-events:none}.volume-finance-modal{position:fixed;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;box-shadow:0 4px 16px #0000004d;color:#fff;padding:0;width:450px;max-width:90vw;max-height:600px;overflow:hidden;z-index:10001;display:flex;flex-direction:column;border:1px solid rgba(255,255,255,.1);-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all}.volume-finance-modal .modal-header{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;background:#ffffff08;cursor:move;-webkit-user-select:none;-moz-user-select:none;user-select:none}.volume-finance-modal .header-title{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.volume-finance-modal .drag-handle{font-size:18px;color:#ffffff4d;cursor:grab;transition:color .2s ease;-webkit-user-select:none;-moz-user-select:none;user-select:none;line-height:1}.volume-finance-modal .header-title:hover .drag-handle{color:#22c55e99}.volume-finance-modal .header-title .icon{font-size:24px}.volume-finance-modal .header-title h3{margin:0;font-size:18px;font-weight:600;color:#22c55e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.volume-finance-modal .close-button{background:#ef444433;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:8px;width:32px;height:32px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0;line-height:1}.volume-finance-modal .close-button:hover{background:#ef44444d;transform:scale(1.1)}.volume-finance-modal .tabs-container{display:flex;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.volume-finance-modal .tab-button{flex:1;background:transparent;border:none;color:#fff9;padding:12px 16px;cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:500;border-bottom:2px solid transparent}.volume-finance-modal .tab-button:hover{background:#ffffff0d;color:#fffc}.volume-finance-modal .tab-button.active{color:#22c55e;border-bottom-color:#22c55e;background:#22c55e1a}.volume-finance-modal .tab-content{padding:16px 20px;overflow-y:auto;flex:1;max-height:500px}.volume-finance-modal .finance-section{margin-bottom:24px}.volume-finance-modal .section-title{font-size:14px;font-weight:600;color:#9ca3af;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.volume-finance-modal .finance-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;margin-bottom:12px}.volume-finance-modal .finance-card.expense{border-color:#ef44444d;background:#ef44440d}.volume-finance-modal .finance-card.profit{border-color:#22c55e4d;background:#22c55e0d}.volume-finance-modal .finance-label{font-size:13px;color:#9ca3af;margin-bottom:8px}.volume-finance-modal .finance-value{font-size:18px;font-weight:700;color:#fff;margin-bottom:8px}.volume-finance-modal .finance-detail{font-size:12px;color:#6b7280;margin-top:4px}.volume-finance-modal .finance-breakdown{margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.1)}.volume-finance-modal .breakdown-item{display:flex;justify-content:space-between;padding:6px 0;font-size:12px;color:#d1d5db}.volume-finance-modal .costs-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.volume-finance-modal .cost-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:16px;text-align:center}.volume-finance-modal .cost-icon{font-size:32px;margin-bottom:8px}.volume-finance-modal .cost-label{font-size:12px;color:#9ca3af;margin-bottom:8px;font-weight:500}.volume-finance-modal .cost-value{font-size:16px;font-weight:700;color:#22c55e;margin-bottom:8px}.volume-finance-modal .cost-detail{font-size:11px;color:#6b7280;margin-top:4px}.volume-finance-modal .config-section{display:flex;flex-direction:column;gap:20px}.volume-finance-modal .config-group{display:flex;flex-direction:column;gap:8px;padding:16px;background:#ffffff08;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.volume-finance-modal .config-group label{font-size:12px;color:#9ca3af;font-weight:500}.volume-finance-modal .config-group input,.volume-finance-modal .config-group select{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;padding:8px 12px;color:#fff;font-size:14px;transition:all .2s ease}.volume-finance-modal .config-group input:focus,.volume-finance-modal .config-group select:focus{outline:none;border-color:#22c55e;background:#0006}.volume-finance-modal .config-group input:hover,.volume-finance-modal .config-group select:hover{border-color:#fff3}.volume-finance-modal .tab-content::-webkit-scrollbar{width:6px}.volume-finance-modal .tab-content::-webkit-scrollbar-track{background:#0003;border-radius:3px}.volume-finance-modal .tab-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.volume-finance-modal .tab-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.satellite-panel{width:100%;height:100%;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:12px;box-shadow:0 8px 32px #0000001f,0 2px 8px #00000014;display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.satellite-panel-header{background:linear-gradient(135deg,#667eea,#764ba2);padding:16px;display:flex;justify-content:space-between;align-items:center;color:#fff;flex-shrink:0}.satellite-panel-title{display:flex;align-items:center;gap:12px}.satellite-panel-icon{font-size:24px}.satellite-panel-title h3{margin:0;font-size:16px;font-weight:600}.satellite-panel-subtitle{font-size:11px;opacity:.9;display:block;margin-top:2px}.satellite-panel-close{background:#fff3;border:none;border-radius:6px;padding:6px 10px;color:#fff;cursor:pointer;font-size:16px;transition:all .2s ease}.satellite-panel-close:hover{background:#ffffff4d}.satellite-panel-controls{padding:12px 16px;background:#f8fafc80;border-bottom:1px solid rgba(0,0,0,.1);display:flex;flex-direction:column;gap:12px;flex-shrink:0}.satellite-control-group{display:flex;align-items:center;gap:12px}.satellite-control-group label{font-size:12px;font-weight:600;color:#374151;min-width:100px}.satellite-button-group{display:flex;gap:4px;background:#fffc;padding:2px;border-radius:6px}.satellite-button-group button{padding:6px 12px;border:none;background:transparent;color:#6b7280;cursor:pointer;border-radius:4px;font-size:11px;font-weight:500;transition:all .2s ease}.satellite-button-group button:hover{background:#3b82f61a;color:#3b82f6}.satellite-button-group button.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;box-shadow:0 2px 4px #3b82f64d}.satellite-opacity-slider{flex:1;height:4px;border-radius:2px;background:#e5e7eb;outline:none;-webkit-appearance:none}.satellite-opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#3b82f6;cursor:pointer;box-shadow:0 2px 4px #3b82f64d}.satellite-opacity-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#3b82f6;cursor:pointer;border:none;box-shadow:0 2px 4px #3b82f64d}.satellite-opacity-value{font-size:11px;font-weight:600;color:#6b7280;min-width:40px;text-align:right}.satellite-panel-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.satellite-images-container{display:flex;gap:8px;padding:12px;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}.satellite-image-wrapper{flex:1;display:flex;flex-direction:column;gap:4px}.satellite-image-label{font-size:10px;font-weight:600;color:#6b7280;text-align:center;text-transform:uppercase;letter-spacing:.5px}.satellite-image-container{position:relative;width:100%;aspect-ratio:1;border-radius:6px;overflow:hidden;background:#f3f4f6;border:1px solid rgba(0,0,0,.1)}.satellite-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.satellite-overlay{position:absolute;top:0;left:0;width:100%;height:100%;-o-object-fit:cover;object-fit:cover;pointer-events:none}.satellite-detections-list{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#fffc}.satellite-detections-header{padding:12px 16px;border-bottom:1px solid rgba(0,0,0,.1);flex-shrink:0}.satellite-detections-header h4{margin:0;font-size:13px;font-weight:600;color:#1f2937}.satellite-detections-scroll{flex:1;overflow-y:auto;padding:8px}.satellite-detection-item{padding:10px;margin-bottom:8px;background:#fffc;border:1px solid rgba(0,0,0,.1);border-radius:6px;cursor:pointer;transition:all .2s ease}.satellite-detection-item:hover{background:#3b82f60d;border-color:#3b82f64d;transform:translate(2px)}.satellite-detection-item.selected{background:#3b82f61a;border-color:#3b82f6;box-shadow:0 2px 8px #3b82f633}.satellite-detection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.satellite-detection-id{font-size:11px;font-weight:600;color:#1f2937}.satellite-detection-area{font-size:10px;font-weight:600;color:#10b981;background:#10b9811a;padding:2px 6px;border-radius:4px}.satellite-detection-details{display:flex;flex-direction:column;gap:4px}.satellite-detection-coords{display:flex;flex-direction:column;gap:2px;font-size:10px;color:#6b7280}.satellite-detection-meta{display:flex;gap:12px;font-size:10px;color:#9ca3af;margin-top:4px}.satellite-panel-loading,.satellite-panel-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:#6b7280}.satellite-spinner{width:40px;height:40px;border:3px solid rgba(59,130,246,.1);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.satellite-no-detections{padding:40px;text-align:center;color:#9ca3af;font-size:12px}.satellite-detections-scroll::-webkit-scrollbar{width:6px}.satellite-detections-scroll::-webkit-scrollbar-track{background:#0000000d;border-radius:3px}.satellite-detections-scroll::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:3px}.satellite-detections-scroll::-webkit-scrollbar-thumb:hover{background:#3b82f680}.leaflet-pane,.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile-container,.leaflet-pane>svg,.leaflet-pane>canvas,.leaflet-zoom-box,.leaflet-image-layer,.leaflet-layer{position:absolute;left:0;top:0}.leaflet-container{overflow:hidden}.leaflet-tile,.leaflet-marker-icon,.leaflet-marker-shadow{-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none}.leaflet-tile::-moz-selection{background:transparent}.leaflet-tile::selection{background:transparent}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{width:1600px;height:1600px;-webkit-transform-origin:0 0}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-width:none!important;max-height:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer,.leaflet-container .leaflet-tile{max-width:none!important;max-height:none!important;width:auto;padding:0}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{width:0;height:0;box-sizing:border-box;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{width:1px;height:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{position:relative;z-index:800;pointer-events:visiblePainted;pointer-events:auto}.leaflet-top,.leaflet-bottom{position:absolute;z-index:1000;pointer-events:none}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{float:left;clear:both}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-zoom-anim .leaflet-tile,.leaflet-pan-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-popup-pane,.leaflet-control{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-image-layer,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-marker-icon.leaflet-interactive,.leaflet-image-layer.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{border:2px dotted #38f;background:#ffffff80}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{box-shadow:0 1px 5px #000000a6;border-radius:4px}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;width:26px;height:26px;line-height:26px;display:block;text-align:center;text-decoration:none;color:#000}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:hover,.leaflet-bar a:focus{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;border-bottom:none}.leaflet-bar a.leaflet-disabled{cursor:default;background-color:#f4f4f4;color:#bbb}.leaflet-touch .leaflet-bar a{width:30px;height:30px;line-height:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{box-shadow:0 1px 5px #0006;background:#fff;border-radius:5px}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);width:36px;height:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{width:44px;height:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{padding:6px 10px 6px 6px;color:#333;background:#fff}.leaflet-control-layers-scrollbar{overflow-y:scroll;overflow-x:hidden;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{height:0;border-top:1px solid #ddd;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{padding:0 5px;color:#333;line-height:1.4}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:hover,.leaflet-control-attribution a:focus{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;vertical-align:baseline!important;width:1em;height:.6669em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{border:2px solid #777;border-top:none;line-height:1.1;padding:2px 5px 1px;white-space:nowrap;box-sizing:border-box;background:#fffc;text-shadow:1px 1px #fff}.leaflet-control-scale-line:not(:first-child){border-top:2px solid #777;border-bottom:none;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{box-shadow:none}.leaflet-touch .leaflet-control-layers,.leaflet-touch .leaflet-bar{border:2px solid rgba(0,0,0,.2);background-clip:padding-box}.leaflet-popup{position:absolute;text-align:center;margin-bottom:20px}.leaflet-popup-content-wrapper{padding:1px;text-align:left;border-radius:12px}.leaflet-popup-content{margin:13px 24px 13px 20px;line-height:1.3;font-size:13px;font-size:1.08333em;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{width:40px;height:20px;position:absolute;left:50%;margin-top:-1px;margin-left:-20px;overflow:hidden;pointer-events:none}.leaflet-popup-tip{width:17px;height:17px;padding:1px;margin:-10px auto 0;pointer-events:auto;transform:rotate(45deg)}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;color:#333;box-shadow:0 3px 14px #0006}.leaflet-container a.leaflet-popup-close-button{position:absolute;top:0;right:0;border:none;text-align:center;width:24px;height:24px;font:16px/24px Tahoma,Verdana,sans-serif;color:#757575;text-decoration:none;background:transparent}.leaflet-container a.leaflet-popup-close-button:hover,.leaflet-container a.leaflet-popup-close-button:focus{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{width:24px;margin:0 auto;-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=.70710678,M12=.70710678,M21=-.70710678,M22=.70710678)}.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{position:absolute;padding:6px;background-color:#fff;border:1px solid #fff;border-radius:3px;color:#222;white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:none;box-shadow:0 1px 3px #0006}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-top:before,.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{position:absolute;pointer-events:none;border:6px solid transparent;background:transparent;content:""}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{bottom:0;margin-bottom:-12px;border-top-color:#fff}.leaflet-tooltip-bottom:before{top:0;margin-top:-12px;margin-left:-6px;border-bottom-color:#fff}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{top:50%;margin-top:-6px}.leaflet-tooltip-left:before{right:0;margin-right:-12px;border-left-color:#fff}.leaflet-tooltip-right:before{left:0;margin-left:-12px;border-right-color:#fff}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}
