@import url(https://api.mapbox.com/mapbox-gl-js/v3.7.0/mapbox-gl.css);@import url(https://api.mapbox.com/mapbox-gl-js/plugins/mapbox-gl-geocoder/v5.0.0/mapbox-gl-geocoder.css);:root{--primary-blue:#1f7cf4;--primary-blue-hover:#0d47a1;--secondary-purple:#5b2c87;--accent-teal:#18d0cd;--bg-main:#10161ca8;--bg-panel:#242730;--bg-card:#2a2f38;--bg-input:#1a1e26d3;--border-color:#3c414c;--text-primary:#f7f8fa;--text-secondary:#a0a7b4;--text-muted:#6b7280;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--shadow-lg:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d;--shadow-xl:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;--gradient-primary:linear-gradient(135deg,#1f7cf4,#5b2c87);--gradient-accent:linear-gradient(135deg,#18d0cd,#1f7cf4)}*{box-sizing:border-box}body,html{color:#f7f8fa;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;height:100%;margin:0;overflow:hidden;padding:0}#map,body,html{background:#10161ca8;background:var(--bg-main)}#map{inset:0;position:fixed;transform:translateX(75px);transform-style:preserve-3d;transition:transform .4s cubic-bezier(.4,0,.2,1);will-change:transform}#star-constellation-canvas{-webkit-backface-visibility:hidden;backface-visibility:hidden;height:100%;left:0;opacity:.8;pointer-events:none;position:fixed;top:0;width:100%;will-change:opacity;z-index:0}#login-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:radial-gradient(ellipse at 50% 50%,#080c1ee6 0,#02030a 100%),linear-gradient(135deg,#0a0e27,#030510 50%,#0a0e27);inset:0;overflow:hidden;position:fixed;z-index:1000}#loading-indicator{align-items:center;background:linear-gradient(135deg,#0f1419,#1a1f2e 50%,#0f1419);display:flex;inset:0;justify-content:center;position:fixed;z-index:999}.loading-content{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff08;border:1px solid #ffffff14;border-radius:24px;box-shadow:0 20px 60px #0000004d,inset 0 1px 0 #ffffff1a;min-width:280px;padding:40px;text-align:center}.loading-spinner{height:60px;margin:0 auto 30px;position:relative;width:60px}.loading-spinner:before{animation:spin 1s cubic-bezier(.68,-.55,.265,1.55) infinite;border-color:#18d0cd #18d0cd #0000 #0000;border-radius:50%;border-style:solid;border-width:2px;content:"";inset:0;position:absolute}.loading-spinner:after{animation:spin 1.5s cubic-bezier(.68,-.55,.265,1.55) infinite reverse;border-color:#0000 #0000 #5b9bf4 #5b9bf4;border-radius:50%;border-style:solid;border-width:2px;content:"";inset:8px;position:absolute}.loading-text{color:#ffffffe6;font-size:14px;font-weight:500;margin-bottom:25px;opacity:.8;text-transform:uppercase}.loading-progress{background:#ffffff1a;border-radius:100px;height:4px;margin-bottom:15px;overflow:hidden;position:relative;width:100%}.loading-progress:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff1a 50%,#0000);content:"";inset:0;position:absolute}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.loading-progress-bar{background:linear-gradient(90deg,#5b9bf4,#18d0cd 50%,#5b9bf4);border-radius:100px;box-shadow:0 0 20px #18d0cd80;height:100%;position:relative;transition:width .5s cubic-bezier(.4,0,.2,1);width:0}.loading-progress-bar:after{animation:pulse 1s ease-in-out infinite;background:#fffc;border-radius:50%;bottom:0;box-shadow:0 0 10px #fffc;content:"";position:absolute;right:0;top:0;width:4px}.loading-percentage{color:#fff9;font-family:SF Mono,Monaco,Inconsolata,monospace;font-size:24px;font-weight:200;letter-spacing:2px}#login-form:before{background:radial-gradient(1.5px 1.5px at 45% 50%,#228b22e6,#0000 15%),radial-gradient(1px 1px at 43% 48%,#8b4513cc,#0000 12%),radial-gradient(1.2px 1.2px at 47% 52%,#228b22d9,#0000 14%),radial-gradient(.8px .8px at 44% 45%,#3cb371b3,#0000 10%),radial-gradient(1px 1px at 46% 55%,#8b4513bf,#0000 13%),radial-gradient(1.3px 1.3px at 52% 47%,#228b22cc,#0000 14%),radial-gradient(1px 1px at 53% 45%,#8b4513bf,#0000 11%),radial-gradient(.9px .9px at 51% 42%,#228b22b3,#0000 12%),radial-gradient(1.1px 1.1px at 54% 49%,#3cb371cc,#0000 13%),radial-gradient(1.4px 1.4px at 58% 45%,#228b22d9,#0000 15%),radial-gradient(1px 1px at 60% 43%,#8b4513cc,#0000 12%),radial-gradient(1.2px 1.2px at 57% 47%,#3cb371bf,#0000 14%),radial-gradient(.8px .8px at 61% 46%,#228b22b3,#0000 10%),radial-gradient(1px 1px at 62% 58%,#8b4513cc,#0000 12%),radial-gradient(.8px .8px at 63% 60%,#228b22b3,#0000 10%),radial-gradient(1px 1px at 35% 45%,#1e90ff99,#0000 20%),radial-gradient(.8px .8px at 33% 50%,#4169e180,#0000 18%),radial-gradient(1.2px 1.2px at 37% 55%,#1e90ffa6,#0000 22%),radial-gradient(.9px .9px at 32% 40%,#4169e18c,#0000 19%),radial-gradient(1.1px 1.1px at 36% 62%,#1e90ff99,#0000 21%),radial-gradient(1px 1px at 48% 40%,#1e90ffa6,#0000 20%),radial-gradient(.8px .8px at 49% 58%,#4169e199,#0000 18%),radial-gradient(1.1px 1.1px at 47% 35%,#1e90ffb3,#0000 21%),radial-gradient(1px 1px at 55% 55%,#1e90ff99,#0000 20%),radial-gradient(.9px .9px at 57% 52%,#4169e18c,#0000 19%),radial-gradient(.6px .6px at 40% 35%,#fff6,#0000 15%),radial-gradient(.5px .5px at 55% 60%,#ffffff59,#0000 12%),radial-gradient(.7px .7px at 45% 65%,#fff6,#0000 16%),radial-gradient(.5px .5px at 58% 38%,#ffffff4d,#0000 13%);background-size:100% 100%;opacity:.9;z-index:1}#login-form:after,#login-form:before{content:"";display:none;height:100%;left:0;position:absolute;top:0;width:100%}#login-form:after{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cline x1='43%25' y1='40%25' x2='45%25' y2='35%25' stroke='rgba(34,139,34,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='45%25' y1='35%25' x2='47%25' y2='38%25' stroke='rgba(34,139,34,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='47%25' y1='38%25' x2='43%25' y2='40%25' stroke='rgba(34,139,34,0.5)' stroke-width='.7' opacity='.7'/%3E%3Cline x1='43%25' y1='40%25' x2='41%25' y2='55%25' stroke='rgba(34,139,34,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='41%25' y1='55%25' x2='47%25' y2='60%25' stroke='rgba(34,139,34,0.5)' stroke-width='.7' opacity='.7'/%3E%3Cline x1='47%25' y1='60%25' x2='47%25' y2='38%25' stroke='rgba(34,139,34,0.4)' stroke-width='.6' opacity='.6'/%3E%3Cline x1='44%25' y1='58%25' x2='46%25' y2='65%25' stroke='rgba(34,139,34,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='46%25' y1='65%25' x2='48%25' y2='70%25' stroke='rgba(34,139,34,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='48%25' y1='70%25' x2='44%25' y2='58%25' stroke='rgba(34,139,34,0.5)' stroke-width='.7' opacity='.7'/%3E%3Cline x1='51%25' y1='38%25' x2='53%25' y2='35%25' stroke='rgba(139,69,19,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='53%25' y1='35%25' x2='55%25' y2='42%25' stroke='rgba(139,69,19,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='55%25' y1='42%25' x2='52%25' y2='65%25' stroke='rgba(139,69,19,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='52%25' y1='65%25' x2='51%25' y2='38%25' stroke='rgba(139,69,19,0.5)' stroke-width='.7' opacity='.7'/%3E%3Cline x1='51%25' y1='38%25' x2='52%25' y2='32%25' stroke='rgba(34,139,34,0.5)' stroke-width='.6' opacity='.7'/%3E%3Cline x1='52%25' y1='32%25' x2='55%25' y2='35%25' stroke='rgba(34,139,34,0.5)' stroke-width='.6' opacity='.7'/%3E%3Cline x1='55%25' y1='35%25' x2='62%25' y2='30%25' stroke='rgba(34,139,34,0.7)' stroke-width='.9' opacity='.8'/%3E%3Cline x1='62%25' y1='30%25' x2='65%25' y2='40%25' stroke='rgba(34,139,34,0.7)' stroke-width='.9' opacity='.8'/%3E%3Cline x1='65%25' y1='40%25' x2='60%25' y2='50%25' stroke='rgba(34,139,34,0.6)' stroke-width='.8' opacity='.7'/%3E%3Cline x1='60%25' y1='50%25' x2='55%25' y2='42%25' stroke='rgba(34,139,34,0.6)' stroke-width='.8' opacity='.7'/%3E%3Cline x1='55%25' y1='42%25' x2='55%25' y2='35%25' stroke='rgba(34,139,34,0.5)' stroke-width='.7' opacity='.6'/%3E%3Cline x1='60%25' y1='58%25' x2='64%25' y2='60%25' stroke='rgba(139,69,19,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='64%25' y1='60%25' x2='62%25' y2='62%25' stroke='rgba(139,69,19,0.6)' stroke-width='.8' opacity='.8'/%3E%3Cline x1='62%25' y1='62%25' x2='60%25' y2='58%25' stroke='rgba(139,69,19,0.5)' stroke-width='.7' opacity='.7'/%3E%3Cline x1='30%25' y1='45%25' x2='35%25' y2='50%25' stroke='rgba(30,144,255,0.4)' stroke-width='.5' opacity='.6'/%3E%3Cline x1='35%25' y1='50%25' x2='38%25' y2='55%25' stroke='rgba(30,144,255,0.4)' stroke-width='.5' opacity='.6'/%3E%3Cline x1='38%25' y1='55%25' x2='35%25' y2='60%25' stroke='rgba(30,144,255,0.4)' stroke-width='.5' opacity='.6'/%3E%3Cline x1='35%25' y1='60%25' x2='30%25' y2='45%25' stroke='rgba(30,144,255,0.3)' stroke-width='.4' opacity='.5'/%3E%3Cline x1='48%25' y1='35%25' x2='49%25' y2='55%25' stroke='rgba(30,144,255,0.4)' stroke-width='.5' opacity='.6'/%3E%3Cline x1='49%25' y1='55%25' x2='50%25' y2='40%25' stroke='rgba(30,144,255,0.3)' stroke-width='.4' opacity='.5'/%3E%3Cline x1='55%25' y1='52%25' x2='58%25' y2='58%25' stroke='rgba(30,144,255,0.4)' stroke-width='.5' opacity='.6'/%3E%3Cline x1='58%25' y1='58%25' x2='56%25' y2='55%25' stroke='rgba(30,144,255,0.3)' stroke-width='.4' opacity='.5'/%3E%3Cline x1='40%25' y1='30%25' x2='45%25' y2='32%25' stroke='rgba(255,255,255,0.3)' stroke-width='.3' opacity='.4'/%3E%3Cline x1='55%25' y1='58%25' x2='58%25' y2='62%25' stroke='rgba(255,255,255,0.3)' stroke-width='.3' opacity='.4'/%3E%3Cline x1='42%25' y1='65%25' x2='47%25' y2='68%25' stroke='rgba(255,255,255,0.3)' stroke-width='.3' opacity='.4'/%3E%3C/svg%3E") no-repeat;background-size:100% 100%;opacity:.7;z-index:2}@keyframes earthRotation{0%{transform:translateX(0) scale(1)}25%{transform:translateX(-5px) scale(1.01)}50%{transform:translateX(-10px) scale(1.02)}75%{transform:translateX(-5px) scale(1.01)}to{transform:translateX(0) scale(1)}}@keyframes earthTriangulation{0%,to{filter:brightness(1) hue-rotate(0deg);opacity:.7}25%{filter:brightness(1.1) hue-rotate(5deg);opacity:.6}50%{filter:brightness(1.2) hue-rotate(10deg);opacity:.8}75%{filter:brightness(1.05) hue-rotate(5deg);opacity:.65}}@keyframes continentPulse{0%,to{filter:brightness(1) hue-rotate(0deg);opacity:1;transform:scale(1)}25%{filter:brightness(1.1) hue-rotate(5deg);opacity:.8;transform:scale(.95)}50%{filter:brightness(1.2) hue-rotate(10deg);opacity:1;transform:scale(1.05)}75%{filter:brightness(1.05) hue-rotate(5deg);opacity:.9;transform:scale(1.02)}}@keyframes oceanFlow{0%,to{filter:brightness(1) hue-rotate(0deg);opacity:.9;transform:scale(1) rotate(0deg)}25%{filter:brightness(1.1) hue-rotate(10deg);opacity:.7;transform:scale(.9) rotate(90deg)}50%{filter:brightness(1.3) hue-rotate(20deg);opacity:1;transform:scale(1.1) rotate(180deg)}75%{filter:brightness(1.15) hue-rotate(10deg);opacity:.8;transform:scale(1.05) rotate(270deg)}}@keyframes cloudDrift{0%,to{filter:brightness(1);opacity:.8;transform:scale(1) translateX(0)}33%{filter:brightness(.9);opacity:.6;transform:scale(.85) translateX(2px)}66%{filter:brightness(1.2);opacity:1;transform:scale(1.15) translateX(-2px)}}#login-box{animation:cosmicEntry 1s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0f162d05;border:1px solid #5b9bf44d;border-radius:20px;left:50%;overflow:visible;padding:24px;position:absolute;top:50%;transform:translate(-50%,-50%);width:336px;z-index:10}.continent-node{animation:continentPulse 8s ease-in-out infinite;background:radial-gradient(circle,#20b2aa 0,#008b8bcc 40%,#40e0d099 80%,#0000 100%);border-radius:50%;box-shadow:0 0 6px #20b2aab3,0 0 12px #008b8b66,0 0 18px #40e0d04d;height:3px;pointer-events:none;position:absolute;width:3px;z-index:6}.continent-node:before{background:linear-gradient(180deg,#0000,#20b2aacc,#0000);content:"";height:4px;left:50%;position:absolute;top:-.5px;transform:translateX(-50%);width:.6px}.continent-node:after{background:linear-gradient(90deg,#0000,#20b2aacc,#0000);content:"";height:.6px;left:-.5px;position:absolute;top:50%;transform:translateY(-50%);width:4px}.ocean-node{animation:oceanFlow 10s ease-in-out infinite;background:radial-gradient(circle,#00bfffe6 0,#1e90ffb3 40%,#4682b480 80%,#0000 100%);border-radius:50%;box-shadow:0 0 5px #00bfffb3,0 0 10px #1e90ff66,0 0 15px #4682b433;height:2.5px;pointer-events:none;position:absolute;width:2.5px;z-index:5}.ocean-node:before{background:linear-gradient(180deg,#0000,#00bfffb3,#0000);content:"";height:3.3px;left:50%;position:absolute;top:-.4px;transform:translateX(-50%);width:.5px}.ocean-node:after{background:linear-gradient(90deg,#0000,#00bfffb3,#0000);content:"";height:.5px;left:-.4px;position:absolute;top:50%;transform:translateY(-50%);width:3.3px}.cloud-node{animation:cloudDrift 12s ease-in-out infinite;background:radial-gradient(circle,#add8e6cc 0,#87ceeb99 50%,#0000 100%);border-radius:50%;box-shadow:0 0 4px #add8e680,0 0 8px #87ceeb4d,0 0 12px #66cdaa33;height:2px;pointer-events:none;position:absolute;width:2px;z-index:4}.cloud-node:before{background:linear-gradient(180deg,#0000,#add8e699,#0000);content:"";height:2.6px;left:50%;position:absolute;top:-.3px;transform:translateX(-50%);width:.4px}.cloud-node:after{background:linear-gradient(90deg,#0000,#add8e699,#0000);content:"";height:.4px;left:-.3px;position:absolute;top:50%;transform:translateY(-50%);width:2.6px}@keyframes fadeInWithBubbles{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}50%{opacity:.7;transform:translate(-50%,-50%) scale(1.05)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes cosmicEntry{0%{filter:blur(10px);opacity:0;transform:translate(-50%,-50%) scale(.6) rotateY(180deg)}30%{filter:blur(5px);opacity:.5;transform:translate(-50%,-50%) scale(1.1) rotateY(90deg)}70%{filter:blur(2px);opacity:.8;transform:translate(-50%,-50%) scale(.95) rotateY(30deg)}to{filter:blur(0);opacity:1;transform:translate(-50%,-50%) scale(1) rotateY(0deg)}}@keyframes cosmicPulse{0%,to{opacity:.3;transform:scale(1) rotate(0deg)}33%{opacity:.6;transform:scale(1.3) rotate(120deg)}66%{opacity:.4;transform:scale(.8) rotate(240deg)}}@keyframes cosmicFloat{0%,to{opacity:.6;transform:translateY(0) translateX(0) scale(1) rotate(0deg)}25%{opacity:.8;transform:translateY(-30px) translateX(10px) scale(1.2) rotate(90deg)}50%{opacity:1;transform:translateY(-15px) translateX(-5px) scale(.9) rotate(180deg)}75%{opacity:.7;transform:translateY(-40px) translateX(15px) scale(1.1) rotate(270deg)}}@keyframes twinkle{0%,to{opacity:.3;transform:scale(1)}50%{opacity:1;transform:scale(1.5)}}@keyframes naturalTwinkle{0%,to{filter:brightness(1);opacity:.7;transform:scale(1)}25%{filter:brightness(.8);opacity:.5;transform:scale(.8)}50%{filter:brightness(1.3);opacity:1;transform:scale(1.2)}75%{filter:brightness(.9);opacity:.6;transform:scale(.9)}}.login-background-logo{bottom:16px;left:30px;opacity:.85;position:absolute;transform:none;transition:opacity .3s ease;z-index:10}.login-background-logo:hover{opacity:1}.login-background-logo img{display:block!important;filter:none!important;height:auto!important;max-height:80px!important;max-width:160px!important;width:auto!important}#login-box h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:700;margin:0 0 20px;text-align:center}.login-input{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;color:#f7f8fa;color:var(--text-primary);font-size:13px;margin-bottom:12px;padding:10px 14px;transition:all .3s ease;width:100%}.login-input:focus{border-color:#1f7cf4;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1f7cf41a;outline:none}.login-btn{background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:13px;font-weight:600;overflow:hidden;padding:10px;position:relative;transition:all .3s ease;width:100%}.login-btn:hover{box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.login-btn:active{transform:translateY(0)}.password-input-wrapper{width:100%}.password-input-wrapper .login-input{padding-right:40px}.password-toggle-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;color:var(--text-muted);cursor:pointer;display:flex;justify-content:center;margin-top:-6px;padding:4px;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:color .2s ease}.password-toggle-btn:hover{color:#1f7cf4;color:var(--primary-blue)}.password-toggle-btn:focus{outline:none}.password-toggle-btn svg{display:block}#topbar{flex-direction:column;right:13px!important;top:12px;z-index:900}#geocoder-toggle,#topbar{display:flex;position:fixed}#geocoder-toggle{align-items:center;background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;color:#e0e0e0;cursor:pointer;height:36px;justify-content:center;opacity:.85;right:12px;top:196px;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:36px;z-index:950}#geocoder-toggle svg{flex-shrink:0;height:18px;position:relative;width:18px;z-index:1}#geocoder-toggle:hover{background:#404040;border-color:#fff;color:#fff;opacity:1;transform:translateY(-1px)}#geocoder-toggle:active{transform:translateY(0)}#geocoder-toggle *{pointer-events:none}#geocoder-container{position:fixed;right:31px;top:179.59055px;transition:all .3s ease;width:260px;z-index:900}#geocoder-container.geocoder-minimized{opacity:0;pointer-events:none;transform:translateX(100%)}#geocoder-container.geocoder-expanded{opacity:1;pointer-events:all;transform:translateX(0)}#geocoder-toggle.hidden-when-expanded{opacity:0;pointer-events:none}#geocoder-container .mapboxgl-ctrl-geocoder{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#242730e6;border:1px solid #ffffff1a;border-radius:12px;box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d;box-shadow:var(--shadow-lg);min-width:300px;position:relative}.geocoder-close-btn{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:#f7f8fa;color:var(--text-primary);cursor:pointer;display:flex;font-size:16px;font-weight:700;height:24px;justify-content:center;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all .2s ease;width:24px;z-index:10}.geocoder-close-btn:hover{background:#ef4444;background:var(--error);color:#fff}#geocoder-container .mapboxgl-ctrl-geocoder--input{background:#0000;color:#f7f8fa;color:var(--text-primary);font-size:14px;padding:12px 40px!important}#geocoder-container .mapboxgl-ctrl-geocoder--input::placeholder{color:#6b7280;color:var(--text-muted)}#geocoder-container .mapboxgl-ctrl-geocoder--icon-search{fill:#6b7280;fill:var(--text-muted);height:18px!important;left:12px!important;top:50%!important;transform:translateY(-50%)!important;width:18px!important}#geocoder-container .mapboxgl-ctrl-geocoder--suggestions{background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl)}#geocoder-container .mapboxgl-ctrl-geocoder--suggestion{background:#2a2f38!important;background:var(--bg-card)!important;border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);color:#f7f8fa!important;color:var(--text-primary)!important;padding:12px 16px!important}#geocoder-container .mapboxgl-ctrl-geocoder--suggestion.mapboxgl-ctrl-geocoder--suggestion-selected,#geocoder-container .mapboxgl-ctrl-geocoder--suggestion:hover{background:#1f7cf4!important;background:var(--primary-blue)!important;color:#fff!important}#geocoder-container .mapboxgl-ctrl-geocoder--suggestion-title,#geocoder-container .mapboxgl-ctrl-geocoder--suggestion>*{color:inherit!important}#geocoder-container .mapboxgl-ctrl-geocoder--suggestion-address{color:#6b7280!important;color:var(--text-muted)!important}#geocoder-container .mapboxgl-ctrl-geocoder--suggestion.mapboxgl-ctrl-geocoder--suggestion-selected .mapboxgl-ctrl-geocoder--suggestion-address,#geocoder-container .mapboxgl-ctrl-geocoder--suggestion:hover .mapboxgl-ctrl-geocoder--suggestion-address{color:#fffc!important}.toolbar-btn{align-items:center;background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;color:#e0e0e0;cursor:pointer;display:flex;height:36px;justify-content:center;opacity:.85;padding:0;position:relative;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:36px}.toolbar-btn:hover{background:#3a3a3a;opacity:1;transform:scale(1.05)}.toolbar-btn:active{transform:scale(.98)}.toolbar-btn svg{flex-shrink:0;height:18px;width:18px}.zoom-fit-btn{background:#2a2a2a;border:2px solid #ffffffe6;color:#e0e0e0;opacity:.85}.zoom-fit-btn:hover{background:#404040;border-color:#fff;color:#fff;opacity:1;transform:translateY(-1px)}.zoom-fit-btn svg{height:18px;transition:transform .2s ease;width:18px}.zoom-fit-btn:hover svg{transform:none}.zoom-fit-btn span{font-weight:600;letter-spacing:.2px}.toolbar-btn *{pointer-events:none}#panel{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:rgba(22,28,38,.769);border-right:1px solid #3c414c;border-right:1px solid var(--border-color);box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;height:100vh;left:0;max-width:90vw;overflow-x:hidden;overflow-y:auto;padding:8px;position:fixed;top:0;transition:transform .4s cubic-bezier(.4,0,.2,1);width:320px;z-index:800}#panel.hide{transform:translateX(-100%)}#map.panel-hidden{transform:translateX(0)}#panel::-webkit-scrollbar{width:6px}#panel::-webkit-scrollbar-track{background:#0000}#panel::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.panel-header{margin-bottom:16px;text-align:center}.panel-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700}.section-title{color:#a0a7b4;color:var(--text-secondary);flex-shrink:0;font-size:10px;gap:6px;margin:8px 0 4px}.section-title:before{background:linear-gradient(135deg,#18d0cd,#1f7cf4);background:var(--gradient-accent);height:12px;width:2px}.add-data-icon-btn{align-items:center;background:#ffffff0d;border:1px solid #ffffff26;border-radius:6px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:inline-flex;flex-shrink:0;height:38px;justify-content:center;margin-right:8px;overflow:hidden;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);vertical-align:top;width:38px}.add-data-icon-btn:before{background:#3b82f633;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .3s ease;width:0;z-index:0}.add-data-icon-btn:hover:not(:disabled){background:#3b82f61a;border-color:#3b82f666;color:#1f7cf4;color:var(--primary-blue);transform:translateY(-1px)}.add-data-icon-btn:hover:not(:disabled):before{height:100%;width:100%}.add-data-icon-btn:active:not(:disabled){box-shadow:0 1px 4px #3b82f633;transform:translateY(0)}.add-data-icon-btn svg{height:19px;position:relative;transition:transform .2s ease;width:19px;z-index:1}.form-control{border-radius:8px;margin-bottom:10px;transition:all .3s ease}.form-control:focus{box-shadow:0 0 0 3px #1f7cf41a}.btn{font-size:11px;font-weight:600;gap:4px;padding:6px 14px;transition:all .3s ease}.btn-primary:hover{box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d;box-shadow:var(--shadow-lg)}.btn-secondary{background:#2a2f38;background:var(--bg-card);color:#f7f8fa}.btn-secondary:hover{background:#3c414c;background:var(--border-color)}.btn-small{font-size:10px;padding:4px 8px}.search-section{margin-bottom:6px}.layers-section{overflow:hidden}#layers-container{scroll-behavior:smooth;scrollbar-color:#ffffff4d #0000;scrollbar-width:thin}#layers-container::-webkit-scrollbar{width:4px}#layers-container::-webkit-scrollbar-track{background:#0000}#layers-container::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:2px;-webkit-transition:background .2s ease;transition:background .2s ease}#layers-container::-webkit-scrollbar-thumb:hover{background:#ffffff80}#layers-container:hover::-webkit-scrollbar-thumb{background:#fff6}#layers-container.has-scroll{position:relative}#layers-container.has-scroll:after,#layers-container.has-scroll:before{display:none}.layer-card{background:#2a2f38;border:1px solid #3c414c;max-width:100%;overflow:visible}.layer-card:hover{border-color:#1f7cf4;box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d}.layer-card.drag-over{border-color:#18d0cd}.layer-content{max-height:1200px;overflow-x:hidden;overflow-y:auto;scrollbar-color:#fff3 #0000;scrollbar-width:thin}.layer-content::-webkit-scrollbar{width:3px}.layer-content::-webkit-scrollbar-track{background:#0000}.layer-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.layer-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.layer-content.minimized{margin:0;pointer-events:none}.layer-control-btn{color:#a0a7b4}.layer-control-btn:hover:not(:disabled){color:#1f7cf4}.labels-content{position:relative}.data-viz-section input[type=color],.data-viz-section input[type=number],.data-viz-section input[type=range],.data-viz-section select{transition:all .2s ease}.data-viz-section input:focus,.data-viz-section select:focus{outline:2px solid #1f7cf4;outline:2px solid var(--primary-blue);outline-offset:2px}.data-viz-section .section-chevron,.labels-section .section-chevron{flex-shrink:0}.layer-header{margin-bottom:8px;overflow:visible}.drag-handle{border-radius:3px;cursor:grab!important;padding:2px;transition:background-color .2s ease}.drag-handle:hover{background-color:#ffffff1a}.drag-handle:active{cursor:grabbing!important}.opacity-slider,input[type=range]{-webkit-user-drag:none;user-drag:none;cursor:pointer!important;touch-action:pan-x;-moz-user-select:none}.opacity-slider::-webkit-slider-thumb,input[type=range]::-webkit-slider-thumb{cursor:grab!important}.opacity-slider::-webkit-slider-thumb:active,input[type=range]::-webkit-slider-thumb:active{cursor:grabbing!important}.opacity-slider::-moz-range-thumb,input[type=range]::-moz-range-thumb{cursor:grab!important}.opacity-slider::-moz-range-thumb:active,input[type=range]::-moz-range-thumb:active{cursor:grabbing!important}.layer-name{flex:1 1}.layer-filename{word-wrap:break-word;font-size:12px;line-height:1.3;overflow:visible;position:relative;top:-2px;white-space:normal;word-break:break-word}.layer-controls{position:relative;right:-10px;top:-10px}.layer-move-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;height:22px;justify-content:center;min-width:22px;padding:3px;transition:all .2s ease}.layer-move-btn:hover{background:#fff3;color:#f7f8fa;color:var(--text-primary);transform:translateY(-1px)}.layer-move-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.layer-toggle{background:#3c414c}.layer-toggle.active{background:#1f7cf4}.layer-info{gap:8px}.layer-details{display:flex;flex-direction:column;gap:4px}.layer-name-row{align-items:center;display:flex;gap:6px}.geometry-icon{flex-shrink:0;font-size:14px}.viz-indicator{flex-shrink:0;font-size:12px}.layer-meta{color:#a0a7b4;color:var(--text-secondary);display:flex;font-size:10px;gap:8px}.feature-count,.file-format,.geometry-type{white-space:nowrap}.visibility-toggle{align-items:center;background:#ffffff0d;border:1px solid #ffffff26;border-radius:6px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px;position:relative;right:-10px;top:-10px;transition:all .2s ease}.visibility-toggle:hover{background:#3b82f61a;border-color:#3b82f666;color:#1f7cf4;color:var(--primary-blue)}.visibility-toggle.visible{border-color:#3b82f64d;color:#1f7cf4;color:var(--primary-blue)}.expand-toggle{align-items:center;background:#ffffff0d;border:1px solid #ffffff26;border-radius:6px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px;position:relative;right:-10px;top:-10px;transition:all .2s ease}.expand-toggle:hover{background:#ffffff1a;color:#f7f8fa;color:var(--text-primary)}.expand-toggle.expanded svg{transform:rotate(180deg)}.control-label{align-items:center;color:#a0a7b4;color:var(--text-secondary);display:flex;font-size:11px;font-weight:500;justify-content:space-between}.opacity-value{color:#1f7cf4;color:var(--primary-blue);font-weight:600}.color-control{align-items:center;display:flex;gap:6px;margin-bottom:8px}.color-sample{display:flex;gap:4px}.fill-color,.outline-color{border:1px solid #fff3;border-radius:4px;cursor:pointer;height:24px;transition:transform .2s ease;width:24px}.fill-color:hover,.outline-color:hover{transform:scale(1.1)}.layer-actions{display:flex;flex-wrap:wrap;gap:6px}.layer-action-btn{align-items:center;background:#ffffff0d;border:1px solid #ffffff26;border-radius:6px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;height:28px;justify-content:center;min-width:28px;padding:6px;position:relative;right:-10px;top:-10px;transition:all .2s ease}.layer-action-btn:hover{background:#3b82f61a;border-color:#3b82f666;color:#1f7cf4;color:var(--primary-blue);transform:translate(-10px,-11px)}.layer-action-btn:active{transform:translate(-10px,-10px)}.layer-action-btn.delete:hover{background:#ef44441a;border-color:#ef444466;color:#ef4444}.color-picker{border:none;border-radius:6px;cursor:pointer;height:26px;transition:transform .2s;width:26px}.color-picker:hover{transform:scale(1.1)}.modern-color-control{gap:6px;position:relative}.coloris-input{border:1px solid #0003;border-radius:4px;box-shadow:0 1px 3px #0000001a;color:#0000;font-size:0;height:24px;padding:0;text-indent:-9999px;transition:all .15s ease;width:30px}.coloris-input:hover{border-color:#0000004d;box-shadow:0 2px 6px #00000026}.coloris-input:focus{border-color:#1f7cf4;box-shadow:0 0 0 2px #1f7cf41a;outline:none}.color-label{font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.color-label,.slider-label{color:#6b7280}.terrain-slider,.uniform-slider,input[type=range]{box-shadow:0 0 0 0 #2193b000;position:relative;transition:all .2s cubic-bezier(.25,.46,.45,.94)}.opacity-control{align-items:center;background:#ffffff08;border-radius:6px;display:flex;gap:8px;margin-top:8px;padding:8px;position:relative;transition:background .15s ease}.opacity-control:hover{background:#ffffff0f}.opacity-control:before{background:#1f7cf4;background:var(--primary-blue);border-radius:6px 0 0 6px;bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;transition:opacity .15s ease;width:3px}.opacity-control:hover:before{opacity:.6}.opacity-control .opacity-value{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:600;min-width:35px;text-align:right;transition:none}.opacity-control-horizontal{gap:8px}.opacity-control-horizontal .opacity-slider{-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,#2193b0 0,#6dd5ed 50%,#e2e8f0 0,#e2e8f0);background:linear-gradient(to right,#2193b0 0,#6dd5ed var(--value,50%),#e2e8f0 var(--value,50%),#e2e8f0 100%);border:none;border-radius:2px;cursor:pointer;flex:1 1;height:3px;min-width:40px;outline:none;transition:all .15s cubic-bezier(.25,.46,.45,.94)}.opacity-control-horizontal .opacity-slider:hover{background:linear-gradient(90deg,#1a7da0 0,#36d1dc 50%,#e2e8f0 0,#e2e8f0);background:linear-gradient(to right,#1a7da0 0,#36d1dc var(--value,50%),#e2e8f0 var(--value,50%),#e2e8f0 100%);box-shadow:0 2px 8px #2193b033;height:4px}.opacity-control-horizontal .opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#36d1dc,#5b86e5);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #2193b04d,0 4px 16px #5b86e526;cursor:grab;height:14px;-webkit-transition:all .15s cubic-bezier(.25,.46,.45,.94);transition:all .15s cubic-bezier(.25,.46,.45,.94);width:14px}.opacity-control-horizontal .opacity-slider::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#2193b0,#4a78f7);border-color:#fff;box-shadow:0 4px 16px #2193b066,0 8px 32px #5b86e540;transform:scale(1.25)}.opacity-control-horizontal .opacity-slider::-webkit-slider-thumb:active{background:linear-gradient(135deg,#1a7da0,#3d68e6);box-shadow:0 2px 12px #2193b080,0 6px 24px #5b86e54d;transform:scale(1.15)}.opacity-control-horizontal .opacity-slider::-moz-range-thumb{background:linear-gradient(135deg,#36d1dc,#5b86e5);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #2193b04d,0 4px 16px #5b86e526;cursor:grab;height:14px;-moz-transition:all .15s cubic-bezier(.25,.46,.45,.94);transition:all .15s cubic-bezier(.25,.46,.45,.94);width:14px}.opacity-control-horizontal .opacity-slider::-moz-range-thumb:hover{background:linear-gradient(135deg,#2193b0,#4a78f7);border-color:#fff;box-shadow:0 4px 16px #2193b066,0 8px 32px #5b86e540;transform:scale(1.25)}.opacity-control-horizontal .opacity-value{font-feature-settings:"tnum";color:#6b7280;color:var(--text-muted);font-size:10px;font-variant-numeric:tabular-nums;font-weight:600;min-width:30px;text-align:right;transition:color .1s ease}.opacity-slider{background:linear-gradient(90deg,#2193b0 0,#6dd5ed 50%,#e2e8f0 0,#e2e8f0);background:linear-gradient(to right,#2193b0 0,#6dd5ed var(--value,50%),#e2e8f0 var(--value,50%),#e2e8f0 100%);height:3px;position:relative;transition:all .2s cubic-bezier(.25,.46,.45,.94);will-change:background}.opacity-slider:hover{background:linear-gradient(90deg,#1a7da0 0,#36d1dc 50%,#e2e8f0 0,#e2e8f0);background:linear-gradient(to right,#1a7da0 0,#36d1dc var(--value,50%),#e2e8f0 var(--value,50%),#e2e8f0 100%);box-shadow:0 2px 8px #2193b033;height:4px}.opacity-slider::-webkit-slider-thumb{background:linear-gradient(135deg,#36d1dc,#5b86e5);box-shadow:0 2px 8px #2193b04d,0 4px 16px #5b86e526;cursor:grab;height:14px;position:relative;-webkit-transition:all .2s cubic-bezier(.25,.46,.45,.94);transition:all .2s cubic-bezier(.25,.46,.45,.94);width:14px;z-index:2}.opacity-slider::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#2193b0,#4a78f7);border-color:#fff;box-shadow:0 4px 16px #2193b066,0 8px 32px #5b86e540;cursor:grab;transform:scale(1.25)}.opacity-slider::-webkit-slider-thumb:active{background:linear-gradient(135deg,#1a7da0,#3d68e6);box-shadow:0 2px 12px #2193b080,0 6px 24px #5b86e54d;cursor:grabbing;transform:scale(1.15)}.opacity-slider::-moz-range-thumb{background:linear-gradient(135deg,#36d1dc,#5b86e5);box-shadow:0 2px 8px #2193b04d,0 4px 16px #5b86e526;cursor:grab;height:14px;position:relative;-moz-transition:all .2s cubic-bezier(.25,.46,.45,.94);transition:all .2s cubic-bezier(.25,.46,.45,.94);width:14px;z-index:2}.opacity-slider::-moz-range-thumb:hover{background:linear-gradient(135deg,#2193b0,#4a78f7);border-color:#fff;box-shadow:0 4px 16px #2193b066,0 8px 32px #5b86e540;transform:scale(1.25)}.opacity-slider::-moz-range-thumb:active{background:linear-gradient(135deg,#1a7da0,#3d68e6);box-shadow:0 2px 12px #2193b080,0 6px 24px #5b86e54d;transform:scale(1.15)}.opacity-slider::-moz-range-track{background:#e2e8f0;border:none;border-radius:2px;height:3px}.opacity-slider:focus{outline:none}.opacity-slider:focus::-webkit-slider-thumb{box-shadow:0 0 0 4px #2193b066,0 4px 16px #5b86e54d}.opacity-slider:focus::-moz-range-thumb{box-shadow:0 0 0 4px #2193b066,0 4px 16px #5b86e54d}.slider{background-color:#3c414c}.switch input:checked+.slider{background-color:#1f7cf4}.legend-opacity{background:#1a1e26d3;background:var(--bg-input);border-radius:4px;color:#6b7280;color:var(--text-muted)}.search-container{flex-shrink:0;margin-bottom:6px;position:relative}.search-input{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;color:#f7f8fa;color:var(--text-primary);font-size:12px;padding:8px 32px;transition:all .3s ease;width:100%}.search-input:focus{border-color:#1f7cf4;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1f7cf41a;outline:none}.search-icon{color:#6b7280;color:var(--text-muted);height:14px;left:10px;width:14px}.search-clear-icon-btn,.search-icon{position:absolute;top:50%;transform:translateY(-50%)}.search-clear-icon-btn{align-items:center;background:#ffffff0d;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;padding:0;right:6px;transition:all .2s;width:24px}.search-clear-icon-btn:hover{background:#ef444426;border-color:#ef444466;color:#ef4444}.search-results{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#161c26e6;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d;box-shadow:var(--shadow-lg);left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:9999}.search-results-header{background:#1f7cf41a;color:#a0a7b4;color:var(--text-secondary);font-size:10px;font-weight:600;letter-spacing:.5px;padding:8px 12px;text-transform:uppercase}.search-result-item,.search-results-header{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color)}.search-result-item{cursor:pointer;font-size:11px;padding:10px 12px;transition:all .2s}.search-result-item:hover{background:#1f7cf426}.search-result-item:last-child{border-bottom:none}.search-result-layer-name{color:#f7f8fa;color:var(--text-primary);font-size:11px;font-weight:600;margin-bottom:4px}.search-result-details{color:#a0a7b4;color:var(--text-secondary);display:flex;flex-wrap:wrap;font-size:10px;gap:4px}.search-result-field{color:#1f7cf4;font-weight:600}.search-result-value{color:#a0a7b4;color:var(--text-secondary);word-break:break-word}.search-results-empty{color:#a0a7b4;color:var(--text-secondary);font-size:11px;padding:16px 12px;text-align:center}#toggle-panel{align-items:center;-webkit-backdrop-filter:none;backdrop-filter:none;background:#0000;border:none;border-radius:0;box-shadow:none;color:#3b82f6;cursor:pointer;display:flex;filter:drop-shadow(0 2px 6px rgba(59,130,246,.5));height:28px;justify-content:center;left:324px;position:fixed;top:29px;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-user-select:none;user-select:none;width:28px;z-index:900}body:has(#panel.hide) #toggle-panel{left:12px}.panel-hidden #toggle-panel{left:12px}#toggle-panel svg{flex-shrink:0;height:29px;width:29px}#toggle-panel:hover{color:#3b82f6;filter:drop-shadow(0 4px 8px rgba(59,130,246,.4));transform:scale(1.1)}#toggle-panel:active{filter:drop-shadow(0 2px 6px rgba(59,130,246,.6));transform:scale(.95)}#toggle-panel *{pointer-events:none}#toast{background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;bottom:50px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);color:#f7f8fa;color:var(--text-primary);font-size:12px;font-weight:500;max-width:320px;opacity:0;padding:10px 14px;position:fixed;right:20px;transform:translateY(20px);transition:all .4s cubic-bezier(.4,0,.2,1);z-index:1100}#toast.show{opacity:1;transform:translateY(0)}.attribute-panel{border-top:2px solid #1f7cf4;border-top:2px solid var(--primary-blue)}.attribute-resize-handle{pointer-events:auto;z-index:9999}.resize-handle-indicator{background:#1f7cf4;background:var(--primary-blue)}.table-tabs-controls{display:flex;gap:4px;padding-left:8px}.table-tabs-controls .action-button{background:#e9ecef;border:1px solid #dee2e6;border-radius:3px;color:#495057;font-size:11px;padding:4px 8px}.table-tabs-controls .action-button:hover{background:#dee2e6}.attribute-panel-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;min-height:36px;padding:6px 12px}.attribute-panel-header-compact{background:#f8f9fa;cursor:move;flex-wrap:nowrap;min-height:26px;overflow-x:auto;padding:3px 8px;-webkit-user-select:none;user-select:none}.legend-panel{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#161c26f2;border:1px solid #3c414c;border-radius:12px;box-shadow:0 25px 80px #0009;max-height:calc(100vh - 200px);max-width:calc(100vw - 360px);min-width:280px;opacity:1;overflow:hidden;position:fixed;right:16px;top:120px;transform:translateX(0);visibility:visible;width:300px;z-index:999}@media (max-width:1024px){.legend-panel{max-width:calc(100vw - 40px);right:20px}}@media (max-width:768px){.legend-panel{left:16px;max-width:none;right:16px;top:100px;width:calc(100vw - 32px)}}.legend-panel.hidden{display:none}.legend-panel.minimized{opacity:0;pointer-events:none;transform:translateX(calc(100% + 32px));visibility:hidden}.legend-panel-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2a2f3899;min-height:40px;padding:10px 14px}.legend-panel-title{align-items:center;color:#e0e0e0;display:flex;font-size:13px;font-weight:600;gap:6px;letter-spacing:.3px}.legend-panel-title svg{color:#18d0cd;color:var(--accent-teal);height:14px;width:14px}.legend-panel-controls{display:flex;gap:4px}.legend-panel-controls .action-button{align-items:center;background:#ffffff0d;border:1px solid #3c414c;border-radius:4px;color:#999;cursor:pointer;display:flex;height:24px;justify-content:center;transition:all .2s ease;width:24px}.legend-panel-controls .action-button:hover{background:#ffffff1a;border-color:#1f7cf4;color:#fff}.legend-panel-controls .action-button svg{height:12px;width:12px}.legend-content{color:#e0e0e0;font-size:12px;line-height:1.4;max-height:calc(100vh - 280px);padding:10px 12px;pointer-events:auto}.legend-content::-webkit-scrollbar-track{background:#0003}.legend-content::-webkit-scrollbar-thumb{background:#fff3}.legend-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.legend-item{background:#2a2f3899;border:1px solid #3c414c;border-radius:4px;gap:6px;margin-bottom:4px;min-height:28px;padding:5px 8px;transition:all .2s ease}.legend-item:hover{background:#2a2f38e6;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf44d}.legend-item:last-child{margin-bottom:0}.legend-color{border:1px solid #fff3;border-radius:3px;box-shadow:0 2px 4px #0000004d;flex-shrink:0;height:14px;width:14px}.legend-text{color:#e0e0e0;flex:1 1;font-size:12px;font-weight:500;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-opacity{color:#888;font-size:10px;font-weight:500;padding:2px 4px}.legend-minimized-icon{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#242730d9;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;bottom:120px;box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d;box-shadow:var(--shadow-lg);color:#f7f8fa;color:var(--text-primary);cursor:pointer;display:flex;height:40px;justify-content:center;position:fixed;right:16px;transition:background .3s ease,border-color .3s ease,box-shadow .3s ease,color .3s ease;width:40px;z-index:998}.legend-minimized-icon:hover{background:#242730f2;border-color:#1f7cf4;border-color:var(--primary-blue);box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);color:#18d0cd;color:var(--accent-teal)}.legend-minimized-icon svg{height:18px;width:18px}.legend-content .legend-item{align-items:center;border-bottom:1px solid #0000000f;display:flex;gap:8px;padding:8px 0;pointer-events:auto}.legend-content .legend-item:last-child{border-bottom:none}.legend-content .legend-color{border:1px solid #0000001a;border-radius:3px;flex-shrink:0;height:16px;width:16px}.legend-content .legend-text{color:#374151;flex:1 1;font-size:12px;font-weight:500;line-height:1.3}.floating-map-style-control{position:fixed;right:12px;top:465px;z-index:1000}.swipe-tool-control{position:fixed;right:12px;top:271px;transition:right .3s ease;z-index:1000}.map-style-toggle-btn{align-items:center;background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;color:#e0e0e0;cursor:pointer;display:flex;height:36px;justify-content:center;opacity:.85;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:36px}.map-style-toggle-btn:hover{background:#404040;border-color:#fff;color:#fff;opacity:1;transform:translateY(-1px)}.map-style-toggle-btn svg{stroke:#f0f0f0!important;flex-shrink:0;height:18px;position:relative;width:18px;z-index:1}.map-style-menu{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #0000001a;border-radius:8px;bottom:-180px;box-shadow:0 8px 24px #00000026;max-height:400px;max-width:220px;min-width:180px;opacity:0;overflow-y:auto;padding:8px;position:absolute;right:38px;transform:translateY(10px);transition:all .2s ease}.map-style-menu:not(.hidden){opacity:1;transform:translateY(0)}.map-style-separator{background:#0000001a;height:1px;margin:6px 0 4px}.map-overlay-section{padding-top:2px}.map-overlay-option{padding:2px 10px}.overlay-checkbox-label{align-items:center;border-radius:4px;color:#374151;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:8px;padding:3px 0;transition:background-color .2s ease}.overlay-checkbox-label:hover{background-color:#3b82f61a}.overlay-checkbox{accent-color:#3b82f6;cursor:pointer;height:14px;width:14px}.overlay-name{flex:1 1;-webkit-user-select:none;user-select:none}.terrain-exaggeration-control{background:#00000005;border-radius:4px;margin:4px 0 2px;padding:6px 10px 4px;transition:all .3s ease}.terrain-exaggeration-control.hidden{display:none}.exaggeration-label{color:#6b7280;font-size:10px;font-weight:600;margin-bottom:6px;text-align:center}.exaggeration-slider-container{align-items:center;display:flex;gap:8px}.exaggeration-value{background:#fffc;border:1px solid #0000001a;border-radius:3px;color:#374151;font-size:10px;font-weight:600;gap:8px;min-width:30px;padding:2px 4px;text-align:center}.map-style-option{align-items:center;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:8px;padding:6px 10px;transition:background-color .2s ease}.map-style-option:hover{background:#3b82f61a}.map-style-option.active{background:#3b82f626;color:#1d4ed8}.style-preview{border:1px solid #0000001a;border-radius:3px;flex-shrink:0;height:14px;width:20px}.menu-section{margin-bottom:8px}.section-title{font-size:11px;margin-bottom:6px;padding:0 4px}.overlay-option{align-items:center;border:1px solid #ffffff1a;border-radius:4px;cursor:pointer;display:flex;margin:2px 0;padding:8px 12px;transition:all .2s ease}.overlay-option:hover{background-color:#ffffff0d}.overlay-option.active{background-color:#3b82f61a}.street-preview{background:linear-gradient(45deg,#f8f9fa 50%,#e9ecef 0)}.satellite-preview{background:linear-gradient(45deg,#8b7355 25%,#a67c52 0,#a67c52 50%,#8b7355 0,#8b7355 75%,#a67c52 0);background-size:4px 4px}.satellite-streets-preview{background:linear-gradient(135deg,#8b7355,#a67c52 30%,#fff 31%,#fff 32%,#a67c52 33%,#8b7355)}.light-preview{background:linear-gradient(45deg,#fff 50%,#f8f9fa 0)}.dark-preview{background:linear-gradient(45deg,#1a1a1a 50%,#2d2d2d 0)}.satellite-preview{background:linear-gradient(45deg,#4a5568 25%,#2d3748 0,#2d3748 50%,#4a5568 0,#4a5568 75%,#2d3748 0);background-size:8px 8px}.outdoors-preview{background:linear-gradient(45deg,#68d391 50%,#48bb78 0)}.attribute-panel.dragging{will-change:transform;z-index:9999}.attribute-panel.dragging .attribute-panel-content,.attribute-panel.dragging .attribute-panel-toolbar{pointer-events:none}.attribute-panel.dragging .attribute-panel-controls,.attribute-panel.dragging .attribute-panel-controls *{pointer-events:auto}.attribute-panel-title{color:#2c3e50;font-size:12px;font-weight:500;gap:6px}.attribute-panel-title svg{color:#1f7cf4;height:14px;width:14px}.attribute-panel-controls{gap:4px;pointer-events:auto;position:relative;z-index:10}.attribute-panel-controls .action-button{pointer-events:auto;z-index:11}.compact-btn{border-radius:3px!important;font-size:10px!important;gap:3px!important;min-height:20px!important;padding:2px 6px!important}.compact-btn svg{height:12px!important;width:12px!important}.action-button.active{background:#1f7cf4!important;border-color:#1f7cf4!important;box-shadow:0 0 10px #1f7cf44d!important;color:#fff!important}.action-button.active:hover{background:#1e40af!important;border-color:#1e40af!important;box-shadow:0 0 15px #1e40af66!important}.mapboxgl-canvas{transition:filter .2s ease}.point-placement-mode .mapboxgl-canvas{filter:brightness(1.1) saturate(1.2)}.point-placement-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1f7cf4e6;border:1px solid #fff3;border-radius:25px;box-shadow:0 4px 15px #1f7cf44d;color:#fff;font-size:14px;font-weight:500;left:50%;padding:12px 20px;pointer-events:none;position:fixed;top:20px;transform:translateX(-50%);z-index:1000}.point-placement-overlay:before{content:"📍";margin-right:8px}.newly-added-row{background:linear-gradient(90deg,#1f7cf41a,#1f7cf40d)!important;border:1px solid #1f7cf44d!important;position:relative}.newly-added-row:before{background:#1f7cf4;border-radius:2px;color:#fff;content:"NEW";font-size:8px;font-weight:700;opacity:.8;padding:1px 4px;position:absolute;right:4px;top:2px;z-index:10}.newly-added-row:hover{background:linear-gradient(90deg,#1f7cf426,#1f7cf414)!important;border-color:#1f7cf480!important}.cell-ready-to-edit{animation:pulseEdit 2s ease-in-out infinite}@keyframes pulseEdit{0%,to{background-color:#1f7cf40d;border-color:#1f7cf480}50%{background-color:#1f7cf41a;border-color:#1f7cf4cc}}.attribute-panel-header-compact .attribute-panel-title{font-size:11px;font-weight:600;gap:4px;white-space:nowrap}.attribute-panel-header-compact .data-view-toggle{border:1px solid #d1d5db;border-radius:4px}.attribute-panel-header-compact .data-view-toggle button{font-size:9px;font-weight:500;padding:2px 6px}.attribute-panel-header-compact .row-count-indicator{color:#6b7280;font-size:10px;white-space:nowrap}.attribute-panel-header-compact .attribute-panel-controls{gap:2px;margin-left:auto}@media (max-width:1200px){.attribute-panel-header-compact{flex-wrap:wrap;gap:4px;min-height:auto}.attribute-panel-header-compact .compact-btn{font-size:9px!important;padding:1px 4px!important}.attribute-panel-header-compact .compact-btn svg{height:10px!important;width:10px!important}}@media (max-width:900px){.attribute-panel-header-compact{padding:2px 6px}.attribute-panel-header-compact .attribute-panel-title span{display:none}.attribute-panel-header-compact .data-view-toggle button{font-size:8px;padding:1px 4px}}.attribute-panel-toolbar{align-items:center;background:#fff;border-bottom:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:6px;min-height:36px;padding:6px 12px}.data-view-toggle{background:#fff;border-radius:6px}.data-view-toggle button{background:#0000;color:#a0a7b4;color:var(--text-secondary);font-size:10px;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.data-view-toggle button.active{background:#1f7cf4;background:var(--primary-blue)}.map-display-options{align-items:center;display:flex;gap:6px}.map-display-options .action-button{align-items:center;background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;font-size:10px;gap:3px;padding:4px 8px;transition:all .2s ease}.map-display-options .action-button:hover{background:var(--bg-hover);color:#f7f8fa;color:var(--text-primary)}.map-display-options .action-button.active{background:#1f7cf4;background:var(--primary-blue);border-color:#1f7cf4;border-color:var(--primary-blue);color:#fff}.data-view-toggle button:hover:not(.active){background:#2a2f38;background:var(--bg-card);color:#f7f8fa;color:var(--text-primary)}.row-count-indicator{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:11px;font-weight:500;padding:6px 12px}.row-count-indicator .count{color:#1f7cf4}.filter-controls{align-items:center;display:flex;flex:1 1;gap:8px}.filter-input-group{flex:1 1;max-width:300px;position:relative}.filter-input-group input{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;font-size:12px;padding:8px 12px 8px 36px;transition:all .2s ease;width:100%}.filter-input-group input:focus{border-color:#1f7cf4;box-shadow:0 0 0 2px #1f7cf433;outline:none}.filter-input-group .search-icon{color:#9ca3af;height:14px;left:12px;position:absolute;top:50%;transform:translateY(-50%);width:14px}.selection-controls{align-items:center;display:flex;gap:6px}.selection-button{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#6b7280;cursor:pointer;font-size:11px;font-weight:500;letter-spacing:.5px;padding:6px 10px;text-transform:uppercase;transition:all .2s ease}.selection-button:hover{background:#f3f4f6;color:#374151}.selection-button.active{background:#1f7cf4;border-color:#1f7cf4;color:#fff}.action-buttons{gap:6px;margin-left:auto}.action-button{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;color:#a0a7b4;color:var(--text-secondary);font-weight:600;gap:4px;overflow:hidden;padding:8px 10px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.action-button:hover{background:#1f7cf4;background:var(--primary-blue);border-color:#1f7cf4;border-color:var(--primary-blue);box-shadow:0 4px 12px #1f7cf44d;color:#fff;transform:translateY(-1px)}.action-button svg{height:14px;width:14px}.attribute-panel-content{background:#10161ca8;background:var(--bg-main)}.column-resize-handle{transition:background-color .2s;width:5px}.column-resize-handle:hover{background:#1f7cf44d!important}.column-resize-handle:active{background:#1f7cf480!important}#attribute-table th{word-wrap:break-word;box-sizing:border-box;height:28px;line-height:1.2;overflow-wrap:break-word;padding:4px 6px;position:relative;-webkit-user-select:none;user-select:none;vertical-align:middle;white-space:nowrap}#attribute-table th .column-name{color:#1f2937;display:inline-block;flex:1 1;font-size:11px;font-weight:600;-webkit-hyphens:auto;hyphens:auto;line-height:1.2;margin-left:1px;max-width:none;order:1;text-align:left;word-break:break-word}#attribute-table .column-menu-btn{flex-shrink:0;height:16px;margin-right:2px;order:0;padding:2px;width:16px}#attribute-table .column-menu-btn svg{height:10px;width:10px}#attribute-table .header-content{align-items:center;display:flex;height:20px}#attribute-table .header-left{align-items:center;display:flex;gap:2px;width:100%}#attribute-table .header-text{align-items:center;display:flex;flex:1 1;gap:2px;margin-left:-1px;min-width:0}#attribute-table .pin-icon,#attribute-table .sort-icon{flex-shrink:0;font-size:10px;line-height:1}#attribute-table .pin-icon{margin-left:3px;opacity:.8;order:2}#attribute-table .sort-icon{margin-left:2px;opacity:.7;order:3}#attribute-table th:hover .column-resize-handle{background:#1f7cf41a}.sorting-active{transition:all .3s ease}.sorting-column{background:#1f7cf41a!important;transform:scale(1.02);transition:all .2s ease}.sorted-column{background:#1f7cf40d!important;border-top:2px solid #1f7cf4!important;border-top:2px solid var(--primary-blue)!important}.sort-indicator{align-items:center;display:inline-flex;opacity:.3;transition:all .2s ease}.sort-indicator.active{animation:sortPulse .3s ease;color:#1f7cf4;color:var(--primary-blue);opacity:1}.sort-indicator.asc svg path,.sort-indicator.desc svg path{fill:#1f7cf4;fill:var(--primary-blue)}@keyframes sortPulse{0%{transform:scale(1)}50%{transform:scale(1.3)}to{transform:scale(1)}}.pin-indicator{align-items:center;display:inline-flex;margin-right:4px;opacity:.3;transition:all .2s ease}.pin-indicator.active{animation:pinPulse .4s ease;color:#1f7cf4;color:var(--primary-blue);opacity:1}.pin-indicator.active svg path{fill:#1f7cf4;fill:var(--primary-blue)}@keyframes pinPulse{0%{transform:rotate(0deg) scale(1)}25%{transform:rotate(5deg) scale(1.1)}75%{transform:rotate(-5deg) scale(1.1)}to{transform:rotate(0deg) scale(1)}}.pinning-column{background:#1f7cf426!important;box-shadow:0 0 15px #1f7cf44d;transform:translateX(10px);transition:all .3s ease}.unpinning-column{background:#c8c8c81a!important;transform:translateX(-10px);transition:all .3s ease}.pinned-column{background:#f8faff!important;border-right:2px solid #1f7cf4!important;border-right:2px solid var(--primary-blue)!important;position:relative}.pinned-column:after{background:#1f7cf4;background:var(--primary-blue);bottom:0;content:"";opacity:.8;position:absolute;right:0;top:0;width:2px}#attribute-table th.pinned-column{background:#f8faff!important;z-index:30!important}#attribute-table td.pinned-column{background:#fff!important;z-index:25!important}#attribute-table th:hover{background:#1f7cf408!important;transition:background-color .15s ease}#attribute-table th:hover .pin-indicator,#attribute-table th:hover .sort-indicator{opacity:.7}.table-loading{opacity:.7;position:relative}.table-loading:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#1f7cf4;border-top:2px solid var(--primary-blue);content:"";height:20px;left:50%;margin:-10px 0 0 -10px;position:absolute;top:50%;width:20px}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-10px)}20%{opacity:1;transform:translateY(0)}80%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-10px)}}#attribute-table th[data-column]:focus{background:#1f7cf41a!important;outline:2px solid #1f7cf4;outline:2px solid var(--primary-blue);outline-offset:-2px}kbd{background:#f4f4f4;border:1px solid #ccc;border-radius:3px;box-shadow:0 1px 0 #0003;color:#333;font-family:monospace;font-size:11px;padding:2px 6px}.attribute-panel-content{display:flex;flex-direction:column;overflow:hidden}.attribute-table{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;width:100%}.data-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:4px;flex:1 1;max-height:calc(100vh - 200px);position:relative}#attribute-table{border-collapse:initial;border-spacing:0;position:relative;width:100%}#attribute-table thead{background:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:100}#attribute-table tbody{background:#fff;position:relative}.attribute-table th{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:#fff!important;border-bottom:2px solid #e5e7eb;border-right:1px solid #e5e7eb;box-shadow:0 1px 0 #e5e7eb;color:#1f2937!important;font-size:11px;font-weight:500;height:28px;letter-spacing:.2px;line-height:1.2;min-width:60px;opacity:1!important;padding:4px 8px;text-transform:none;transition:none!important;vertical-align:middle;z-index:100!important}.attribute-table th:last-child{border-right:none}.attribute-table th:hover{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;color:#1f2937!important;opacity:1!important}.attribute-table th.sorted{background:#1f7cf4!important;color:#fff!important;opacity:1!important}.attribute-table th.pin-animation,.attribute-table th.pinned,.attribute-table th.sorting{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:#fff!important;opacity:1!important}.attribute-table th,.attribute-table th:active,.attribute-table th:focus,.attribute-table th:hover,.attribute-table th:nth-child(n),.attribute-table th:nth-child(n):active,.attribute-table th:nth-child(n):hover,.attribute-table th[style*="left:"],.attribute-table th[style*="position: sticky"]{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:#fff!important;filter:none!important;-webkit-filter:none!important;opacity:1!important}.attribute-table th:hover{background:#f8f9fa!important}.attribute-table th{overflow:auto;position:relative;resize:horizontal}.attribute-table th:after{background:#0000;bottom:0;content:"";cursor:col-resize;position:absolute;right:0;top:0;width:4px;z-index:100}.attribute-table th:after:hover{background:#1f7cf4}.attribute-table td{border-bottom:1px solid #f3f4f6;font-size:11px;height:24px;line-height:1.3;padding:3px 8px;vertical-align:middle}.attribute-table td:last-child{border-right:none}.attribute-table tbody tr:hover{background-color:#f8fafc}.attribute-table tbody tr:nth-child(2n){background-color:#f9fafb}.attribute-table tbody tr:nth-child(2n):hover{background-color:#f1f5f9}.attribute-table tbody tr:hover{background:#f8f9fa}.attribute-table tbody tr.selected{background:#eff6ff;border-left:3px solid #1f7cf4}.attribute-table tbody tr.highlighted{background:#f0fdfa;border-left:3px solid #18d0cd}.data-type-indicator{border-radius:50%;display:inline-block;height:8px;margin-right:6px;opacity:.7;width:8px}.data-type-string{background:#8e8e8e}.data-type-number{background:#4a90e2}.data-type-boolean{background:#7ed321}.data-type-date{background:#f5a623}.data-type-geometry{background:#d0021b}.column-resize-handle{background:#0000;bottom:0;cursor:col-resize;position:absolute;right:0;top:0;transition:background .2s ease;width:4px}.column-resize-handle:hover{background:#1f7cf4}.sort-indicator{font-size:10px;margin-left:6px;opacity:.7}.sort-indicator.asc:after{color:#1f7cf4;content:"↑";font-weight:700}.sort-indicator.desc:after{color:#1f7cf4;content:"↓";font-weight:700}.file-upload{display:inline-block;margin-bottom:10px;position:relative;width:100%}.file-upload-input{cursor:pointer;height:100%;opacity:0;position:absolute;width:100%}.file-upload-label{align-items:center;background:#1a1e26d3;background:var(--bg-input);border:2px dashed #3c414c;border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;padding:16px;transition:all .3s ease}.file-upload-label:hover{background:#1f7cf40d;border-color:#1f7cf4;border-color:var(--primary-blue)}.file-upload-icon{color:#6b7280;color:var(--text-muted);height:24px;margin-bottom:6px;width:24px}.file-upload-text{font-size:12px;font-weight:500;margin-bottom:3px}.file-upload-hint{color:#6b7280;color:var(--text-muted);font-size:10px}.pdf-export-hidden{display:none!important;visibility:hidden!important}@media (max-width:768px){#panel{padding:12px;width:100vw}.layer-content{max-height:800px}.data-viz-section,.labels-section{margin-bottom:4px}.data-viz-section input,.data-viz-section select{min-height:40px}}#login-box{max-width:360px;padding:30px 20px;width:85vw}#topbar{gap:8px;right:10px;top:10px}#toggle-panel{left:2px;top:27px}.toolbar-btn{padding:10px 12px}.toolbar-btn span{display:none}.data-table-container::-webkit-scrollbar,.search-results::-webkit-scrollbar{width:8px}.data-table-container::-webkit-scrollbar-track,.search-results::-webkit-scrollbar-track{background:#f8f9fa;border-radius:4px}.data-table-container::-webkit-scrollbar-thumb,.search-results::-webkit-scrollbar-thumb{background:#d1d5db;border:1px solid #e5e7eb;border-radius:4px}.data-table-container::-webkit-scrollbar-thumb:hover,.search-results::-webkit-scrollbar-thumb:hover{background:#9ca3af}.pdf-modal{align-items:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.pdf-modal-content{animation:modalSlideIn .3s cubic-bezier(.4,0,.2,1);background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:0;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);max-width:420px;width:90vw}.pdf-modal-header{align-items:center;border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:14px 18px 12px}.pdf-modal-header h3{color:#f7f8fa;color:var(--text-primary);font-size:14px;font-weight:600;margin:0}.pdf-modal-body{padding:14px 18px}.pdf-modal-footer{border-top:1px solid #3c414c;border-top:1px solid var(--border-color);display:flex;gap:8px;justify-content:flex-end;padding:12px 18px 14px}.progress-container{margin-bottom:10px}.progress-bar{background:#3c414c;background:var(--border-color);margin-bottom:6px}.progress-fill{background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);border-radius:4px;width:0}.progress-text{color:#1f7cf4;color:var(--primary-blue);font-size:14px;margin-bottom:6px;text-align:center}.progress-status{color:#a0a7b4;color:var(--text-secondary);font-size:11px;text-align:center}.filter-panel{background:#242730;background:var(--bg-panel);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);cursor:default;max-height:420px;overflow:hidden;right:2cm;top:.5cm;width:280px;z-index:1000}.filter-panel.dragging{cursor:move;opacity:.9}.filter-panel-header{background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);border-bottom:1px solid var(--border-color);cursor:move;padding:8px 10px;-webkit-user-select:none;user-select:none}.filter-panel-title{align-items:center;color:#fff;display:flex;font-size:12px;font-weight:600;gap:4px}.filter-panel-title svg{stroke:#fff;height:14px;width:14px}.filter-panel-controls{display:flex;gap:4px}.filter-panel-content{max-height:380px;overflow-y:auto;padding:8px}.filter-section{margin-bottom:10px}.filter-section-title{align-items:center;color:#f7f8fa;color:var(--text-primary);display:flex;font-size:12px;gap:4px;margin-bottom:8px}.filter-controls-container{background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;padding:8px}.filter-row{display:flex;gap:4px;margin-bottom:6px}.filter-row:last-child{margin-bottom:0}.filter-select{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#f7f8fa;color:var(--text-primary);flex:1 1;font-size:12px;outline:none;padding:6px 8px}.filter-select:hover{box-shadow:0 2px 4px #1f7cf426}.filter-select:focus,.filter-select:hover{border-color:#1f7cf4;border-color:var(--primary-blue)}.filter-select:focus{box-shadow:0 0 0 2px #1f7cf433}.filter-select option{background:#1a1e26d3;background:var(--bg-input);color:#f7f8fa;color:var(--text-primary);padding:10px 12px}.filter-select option:hover{background:#1f7cf4;background:var(--primary-blue);color:#fff}.filter-select option:checked{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.filter-input{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#f7f8fa;color:var(--text-primary);flex:1 1;font-size:12px;outline:none;padding:6px 8px}.filter-input:focus{border-color:#1f7cf4;border-color:var(--primary-blue);box-shadow:0 0 0 2px #1f7cf433}.filter-btn{font-size:12px;outline:none;padding:6px 12px;transition:all .2s ease}.filter-btn.primary{background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);color:#fff}.filter-btn.primary:hover{box-shadow:0 4px 8px #1f7cf44d;transform:translateY(-1px)}.filter-btn.secondary{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);color:#a0a7b4;color:var(--text-secondary)}.filter-btn.secondary:hover{background:#3c414c;background:var(--border-color);color:#f7f8fa;color:var(--text-primary)}.active-filters-section{border-top:1px solid #3c414c;border-top:1px solid var(--border-color);padding-top:12px}.active-filters-list{background:#2a2f38;background:var(--bg-card);border:1px solid var(--border-color);max-height:120px;min-height:40px;padding:8px}.no-filters-message{color:#6b7280;color:var(--text-muted);font-size:11px;padding:12px}.filter-chip{align-items:center;background:#1f7cf4;background:var(--primary-blue);border-radius:16px;color:#fff;display:inline-flex;font-size:12px;gap:6px;margin:2px;padding:4px 8px}.filter-chip .remove-filter{align-items:center;background:none;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:10px;height:16px;justify-content:center;padding:2px;width:16px}.filter-chip .remove-filter:hover{background:#fff3}.filter-minimized-icon{align-items:center;background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;box-shadow:0 2px 8px #00000026;color:#e0e0e0;cursor:pointer;display:none;height:36px;justify-content:center;opacity:.85;position:fixed!important;right:12px!important;top:379px!important;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:36px;z-index:1000!important}.filter-minimized-icon:hover{background:#404040;border-color:#fff;color:#fff;opacity:1;transform:translateY(-1px)}#filter-minimized-icon.filter-active,.filter-minimized-icon.filter-active{background:#1e90ff26!important;border-color:#1e90ffcc!important;box-shadow:0 0 8px #1e90ff66!important;color:#1e90ff!important;opacity:1!important}#filter-minimized-icon.filter-active:hover,.filter-minimized-icon.filter-active:hover{background:#1e90ff40!important;border-color:#1e90ff!important;box-shadow:0 0 12px #1e90ff99!important;color:#4da6ff!important;transform:translateY(-1px)!important}.filter-minimized-icon svg{stroke:currentColor;flex-shrink:0;height:18px;position:relative;width:18px;z-index:1}.attribute-minimized-icon{background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;box-shadow:0 2px 8px #00000026;color:#e0e0e0;height:36px;justify-content:center;opacity:.85;right:12px;top:415px!important;-webkit-user-select:none;user-select:none;width:36px;z-index:1000}.attribute-minimized-icon:hover{background:#404040;border-color:#fff;color:#fff;opacity:1;transform:translateY(-1px)}.attribute-minimized-icon:not(.hidden),body.logged-in .filter-minimized-icon:not(.hidden),body:not(.login-page) .filter-minimized-icon:not(.hidden){display:flex!important}.attribute-minimized-icon svg{stroke:currentColor;flex-shrink:0;height:18px;position:relative;width:18px;z-index:1}.create-layer-minimized-icon{background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;box-shadow:0 2px 8px #00000026;height:36px;opacity:.85;right:12px;top:307.59055px;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:36px;z-index:1000}.create-layer-minimized-icon:hover{background:#3b82f6;border-color:#fff;box-shadow:0 4px 12px #3b82f64d;color:#fff;opacity:1;transform:translateY(-1px)}.create-layer-minimized-icon:not(.hidden){display:flex!important}.create-layer-minimized-icon svg{stroke:currentColor;flex-shrink:0;height:18px;position:relative;width:18px;z-index:1}.create-layer-minimized-icon.active-marking{animation:pulse-marking 2s infinite;background:#3b82f6;border-color:#1d4ed8}.create-layer-minimized-icon.active-marking:hover{background:#2563eb}@keyframes pulse-marking{0%,to{box-shadow:0 2px 8px #3b82f64d}50%{box-shadow:0 4px 16px #3b82f699}}.compact-create-panel{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#242730d9;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:6px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);color:#a0a7b4;color:var(--text-secondary);display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:11px;max-height:88vh;overflow:hidden;position:fixed;right:16px;top:80px;width:320px;z-index:1002}.compact-create-panel.hidden{display:none!important}.panel-header{align-items:center;background:#242730;background:var(--bg-panel);border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);color:#f7f8fa;color:var(--text-primary);cursor:move;display:flex;justify-content:space-between;min-height:44px;padding:8px 12px;-webkit-user-select:none;user-select:none}.header-left{gap:8px}.layer-icon{align-items:center;background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);border-radius:4px;color:#f7f8fa;color:var(--text-primary);display:flex;flex-shrink:0;height:24px;justify-content:center;width:24px}.header-text{flex-direction:column;gap:1px;min-width:0}.panel-title-main{color:#f7f8fa;color:var(--text-primary);font-size:12px;font-weight:600;line-height:1.2}.panel-subtitle{color:#a0a7b4;color:var(--text-secondary);font-size:10px;font-weight:400;line-height:1.2}.header-actions{align-items:center;gap:4px}.kepler-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;height:20px;justify-content:center;padding:0;transition:all .2s ease;width:20px}.kepler-btn:hover{background:#2a2f38;background:var(--bg-card);color:#f7f8fa;color:var(--text-primary)}.kepler-btn:active{background:#1a1e26d3;background:var(--bg-input)}.point-count-badge{background:#18d0cd33;border:1px solid #18d0cd;border:1px solid var(--accent-teal);border-radius:12px;color:#18d0cd;color:var(--accent-teal);font-size:11px;font-weight:600;padding:4px 8px}.panel-controls{display:flex;gap:6px}.panel-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#f7f8fa;color:var(--text-primary);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .2s ease;width:28px}.panel-btn:hover{background:#fff3;border-color:#18d0cd;border-color:var(--accent-teal);box-shadow:0 2px 8px #18d0cd4d;transform:scale(1.05)}.panel-body{background:#242730d9;flex:1 1;overflow-y:auto;padding:0}.panel-section{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color)}.panel-section:last-child{border-bottom:none}.section-toggle{align-items:center;background:#242730;background:var(--bg-panel);color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;font-size:11px;font-weight:500;justify-content:space-between;min-height:32px;padding:8px 12px;transition:background .2s ease}.section-toggle.active,.section-toggle:hover{background:#2a2f38;background:var(--bg-card)}.section-toggle.active{color:#f7f8fa;color:var(--text-primary)}.section-toggle.collapsed{color:#6b7280;color:var(--text-muted)}.section-toggle span{align-items:center;display:flex;font-size:12px;gap:6px}.toggle-icon{transition:transform .2s ease}.section-toggle.collapsed .toggle-icon{transform:rotate(-90deg)}.section-content{background:#242730d9;max-height:500px;overflow:hidden;padding:12px;transition:all .25s cubic-bezier(.4,0,.2,1)}.section-content.collapsed{max-height:0;padding:0 12px}.compact-input{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#f7f8fa;color:var(--text-primary);font-family:inherit;font-size:11px;padding:6px 10px;transition:all .2s ease;width:100%}.compact-input:focus{background:#2a2f38;background:var(--bg-card);border-color:#1f7cf4;border-color:var(--primary-blue);box-shadow:0 0 0 2px #1f7cf433;outline:none}.compact-btn{align-items:center;background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:2px;color:#f7f8fa;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:11px;font-weight:500;justify-content:center;min-height:26px;padding:6px 10px;text-align:center;transition:all .2s ease}.compact-btn.primary{background:#1f7cf4;background:var(--primary-blue);border-color:#1f7cf4;border-color:var(--primary-blue);color:var(--text-dark);font-weight:600}.compact-btn.primary:hover{background:#0d47a1;background:var(--primary-blue-hover);border-color:#0d47a1;border-color:var(--primary-blue-hover)}.compact-btn.primary:disabled{background:#a0a7b4;background:var(--text-secondary);border-color:#a0a7b4;border-color:var(--text-secondary);color:#6b7280;color:var(--text-muted);cursor:not-allowed;opacity:.6}.compact-btn.secondary{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);color:#a0a7b4;color:var(--text-secondary)}.compact-btn.secondary:hover{background:#2a2f38;background:var(--bg-card);border-color:#1f7cf4;border-color:var(--primary-blue);color:#f7f8fa;color:var(--text-primary)}.compact-btn.secondary:disabled{background:#242730;background:var(--bg-panel);color:#6b7280;color:var(--text-muted);cursor:not-allowed;opacity:.6}.compact-btn.full-width{width:100%}.marking-controls{display:flex;flex-direction:column;gap:6px}.controls-row{display:flex;gap:4px}.controls-row .compact-btn{flex:1 1;font-size:10px;padding:5px 8px}.status-row{align-items:center;display:flex;font-size:10px;justify-content:space-between;margin-top:2px}.status-text{color:#1f7cf4;color:var(--primary-blue);font-weight:600}.marking-status{color:#6b7280;color:var(--text-muted);font-size:10px;font-style:italic}.marking-status.active{color:#10b981;color:var(--success);font-weight:500}.compact-table-container{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;max-height:180px;overflow:auto}.compact-table{border-collapse:collapse;color:#f7f8fa;color:var(--text-primary);font-size:11px;width:100%}.compact-table th{background:#2a2f38;background:var(--bg-card);font-weight:600;padding:8px 10px;position:-webkit-sticky;position:sticky;text-align:left;top:0}.compact-table td,.compact-table th{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);color:#f7f8fa;color:var(--text-primary)}.compact-table td{padding:6px 10px}.compact-table tr:hover{background:#2a2f38;background:var(--bg-card)}.compact-table tr.selected{background:#1f7cf433;border-left:3px solid #1f7cf4;border-left:3px solid var(--primary-blue)}.compact-table .empty-row td{color:#a0a7b4;color:var(--text-secondary);font-style:italic;padding:20px 10px;text-align:center}.panel-footer{background:#1a1e26d3;background:var(--bg-input);border-top:1px solid #3c414c;border-top:1px solid var(--border-color);display:flex;flex-shrink:0;gap:6px;padding:8px 12px}.panel-footer .compact-btn{flex:1 1;font-size:11px;font-weight:600}.table-header{background:#f5f5f5!important;border-bottom:2px solid #e0e0e0!important;color:#333!important;cursor:pointer;font-weight:600;height:26px!important;padding:3px 6px!important;position:-webkit-sticky!important;position:sticky!important;top:0!important;transition:background-color .2s ease;-webkit-user-select:none;user-select:none;z-index:100!important}.table-header:hover{background:#eee!important}.column-name{font-size:11px;letter-spacing:.3px;line-height:1;text-transform:uppercase}.sort-icon{color:#1f7cf4;color:var(--primary-blue);font-size:10px;margin-left:2px;min-width:10px}.table-row{background:#fff!important;cursor:pointer;height:24px!important;position:relative!important;transition:background-color .15s ease;z-index:1!important}.table-row:nth-child(2n){background:#f8f9fa!important}.table-row:hover{background:#e3f2fd!important}.table-row.selected{background:#1976d226!important}.table-row.selected:hover{background:#1976d240!important}.table-row.selected:nth-child(2n){background:#1976d226!important}.table-cell{border:1px solid #e0e0e0!important;border-left:none!important;border-right:none!important;color:#333!important;font-size:11px;height:24px!important;line-height:20px!important;padding:2px 6px!important;transition:background-color .15s ease}.header-content{height:100%;justify-content:flex-start;padding:2px 4px;width:100%}.header-left{height:100%}.header-text{flex:1 1;gap:2px}.column-menu-btn{align-items:center;background:#0000;border:none;border-radius:3px;color:#9ca3af;cursor:pointer;display:flex;height:18px;justify-content:center;opacity:.7;padding:2px;transition:all .2s ease;width:18px}.column-menu-btn:hover{background:#9ca3af1a;color:#6b7280;opacity:1;transform:scale(1.1)}.column-menu-btn:active{color:#4b5563;transform:scale(.95)}.column-menu-btn.menu-active{background:#1f7cf41a;box-shadow:0 1px 4px #1f7cf433;color:#1f7cf4;color:var(--primary-blue);opacity:1;transform:scale(1.05)}.table-header.pinned{background:#1f7cf414!important;border-right:2px solid #1f7cf4!important;border-right:2px solid var(--primary-blue)!important;transition:none!important;will-change:transform;z-index:150!important}.table-header.pinned,td.pinned-column{left:0!important;position:-webkit-sticky!important;position:sticky!important}td.pinned-column{background:#1f7cf408!important;border-right:2px solid #1f7cf44d!important;z-index:5!important}.table-header.sorted{background:#1f7cf40d!important;transition:background-color .15s ease}.table-header.sorted .sort-icon{animation:sortIndicatorPulse .3s ease;color:#1f7cf4;color:var(--primary-blue);font-weight:700;margin-left:6px}@keyframes sortIndicatorPulse{0%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.pin-icon{margin-right:2px;opacity:.8}.column-menu-dropdown{animation:menuSlideIn .15s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;border:1px solid #0000001a;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:45px;padding:3px}@keyframes menuSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-item{border-radius:8px;color:#f7f8fa;color:var(--text-primary);font-size:14px;gap:12px;padding:10px 14px;transition:all .2s ease}.menu-item,.menu-item.compact{align-items:center;cursor:pointer;display:flex;position:relative}.menu-item.compact{border-radius:4px;color:#374151;font-size:16px;gap:4px;justify-content:center;min-height:24px;min-width:32px;padding:8px 6px;transition:all .15s ease}.menu-item.compact .menu-icon{font-size:14px}.menu-item.compact .check{color:#1f7cf4;color:var(--primary-blue);font-size:10px;position:absolute;right:2px;top:2px}.menu-item:hover{background:#1f7cf41f;color:#1f7cf4;color:var(--primary-blue);transform:translateX(1px);transition:all .15s cubic-bezier(.4,0,.2,1)}.menu-item.compact:hover{background:#1f7cf41a;transform:scale(1.1);transition:all .15s ease}.menu-item.active{background:#1f7cf414;color:#1f7cf4;color:var(--primary-blue);font-weight:500}.menu-item.active:before{animation:activeIndicator .2s ease-out;background:#1f7cf4;background:var(--primary-blue);border-radius:2px;content:"";height:70%;left:3px;position:absolute;top:50%;transform:translateY(-50%);width:3px}@keyframes activeIndicator{0%{opacity:0;width:0}to{opacity:1;width:3px}}.menu-item svg{color:currentColor;flex-shrink:0}.menu-item span{flex:1 1}.pin-indicator,.sort-indicator{font-size:12px;margin-left:auto;opacity:.8}.menu-divider{background:#3c414c;background:var(--border-color);height:1px;margin:4px 0}.attribute-panel{max-width:95vw;min-height:200px;min-width:400px;resize:both}.attribute-panel-header{cursor:move;-webkit-user-select:none;user-select:none}.table-row.filtered-highlight{background-color:#3498db1a!important;border-left:3px solid #3498db}.table-row.filtered-highlight:hover{background-color:#3498db33!important}.filter-section{background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:6px;margin-bottom:16px;overflow:hidden}.filter-section-header{align-items:center;background:#1f7cf41a;border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:8px 12px}.section-title{color:#f7f8fa;color:var(--text-primary);font-size:12px;font-weight:600;letter-spacing:.5px}.clear-section-btn{background:none;border:none;border-radius:3px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;font-size:11px;padding:2px 6px;transition:all .2s ease}.clear-section-btn:hover{background:#1a1e26d3;background:var(--bg-input);color:#f7f8fa;color:var(--text-primary)}.filter-group{background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:6px;margin-bottom:12px;transition:all .2s ease}.filter-group.enabled{border-color:#1f7cf44d;box-shadow:0 2px 4px #1f7cf41a}.filter-group.disabled{border-color:#6b7280;border-color:var(--text-muted);opacity:.6}.filter-group-header{align-items:center;background:#1f7cf414;border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:10px 12px}.group-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.group-name-input{background:#0000;border:none;border-radius:3px;color:#f7f8fa;color:var(--text-primary);font-size:13px;font-weight:600;padding:2px 4px;transition:background .2s ease}.group-name-input:focus,.group-name-input:hover{background:#1a1e26d3;background:var(--bg-input)}.group-name-input:focus{border:1px solid #1f7cf4;border:1px solid var(--primary-blue);outline:none}.layer-name{color:#a0a7b4;color:var(--text-secondary);font-size:11px;letter-spacing:.3px;text-transform:uppercase}.group-controls{align-items:center;display:flex;gap:8px}.logic-toggle{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;font-size:10px;font-weight:600;min-width:32px;padding:4px 8px;text-transform:uppercase;transition:all .2s ease}.logic-toggle.and{background:#10b9811a;border-color:#10b981;border-color:var(--success);color:#10b981;color:var(--success)}.logic-toggle.or{background:#f59e0b1a;border-color:#f59e0b;border-color:var(--warning);color:#f59e0b;color:var(--warning)}.logic-toggle:hover{box-shadow:0 2px 4px #0003;transform:translateY(-1px)}.toggle-switch{height:18px;width:34px}.slider{background-color:#6b7280;background-color:var(--text-muted);border-radius:18px}.slider:before{border-radius:50%;bottom:2px;height:14px;left:2px;width:14px}input:checked+.slider{background-color:#1f7cf4;background-color:var(--primary-blue)}input:checked+.slider:before{transform:translateX(16px)}.remove-group-btn{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;color:var(--text-muted);cursor:pointer;display:flex;font-size:16px;height:20px;justify-content:center;transition:all .2s ease;width:20px}.remove-group-btn:hover{background:#ef44441a;color:#ef4444;color:var(--error)}.filter-conditions{padding:8px 12px}.filter-condition{align-items:center;background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;display:flex;gap:8px;margin-bottom:6px;padding:6px 8px;transition:all .2s ease}.filter-condition:hover{background:#1f7cf40d;border-color:#1f7cf4;border-color:var(--primary-blue)}.condition-field{color:#f7f8fa;color:var(--text-primary);font-size:12px;font-weight:500}.condition-operator{background:#2a2f38;background:var(--bg-card);border-radius:3px;color:#a0a7b4;color:var(--text-secondary);font-size:11px;padding:2px 6px;text-transform:lowercase}.condition-value{color:#18d0cd;color:var(--accent-teal);flex:1 1;font-size:12px;text-align:right}.remove-condition-btn{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;color:var(--text-muted);cursor:pointer;display:flex;font-size:14px;height:18px;justify-content:center;transition:all .2s ease;width:18px}.remove-condition-btn:hover{background:#ef44441a;color:#ef4444;color:var(--error)}.add-condition{margin-top:8px}.add-condition-btn{background:none;border:1px dashed #3c414c;border:1px dashed var(--border-color);border-radius:4px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;font-size:12px;padding:8px;transition:all .2s ease;width:100%}.add-condition-btn:hover{background:#1f7cf40d;border-color:#1f7cf4;border-color:var(--primary-blue);color:#1f7cf4;color:var(--primary-blue)}.add-filter-group-btn{margin-top:16px}.create-group-btn{align-items:center;background:#1f7cf41a;border:1px solid #1f7cf4;border:1px solid var(--primary-blue);border-radius:6px;color:#1f7cf4;color:var(--primary-blue);cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:6px;justify-content:center;padding:10px;transition:all .2s ease;width:100%}.create-group-btn:hover{background:#1f7cf433;box-shadow:0 4px 8px #1f7cf433;transform:translateY(-1px)}.create-group-btn .icon{font-size:16px;font-weight:700}.modal-content{background:#242730;background:var(--bg-panel);border:1px solid #3c414c;border:1px solid var(--border-color);box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);max-width:90vw;min-width:320px;padding:20px}.modal-content h3{color:#f7f8fa;color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 16px}.form-group{margin-bottom:12px}.form-group label{color:var(--text-secondary);font-size:12px;margin-bottom:4px}.form-control{font-size:13px;transition:all .2s ease}.form-control:focus{box-shadow:0 0 0 2px #1f7cf433}.modal-actions{gap:8px;margin-top:20px}.btn-primary{background:linear-gradient(135deg,#1f7cf4,#5b2c87);background:var(--gradient-primary);border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;padding:8px 16px;transition:all .2s ease}.btn-primary:hover{box-shadow:0 4px 8px #1f7cf44d;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;padding:8px 16px;transition:all .2s ease}.btn-success:hover{box-shadow:0 4px 8px #10b9814d;transform:translateY(-1px)}.btn-secondary{background:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:12px;font-weight:500;padding:8px 16px;transition:all .2s ease}.btn-secondary:hover{background:#1a1e26d3;background:var(--bg-input);color:#f7f8fa;color:var(--text-primary)}.hidden{display:none!important}.filter-item.legacy{align-items:center;background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;display:flex;justify-content:space-between;margin-bottom:4px;padding:6px 8px}.filter-content{display:flex;flex:1 1;flex-direction:column;gap:2px}.filter-content .layer-name{color:#a0a7b4;color:var(--text-secondary);font-size:10px;letter-spacing:.3px;text-transform:uppercase}.filter-details{color:#f7f8fa;color:var(--text-primary);font-size:11px}.remove-filter-btn{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;color:var(--text-muted);cursor:pointer;display:flex;font-size:14px;height:18px;justify-content:center;transition:all .2s ease;width:18px}.remove-filter-btn:hover{background:#ef44441a;color:#ef4444;color:var(--error)}.kepler-legend-item{background:#ffffff08;border:1px solid #ffffff14;border-radius:6px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin-bottom:6px;padding:8px 10px;transition:all .3s ease}.kepler-legend-item:hover{background:#ffffff0f;border-color:#1f7cf4;border-color:var(--primary-blue);box-shadow:0 2px 8px #1f7cf41a}.kepler-legend-item:last-child{margin-bottom:0}.kepler-legend-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.kepler-legend-title{color:#f7f8fa;color:var(--text-primary);font-size:12px;font-weight:600;letter-spacing:-.01em;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kepler-legend-type{background:#18d0cd1a;border:1px solid #18d0cd33;border-radius:3px;color:#a0a7b4;color:var(--text-secondary);flex-shrink:0;font-size:9px;font-weight:600;letter-spacing:.3px;padding:2px 6px;text-transform:uppercase}.kepler-color-scale{display:flex;flex-direction:column;gap:4px}.kepler-gradient-bar{border:1px solid #ffffff1a;border-radius:6px;box-shadow:inset 0 1px 2px #0003;height:12px}.kepler-scale-labels{color:#a0a7b4;color:var(--text-secondary);display:flex;font-size:10px;font-weight:500;justify-content:space-between}.kepler-scale-labels span{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:3px;padding:1px 4px}.kepler-categorical-scale{display:flex;flex-direction:column;gap:3px}.kepler-category-item{align-items:center;display:flex;font-size:11px;gap:6px;min-height:20px}.kepler-category-color{border:1px solid #ffffff1a;border-radius:2px;flex-shrink:0;height:12px;width:12px}.kepler-category-label{color:#f7f8fa;color:var(--text-primary);flex:1 1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kepler-category-more{background:#1a1e26d3;background:var(--bg-input);border-radius:3px;color:#6b7280;color:var(--text-muted);font-size:10px;font-style:italic;margin-top:2px;padding:2px 6px;text-align:center}.kepler-solid-color{align-items:center;display:flex;justify-content:center;padding:6px 0}.kepler-color-swatch{border:1px solid #ffffff1a;border-radius:6px;box-shadow:0 1px 2px #0003;height:12px;width:24px}.legend-content{max-height:calc(70vh - 80px);overflow-y:auto;padding:16px}.legend-content::-webkit-scrollbar{width:6px}.legend-content::-webkit-scrollbar-track{background:#1a1e26d3;background:var(--bg-input);border-radius:3px}.legend-content::-webkit-scrollbar-thumb{background:#3c414c;background:var(--border-color);border-radius:3px}.legend-content::-webkit-scrollbar-thumb:hover{background:#6b7280;background:var(--text-muted)}.legend-item{isolation:isolate;position:relative}.legend-item *{pointer-events:none}.legend-item .legend-toggle-btn,.legend-item button,.legend-item input,.legend-item select{pointer-events:auto;position:relative;z-index:1}.kepler-legend-item{isolation:isolate;position:relative}.kepler-legend-item *{pointer-events:none}.kepler-legend-item button,.kepler-legend-item input{pointer-events:auto;position:relative;z-index:1}.legend-content{position:relative}.legend-panel:hover .legend-item:not(:hover){transition:none}#custom-compass{cursor:pointer;height:63.21px;position:fixed;right:1.55905px;top:77.30708px;transition:transform .2s ease;width:63.21px;z-index:950}#custom-compass:hover{transform:scale(1.05)}#custom-compass:active{transform:scale(.98)}#custom-compass svg{border-radius:50%;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));height:100%;width:100%}#custom-compass .compass-needle{transform-origin:18px 18px;transition:transform .15s cubic-bezier(.25,.46,.45,.94);will-change:transform}@media (max-width:768px){#custom-compass{height:52.67px;right:5.55905px;top:67.30708px;width:52.67px}}@media (max-width:1200px){.legend-panel{max-width:calc(100vw - 60px);width:280px}}@media (max-width:768px){.legend-panel{left:16px;max-height:calc(100vh - 170px);max-width:300px;right:16px;top:110px;width:calc(100vw - 32px)}.legend-content{max-height:calc(100vh - 250px);padding:8px 10px}.legend-minimized-icon{bottom:160px;height:36px;right:16px;width:36px}.legend-minimized-icon svg{height:16px;width:16px}}@media (max-width:480px){.legend-panel{left:12px;max-height:calc(100vh - 160px);right:12px;top:100px;width:calc(100vw - 24px)}.kepler-legend-item{margin-bottom:4px;padding:6px 8px}.kepler-legend-title{font-size:11px;max-width:140px}.legend-minimized-icon{bottom:140px;height:36px;right:12px;width:36px}}@media (min-width:769px){.legend-panel{max-width:calc(100vw - 380px);right:max(16px,calc(2vw - 6.4px))}#panel.hide~.legend-panel{max-width:calc(100vw - 100px)}}.legend-panel{bottom:max(80px,10vh)}.legend-minimized-icon{z-index:999}.legend-empty-state{align-items:center;color:#6b7280;color:var(--text-muted);display:flex;flex-direction:column;justify-content:center;min-height:120px;padding:20px;text-align:center}.legend-empty-state svg{height:32px;margin-bottom:8px;opacity:.5;width:32px}.legend-empty-state p{font-size:12px;line-height:1.4;margin:0}.legend-empty-state .empty-subtitle{font-size:11px;margin-top:4px;opacity:.8}.data-source-tab{color:var(--text-secondary)}.data-source-tab.active{background:#1f7cf40d;border-bottom-color:var(--primary-blue);color:var(--primary-blue)}.data-source-tab:hover:not(.active){background:#ffffff05;color:#f7f8fa;color:var(--text-primary)}.file-drop-zone{border:2px dashed var(--border-color)}.file-drop-zone.drag-over,.file-drop-zone:hover{border-color:var(--primary-blue)}.drop-zone-content h4{color:var(--text-primary);font-size:18px}.drop-zone-content p{color:var(--text-secondary)}.supported-formats{background:#ffffff08;padding:12px 16px}.supported-formats strong{color:var(--text-primary);font-size:12px}.format-list{color:#a0a7b4;color:var(--text-secondary);font-size:12px;margin-left:8px}.server-data-list{background:#ffffff03;max-height:200px}.server-data-item{cursor:pointer;padding:12px 16px;transition:background .2s ease}.server-data-item:hover{background:#1f7cf40d}.server-data-item.selected{background:#1f7cf41a}.server-data-name{font-weight:500}.loading-state{font-size:14px}.upload-type-options{display:flex;flex-direction:column;gap:12px}.radio-option{background:#ffffff03;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;padding:16px;transition:all .2s ease}.radio-option:hover{background:#1f7cf405;border-color:#1f7cf4;border-color:var(--primary-blue)}.radio-option input[type=radio]{align-self:flex-start;margin:0 8px 8px 0}.radio-option span{color:#f7f8fa;color:var(--text-primary);font-weight:500;margin-bottom:4px}.radio-option small{color:#a0a7b4;color:var(--text-secondary);font-size:12px;line-height:1.4}.upload-section{animation:fadeIn .3s ease;display:none}.upload-section.active{display:block}.form-control{background:#1a1e26d3;background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary);transition:border-color .2s ease}.form-control:focus{border-color:var(--primary-blue);box-shadow:0 0 0 2px #1f7cf41a}.form-control::placeholder{color:var(--text-muted)}.form-control option,select option{background:#242730;background:var(--bg-panel);color:#f7f8fa;color:var(--text-primary)}select option{padding:8px}select option:hover{background:#2a2f38;background:var(--bg-card)}select option:checked,select option:focus{background:#1f7cf4;background:var(--primary-blue);color:#fff}textarea.form-control{line-height:1.4;min-height:80px;resize:vertical}.divider{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);margin:20px 0}.btn:disabled{background:#1a1e26d3!important;background:var(--bg-input)!important;color:#6b7280!important;color:var(--text-muted)!important}.btn:not(:disabled):hover{transform:translateY(-1px)}.loading-spinner{animation:spin 1s ease-in-out infinite;border:2px solid #3c414c;border-radius:50%;border-top-color:#1f7cf4;border:2px solid var(--border-color);border-top-color:var(--primary-blue);display:inline-block;height:16px;margin-right:8px;width:16px}.create-layer-section{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);margin-bottom:24px;padding-bottom:20px}.create-layer-section:last-child{border-bottom:none}.create-layer-section h4{color:#f7f8fa;color:var(--text-primary);font-size:16px;font-weight:600}.csv-import-section{transition:all .2s ease}.csv-import-section:hover{background:#ffffff0a!important}#custom-columns-list{border-radius:4px;display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto;padding:4px}#custom-columns-list::-webkit-scrollbar{width:6px}#custom-columns-list::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}#custom-columns-list::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}#custom-columns-list::-webkit-scrollbar-thumb:hover{background:#ffffff80}.custom-column-item{align-items:center;background:#ffffff05;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:6px;display:flex;gap:12px;padding:12px;transition:all .2s ease}.custom-column-item:hover{background:#ffffff0a}.custom-column-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.custom-column-name{color:#f7f8fa;color:var(--text-primary);font-size:14px;font-weight:500}.custom-column-type{color:#a0a7b4;color:var(--text-secondary);font-size:12px}.custom-column-actions{display:flex;gap:4px}.custom-column-btn{border-radius:4px;font-size:11px;height:auto;min-width:auto;padding:4px 8px}.point-marking-info{transition:all .2s ease}#point-count-display{background:#ffffff0d;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;font-weight:500;padding:6px 12px}.create-layer-table-container{background:#1f2329;border:1px solid #3a414b;border-radius:2px;max-height:200px;overflow:hidden;overflow-y:auto}#create-layer-table{border-collapse:collapse;font-size:10px;width:100%}#create-layer-table th{background:#242730;color:#a0a7b4;font-weight:600;padding:6px 8px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:1}#create-layer-table td,#create-layer-table th{border-bottom:1px solid #3a414b;font-size:10px}#create-layer-table td{color:#fff;padding:4px 8px}#create-layer-table tbody tr:hover{background:#5cc6ff14}#create-layer-table tbody tr.selected{background:#5cc6ff26}.editable-cell{border-radius:3px;cursor:text;min-height:18px;padding:2px 6px;transition:all .2s ease}.editable-cell:hover{background:#ffffff0d}.editable-cell.edit-mode-active{background:#1f7cf40d;border:1px solid #1f7cf433;cursor:pointer}.editable-cell.edit-mode-active:hover{background:#1f7cf41a;border-color:#1f7cf466}.editable-cell.editing{background:#1a1e26d3;background:var(--bg-input);outline:1px solid #1f7cf4;outline:1px solid var(--primary-blue)}.editable-input{background:#0000;border:none;color:#f7f8fa;color:var(--text-primary);font-size:12px;outline:none;padding:0;width:100%}.map-point-marking,.map-point-marking *{cursor:crosshair!important}.point-marking-active{animation:slideInRight .3s ease;background:#1f7cf4e6;border-radius:6px;box-shadow:0 10px 15px -3px #0006,0 4px 6px -2px #0000004d;box-shadow:var(--shadow-lg);color:#fff;font-size:12px;font-weight:600;padding:8px 16px;position:fixed;right:20px;top:80px;z-index:1000}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.create-layer-table-container table tbody tr{cursor:pointer}.create-layer-table-container table tbody tr:nth-child(2n){background:#ffffff03}.column-type-indicator{border-radius:3px;display:inline-block;font-size:10px;font-weight:600;padding:2px 6px;text-transform:uppercase}.column-type-string{background:#3b82f633;color:#60a5fa}.column-type-number{background:#10b98133;color:#34d399}.column-type-boolean{background:#f59e0b33;color:#fbbf24}.column-type-date{background:#a855f733;color:#c084fc}.compact-create-panel .csv-import-section{background:#1f2329;border:1px solid #3a414b;border-radius:2px;margin-bottom:12px;padding:10px}.compact-create-panel .csv-label{color:#6a7485;display:block;font-size:10px;font-weight:500;letter-spacing:.2px;margin-bottom:6px;text-transform:uppercase}.compact-create-panel .csv-file-input{background:#242730;border:1px solid #3a414b;border-radius:2px;color:#fff;cursor:pointer;font-size:10px;margin-bottom:6px;padding:6px;width:100%}.compact-create-panel .csv-file-input::-webkit-file-upload-button{background:#5cc6ff;border:none;border-radius:2px;color:#0f1419;cursor:pointer;font-size:10px;font-weight:600;letter-spacing:.2px;margin-right:6px;padding:4px 8px;text-transform:uppercase}.compact-create-panel .csv-file-input::-webkit-file-upload-button:hover{background:#73d1ff}.compact-create-panel .divider{border-bottom:1px solid #3a414b;margin:12px 0}.compact-create-panel .layer-import-section{background:#1f2329;border:1px solid #3a414b;border-radius:2px;margin-bottom:12px;padding:10px}.compact-create-panel .layer-select{background:#242730;border:1px solid #3a414b;border-radius:2px;color:#fff;cursor:pointer;font-size:10px;margin-bottom:6px;max-height:120px;overflow-y:auto;padding:6px;width:100%}.compact-create-panel .layer-select:focus{border-color:#5cc6ff;box-shadow:0 0 0 1px #5cc6ff;outline:none}.compact-create-panel .layer-select option{background:#242730;border-bottom:1px solid #3a414b;color:#fff;padding:8px}.compact-create-panel .layer-select option:hover{background:#2a2f38}.compact-create-panel .layer-select option:checked{background:#5cc6ff;color:#0f1419}.tab-content{min-height:400px;text-align:center}.tab-content:not(.active){display:none}.tab-content .file-drop-zone,.tab-content .remote-data-section,.tab-content .server-data-section{align-items:center;display:flex;flex-direction:column;justify-content:flex-start;min-height:360px;padding:20px;text-align:center}.tab-content h4{color:#f7f8fa;color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 16px}.tab-content svg{color:#a0a7b4;color:var(--text-secondary);margin-bottom:16px}.tab-content .btn,.tab-content .form-control{max-width:400px;width:100%}.tab-content .btn{margin-top:8px}.server-selector-section{max-width:450px;width:100%}.server-selector-section label{text-align:left}.server-layer-selector{background:#ffffff05;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;padding:16px}.server-layers-list{width:100%}.server-data-list{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;max-height:280px;width:100%}.server-data-list:empty{align-items:center;display:flex;justify-content:center;min-height:120px}.server-data-item{align-items:center;border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px;transition:background-color .2s ease}.server-data-item:hover{background:#ffffff0d}.server-data-item:last-child{border-bottom:none}.server-data-info{flex:1 1;text-align:left}.server-data-name{color:#f7f8fa;color:var(--text-primary);font-size:14px;font-weight:600;margin-bottom:4px}.server-data-meta{align-items:center;color:#a0a7b4;color:var(--text-secondary);display:flex;font-size:12px;gap:8px}.server-data-item .btn{margin-left:12px;min-width:80px}.loading-state{color:#a0a7b4;color:var(--text-secondary);font-style:italic;padding:20px;text-align:center}.close-btn{background:#ffffff1a;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:6px;min-height:32px;min-width:32px;padding:8px!important;transition:all .2s ease}.close-btn:hover{background:#ffffff26;border-color:#a0a7b4;border-color:var(--text-secondary);transform:scale(1.05)}.close-btn svg{transition:transform .2s ease}.close-btn:hover svg{transform:rotate(90deg)}.create-layer-panel{background:#242730;background:var(--bg-panel);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0003;box-shadow:var(--shadow-xl);display:flex;flex-direction:column;font-family:var(--font-family);left:20px;max-height:calc(100vh - 120px);position:fixed;top:100px;width:380px;z-index:1000}.create-layer-panel .panel-header{align-items:center;background:var(--bg-secondary);border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);border-radius:8px 8px 0 0;cursor:move;display:flex;justify-content:space-between;min-height:60px;padding:12px 16px}.create-layer-panel .header-main{align-items:center;display:flex;flex:1 1;gap:12px}.create-layer-panel .header-icon{color:var(--primary-color);flex-shrink:0;opacity:.9}.create-layer-panel .header-info{flex:1 1;min-width:0}.create-layer-panel .panel-title{color:#f7f8fa;color:var(--text-primary);font-size:15px;font-weight:600;line-height:1.2;margin:0}.create-layer-panel .header-stats{align-items:center;display:flex;gap:12px;margin-top:4px}.create-layer-panel .layer-type{color:#a0a7b4;color:var(--text-secondary);font-size:12px}.create-layer-panel .point-count{color:var(--primary-color);font-size:12px;font-weight:600}.create-layer-panel .header-actions{display:flex;flex-shrink:0;gap:6px}.create-layer-panel .header-btn{align-items:center;background:#ffffff1a;border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#a0a7b4;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s ease}.create-layer-panel .header-btn:hover{background:#ffffff26;color:#f7f8fa;color:var(--text-primary)}.create-layer-panel .panel-body{flex:1 1;max-height:calc(100vh - 220px);overflow-y:auto;padding:20px}.create-layer-panel .form-section{margin-bottom:20px}.create-layer-panel .form-label{color:#f7f8fa;color:var(--text-primary);display:block;font-size:14px;font-weight:600;margin-bottom:8px}.create-layer-panel .control-group{display:flex;flex-direction:column;gap:12px}.create-layer-panel .button-group{display:flex;gap:8px}.create-layer-panel .status-info{align-items:center;background:var(--bg-secondary);border-radius:6px;color:#a0a7b4;color:var(--text-secondary);display:flex;font-size:12px;gap:8px;padding:8px 12px}.create-layer-panel .status-counter{color:var(--primary-color);font-weight:600}.create-layer-panel .status-separator{opacity:.5}.create-layer-panel .status-text{color:#a0a7b4;color:var(--text-secondary)}.create-layer-panel .collapsible-section{border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:6px;margin-bottom:16px;overflow:hidden}.create-layer-panel .collapsible-section.collapsed{border-color:rgba(var(--border-color-rgb),.3)}.create-layer-panel .section-header{align-items:center;background:var(--bg-secondary);border:none;cursor:pointer;display:flex;justify-content:space-between;padding:12px 16px;transition:background-color .2s ease;width:100%}.create-layer-panel .section-header:hover{background:#ffffff0d}.create-layer-panel .section-title{color:#f7f8fa;color:var(--text-primary);font-size:14px;font-weight:600}.create-layer-panel .section-description{color:#a0a7b4;color:var(--text-secondary);font-size:11px;margin-top:2px}.create-layer-panel .section-info{align-items:flex-start;display:flex;flex-direction:column}.create-layer-panel .toggle-icon{color:#a0a7b4;color:var(--text-secondary);transition:transform .2s ease}.create-layer-panel .collapsible-section.collapsed .toggle-icon{transform:rotate(-90deg)}.create-layer-panel .section-content{border-top:1px solid #3c414c;border-top:1px solid var(--border-color);padding:16px}.create-layer-panel .section-content.collapsed{display:none}.create-layer-panel .table-container{border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:6px;margin-bottom:12px;overflow:hidden}.create-layer-panel .data-table{border-collapse:collapse;font-size:12px;width:100%}.create-layer-panel .data-table td,.create-layer-panel .data-table th{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);padding:8px 12px;text-align:left}.create-layer-panel .data-table th{background:var(--bg-secondary);border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);color:#f7f8fa;color:var(--text-primary);font-weight:600}.create-layer-panel .data-table td{color:#a0a7b4;color:var(--text-secondary)}.create-layer-panel .data-table .empty-row td{color:#6b7280;color:var(--text-muted);font-style:italic;padding:20px;text-align:center}.create-layer-panel .table-actions{align-items:center;display:flex;justify-content:space-between}.create-layer-panel .hint-text{color:#a0a7b4;color:var(--text-secondary);font-size:11px}.create-layer-panel .form-group{margin-bottom:16px}.create-layer-panel .input-group{align-items:flex-end;display:flex;gap:8px}.create-layer-panel .input-group .form-control{flex:1 1}.create-layer-panel .file-input{font-size:12px}.create-layer-panel .full-width{width:100%}.create-layer-panel .custom-columns{margin-top:12px}.create-layer-panel .panel-footer{background:var(--bg-secondary);border-radius:0 0 8px 8px;border-top:1px solid #3c414c;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.create-layer-panel .advanced-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr}.create-layer-panel .subsection-title{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color);color:#f7f8fa;color:var(--text-primary);font-size:13px;font-weight:600;margin:0 0 12px;padding-bottom:6px}.create-layer-panel .import-section{display:flex;flex-direction:column;gap:12px}.create-layer-panel .import-option{display:flex;flex-direction:column;gap:6px}.create-layer-panel .option-label{color:#f7f8fa;color:var(--text-primary);font-size:12px;font-weight:500}.create-layer-panel .option-controls{align-items:flex-end;display:flex;gap:8px}.create-layer-panel .option-controls .form-control.compact{flex:1 1;font-size:12px;padding:6px 8px}.create-layer-panel .file-input{background:#242730;background:var(--bg-panel);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#f7f8fa;color:var(--text-primary);flex:1 1;font-size:11px;padding:6px 8px}.create-layer-panel .custom-section{display:flex;flex-direction:column;gap:12px}.create-layer-panel .custom-columns-list{margin-top:8px;min-height:20px}.create-layer-panel .btn-small{border-radius:4px;font-size:11px;padding:6px 12px;white-space:nowrap}.simple-draggable-panel{background:#242730;background:var(--bg-panel,#2d3748);border:1px solid var(--border-color,#4a5568);box-shadow:0 4px 20px #0000004d;color:var(--text-primary,#e2e8f0)}.simple-panel-header{background:#1a202c;background:var(--bg-header,#1a202c);border-bottom:1px solid var(--border-color,#4a5568)}.simple-panel-header span{color:var(--text-primary,#e2e8f0)}.simple-close-btn{color:#6b7280;color:var(--text-muted,#a0aec0)}.simple-close-btn:hover{background:#ffffff1a;background:var(--bg-hover,#ffffff1a);color:var(--text-primary,#e2e8f0)}.simple-panel-body{background:#242730;background:var(--bg-panel,#2d3748)}.simple-section label{color:var(--text-secondary,#a0aec0)}.simple-section input[type=text]{background:#1a1e26d3;background:var(--bg-input,#1a202c);border:1px solid var(--border-color,#4a5568);color:var(--text-primary,#e2e8f0)}.simple-section input[type=text]:focus{border-color:var(--primary-blue,#1f7cf4);box-shadow:0 0 0 2px #1f7cf433}.simple-section input[type=text]::placeholder{color:var(--text-muted,#718096)}.simple-btn{background:#2a2f38;background:var(--bg-card,#1a202c);border:1px solid var(--border-color,#4a5568);border-radius:4px;color:#f7f8fa;color:var(--text-primary,#e2e8f0)}.simple-btn:hover:not(:disabled){background:#2d3748;background:var(--bg-hover,#2d3748)}.simple-btn.primary,.simple-btn:hover:not(:disabled){border-color:#1f7cf4;border-color:var(--primary-blue,#1f7cf4)}.simple-btn.primary{background:#1f7cf4;background:var(--primary-blue,#1f7cf4)}.simple-btn.primary:hover:not(:disabled){background:#1e40af;border-color:#1e40af;box-shadow:0 2px 8px #1f7cf44d}.resize-handle{background:#0000}.resize-handle-e{cursor:e-resize;height:100%;right:-2px;top:0;width:4px}.resize-handle-s{bottom:-2px;cursor:s-resize;height:4px;left:0;width:100%}.resize-handle-se{bottom:-2px;cursor:se-resize;height:8px;right:-2px;width:8px}.resize-handle:hover{background:#1f7cf44d}.simple-draggable-panel{position:relative;resize:none}.simple-status{color:#6b7280;color:var(--text-muted,#718096);font-size:9px}.simple-table-container{background:#1a1e26d3;background:var(--bg-input,#1a202c);border:1px solid var(--border-color,#4a5568);max-height:280px;min-height:200px}.simple-table thead{background:var(--bg-header,#1a202ce6)}.simple-table th{background:#1a202ce6;background:var(--bg-header,#1a202ce6);border-bottom:2px solid var(--border-color,#4a5568);color:var(--text-secondary,#a0aec0)}.simple-table td{border-bottom:1px solid #4a55684d;border-bottom:1px solid var(--border-light,#4a55684d);color:var(--text-primary,#e2e8f0);line-height:1.4}.simple-table tr:hover{background:#ffffff14;background:var(--bg-hover,#ffffff14)}.simple-table tr.selected{background:#1f7cf433;border:1px solid #1f7cf466}.simple-table tr.selected td{color:#fff;font-weight:500}.simple-table td.empty{color:var(--text-muted,#718096);padding:8px}.simple-panel-footer{background:#1a202c;background:var(--bg-header,#1a202c);border-top:1px solid var(--border-color,#4a5568);gap:6px;justify-content:flex-end;padding:8px 12px}.route-waypoint-marker{transition:transform .2s ease}.route-waypoint-marker:hover{transform:scale(1.1)}.route-waypoint-number{color:#fff;font-weight:700;text-shadow:0 1px 2px #00000080}.simple-minimized-icon.active-marking{animation:pulse-blue 2s infinite}@keyframes pulse-blue{0%{box-shadow:0 0 4px #007bbf80}50%{box-shadow:0 0 20px #007bbfcc}to{box-shadow:0 0 4px #007bbf80}}.route-tab-nav{background:#1a202c;background:var(--bg-header,#1a202c);border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color,#4a5568);display:flex}.route-tab{color:var(--text-secondary,#a0aec0);font-size:10px}.route-tab:hover{background:#ffffff0d;color:var(--text-primary,#fff)}.route-tab.active{background:#007bbf1a;border-bottom-color:#007cbf;color:#f7f8fa;color:var(--text-primary,#fff)}.route-tab-content{display:block}.route-tab-content.hidden{display:none}.route-stats-grid{grid-gap:4px;gap:4px;grid-template-columns:repeat(3,1fr);margin-top:4px}.route-stat{background:#007bbf14;border:1px solid #007bbf26;border-radius:3px;padding:4px}#route-management-modal .simple-section{margin-bottom:6px}#route-management-modal .simple-section label{color:#495057;display:block;font-size:10px;font-weight:600;margin-bottom:4px}#route-management-modal input,#route-management-modal select{border:1px solid #ddd;border-radius:3px;font-size:10px;padding:4px}#route-management-modal .simple-btn{border-radius:3px;font-size:9px;padding:4px 6px}#route-management-modal .simple-table{font-size:9px}#route-management-modal .simple-table td,#route-management-modal .simple-table th{padding:3px}.route-card{background:#2a2d3a;border:1px solid #4a5568;border-radius:5px;box-shadow:0 1px 3px #0000001a;margin-bottom:5px;padding:8px}.route-card:hover{background:#3a3d4a;border-color:#007cbf;box-shadow:0 2px 6px #007bbf33}.route-card-header{border-bottom:1px solid #4a5568;margin-bottom:6px;padding-bottom:2px}.route-name{color:#fff;font-size:11px;font-weight:600;margin:0;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.route-priority{border-radius:3px;font-size:8px;font-weight:600;letter-spacing:.3px;padding:2px 5px;text-transform:uppercase}.route-priority.high{background:#dc3545;color:#fff}.route-priority.medium{background:#ffc107;color:#000}.route-priority.low{background:#28a745;color:#fff}.route-info{grid-gap:4px;color:#a0aec0;display:grid;font-size:9px;gap:4px;grid-template-columns:1fr 1fr;line-height:1.3;margin-bottom:5px}.route-info-item{align-items:center;display:flex;justify-content:space-between;padding:1px 0}.route-info-label{color:#9ca3af;font-weight:500}.route-info-value{color:#fff;font-weight:600;text-align:right}.route-actions{border-top:1px solid #4a5568;display:flex;gap:3px;justify-content:flex-end;margin-top:6px;padding-top:4px}.route-action-btn{border:none;font-size:8px;font-weight:500;min-width:32px;padding:3px 5px}.route-action-btn.view{background:#007cbf;color:#fff}.route-action-btn.view:hover{background:#0056b3}.route-action-btn.edit{background:#28a745;color:#fff}.route-action-btn.edit:hover{background:#1e7e34}.route-action-btn.copy{background:#6c757d;color:#fff}.route-action-btn.copy:hover{background:#545b62}.route-action-btn.delete{background:#dc3545;color:#fff}.route-action-btn.delete:hover{background:#c82333;text-align:center}.stat-label{color:#a0a7b4;color:var(--text-secondary,#a0aec0);font-size:10px;margin-bottom:2px}.stat-value{color:#007cbf;display:block;font-size:12px}.simple-select{background:var(--bg-input,#2d3748);border-radius:4px;color:var(--text-primary,#fff);font-size:12px;padding:6px 8px;width:100%}.simple-select:focus{border-color:#007cbf;box-shadow:0 0 0 2px #007bbf33;outline:none}.saved-routes-list{background:#1a1e26d3;background:var(--bg-input,#2d3748);border:1px solid #3c414c;border:1px solid var(--border-color,#4a5568);border-radius:4px;margin-top:8px;max-height:300px}.no-routes-message{color:#a0a7b4;color:var(--text-secondary,#a0aec0);font-size:12px;font-style:italic;padding:20px;text-align:center}.saved-route-item{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color,#4a5568);cursor:pointer;padding:12px;transition:background-color .2s ease}.saved-route-item:last-child{border-bottom:none}.saved-route-item:hover{background:#ffffff0d}.route-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.route-item-name{color:#f7f8fa;color:var(--text-primary,#fff);font-size:13px;font-weight:700}.route-item-priority{border-radius:3px;font-size:10px;font-weight:700;padding:2px 6px;text-transform:uppercase}.priority-high{background:#dc3545;color:#fff}.priority-medium{background:#ffc107;color:#212529}.priority-low{background:#28a745;color:#fff}.route-item-details{grid-gap:8px;color:#a0a7b4;color:var(--text-secondary,#a0aec0);display:grid;font-size:11px;gap:8px;grid-template-columns:1fr 1fr}.route-item-user{color:#007cbf;font-weight:500}.route-item-actions{display:flex;gap:4px;margin-top:8px}.route-action-btn{background:#0000;border:1px solid #3c414c;border:1px solid var(--border-color,#4a5568);border-radius:3px;color:#a0a7b4;color:var(--text-secondary,#a0aec0);cursor:pointer;font-size:10px;padding:4px 8px;transition:all .2s ease}.route-action-btn:hover{background:#ffffff1a;color:#f7f8fa;color:var(--text-primary,#fff)}.route-action-btn.primary{background:#007cbf;border-color:#007cbf;color:#fff}.route-action-btn.danger{background:#dc3545;border-color:#dc3545;color:#fff}.route-optimizing{overflow:hidden;position:relative}.route-optimizing:after{animation:optimizing-shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#007bbf66,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes optimizing-shimmer{0%{left:-100%}to{left:100%}}.optimized-route-line{filter:drop-shadow(0 0 4px rgba(0,123,191,.6))}.route-waypoint-marker.priority-high{border-color:#dc3545!important;box-shadow:0 0 8px #dc354580}.route-waypoint-marker.priority-medium{border-color:#ffc107!important;box-shadow:0 0 8px #ffc10780}.route-waypoint-marker.priority-low{border-color:#28a745!important;box-shadow:0 0 8px #28a74580}.simple-draggable-panel.dragging{cursor:move;opacity:.9}.simple-expandable-header{border-bottom:1px solid #3c414c;border-bottom:1px solid var(--border-color,#4a5568);margin-bottom:6px;padding:3px 0}.simple-expandable-header:hover{background:#ffffff0d;background:var(--bg-hover,#ffffff0d);border-radius:3px;margin:0 -4px 6px;padding:3px 4px}.simple-toggle-icon{color:#6b7280;color:var(--text-muted,#718096);font-size:11px}.simple-toggle-icon.expanded{transform:rotate(-180deg)}.simple-advanced-content{max-height:250px;overflow-y:auto}.simple-advanced-section{border-bottom:1px solid #4a55684d;border-bottom:1px solid var(--border-light,#4a55684d);margin-bottom:8px;padding-bottom:6px}.simple-advanced-section:last-child{border-bottom:none;margin-bottom:0}.simple-import-row{align-items:center;display:flex;gap:4px;margin-bottom:4px}.simple-import-label{color:#6b7280;color:var(--text-muted,#718096);flex-shrink:0;font-size:9px;min-width:60px}.simple-file-input,.simple-select{border:1px solid #3c414c;border:1px solid var(--border-color,#4a5568);border-radius:3px;flex:1 1;font-size:9px;padding:2px 4px}.simple-file-input,.simple-select,.simple-select option{background:#1a1e26d3;background:var(--bg-input,#1a202c);color:#f7f8fa;color:var(--text-primary,#e2e8f0)}.simple-columns-list{background:#1a1e26d3;background:var(--bg-input,#1a202c);border:1px solid #3c414c;border:1px solid var(--border-color,#4a5568);border-radius:3px;font-size:9px;max-height:80px;overflow-y:auto;padding:4px}.simple-columns-list::-webkit-scrollbar{width:4px}.simple-columns-list::-webkit-scrollbar-track{background:#1a1e26d3;background:var(--bg-input,#1a202c)}.simple-columns-list::-webkit-scrollbar-thumb{background:#3c414c;background:var(--border-color,#4a5568);border-radius:2px}.simple-column-item{align-items:center;background:#2a2f38;background:var(--bg-card,#1a202c80);border:1px solid #4a55684d;border:1px solid var(--border-light,#4a55684d);border-radius:2px;color:#f7f8fa;color:var(--text-primary,#e2e8f0);display:flex;justify-content:space-between;margin-bottom:2px;padding:2px 4px}.simple-column-item:last-child{margin-bottom:0}.simple-column-item:hover{background:#ffffff0d;background:var(--bg-hover,#ffffff0d)}.simple-column-remove{background:#e53e3e;border:none;border-radius:2px;color:#fff;cursor:pointer;font-size:8px;padding:1px 3px;transition:background .2s ease}.simple-column-remove:hover{background:#c53030}.enhanced-popup .mapboxgl-popup-content{animation:popupFadeIn .2s cubic-bezier(.4,0,.2,1)!important;background:#fff!important;border:1px solid #d1d5db!important;border-radius:2px!important;box-shadow:0 1px 8px #0000001f!important;font-family:ff-clan-web-pro,Helvetica Neue,Helvetica,sans-serif!important;font-size:10px!important;line-height:1.3!important;max-width:280px!important;min-width:180px!important;overflow:hidden!important;padding:0!important;pointer-events:auto!important;transform:translateY(0) scale(1)!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.enhanced-popup.sticky .mapboxgl-popup-content{animation:none!important;border:2px solid #3b82f6!important;box-shadow:0 4px 20px #3b82f626,0 2px 14px #00000026!important}.enhanced-popup .popup-pin-button{align-items:center!important;background:#0000!important;border:none!important;border-radius:2px!important;color:#6a7485!important;cursor:pointer!important;display:flex!important;flex-shrink:0!important;font-size:12px!important;height:18px!important;justify-content:center!important;margin-left:8px!important;opacity:.8!important;padding:0!important;position:relative!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important;width:18px!important;z-index:10!important}.enhanced-popup .popup-pin-button:hover{transform:scale(1.1)!important}.enhanced-popup .popup-pin-button:hover,.enhanced-popup.sticky .popup-pin-button{background:#3b82f61a!important;color:#3b82f6!important;opacity:1!important}.enhanced-popup.sticky .popup-pin-button:hover{background:#3b82f626!important;transform:scale(1.05)!important}.enhanced-popup .mapboxgl-popup-close-button{background:#0000!important;border:none!important;border-radius:2px!important;color:#6a7485!important;cursor:pointer!important;font-size:16px!important;font-weight:400!important;height:18px!important;line-height:1!important;opacity:.8!important;padding:0!important;right:3px!important;top:3px!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important;width:18px!important;z-index:11!important}.enhanced-popup .mapboxgl-popup-close-button:hover{background:#ef44441a!important;color:#ef4444!important;opacity:1!important;transform:scale(1.1)!important}.enhanced-popup .mapboxgl-popup-tip{border-bottom-color:#fff!important;border-top-color:#fff!important}.enhanced-popup h4{align-items:center!important;background:#fff!important;border-bottom:1px solid #d1d5db!important;color:#1f2937!important;display:flex!important;font-size:11px!important;font-weight:500!important;justify-content:space-between!important;line-height:1.2!important;margin:0!important;padding:6px 40px 4px 12px!important;position:-webkit-sticky!important;position:sticky!important;top:0!important;transition:all .2s ease!important;z-index:10!important}.enhanced-popup .popup-title{flex:1 1!important;margin-right:8px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.enhanced-popup .mapboxgl-popup-content>div{background:#fff!important;max-width:none!important}.enhanced-popup .mapboxgl-popup-content>div>div{background:#fff!important;margin:0!important;max-height:min(180px,25vh)!important;overflow-y:auto!important;padding:2px 0 4px!important;pointer-events:auto!important;scroll-behavior:smooth!important}@media (max-height:600px){.enhanced-popup .mapboxgl-popup-content>div>div{max-height:min(120px,20vh)!important}}.enhanced-popup .mapboxgl-popup-content>div>div::-webkit-scrollbar{width:4px!important}.enhanced-popup .mapboxgl-popup-content>div>div::-webkit-scrollbar-track{background:#f3f4f6!important}.enhanced-popup .mapboxgl-popup-content>div>div::-webkit-scrollbar-thumb{background:#d1d5db!important;border-radius:2px!important}.enhanced-popup .mapboxgl-popup-content>div>div::-webkit-scrollbar-thumb:hover{background:#9ca3af!important}.enhanced-popup .mapboxgl-popup-content div[style*="margin-bottom: 6px"]{background:#fff!important;border-bottom:none!important;display:block!important;margin:0!important;overflow:hidden!important;padding:3px 12px!important;position:relative!important;transition:background-color .15s ease!important}.enhanced-popup .mapboxgl-popup-content div[style*="margin-bottom: 6px"]:nth-child(2n){background:#f3f4f6!important}.enhanced-popup .mapboxgl-popup-content div[style*="margin-bottom: 6px"]:hover{background:#e5e7eb!important}.enhanced-popup .mapboxgl-popup-content div[style*="margin-bottom: 6px"]:last-child{border-bottom:none!important;margin-bottom:0!important;padding-bottom:4px!important}.enhanced-popup strong{color:#6b7280!important;display:inline!important;font-size:10px!important;font-weight:500!important;margin-right:6px!important;min-width:auto!important}.enhanced-popup strong:after{content:": "!important}.enhanced-popup span[style*="color: #666"]{color:#1f2937!important;font-size:10px!important;font-weight:400!important;line-height:1.3!important;word-break:break-word!important}.enhanced-popup em{background:#fff!important;color:#9ca3af!important;display:block!important;font-size:10px!important;font-style:italic!important;padding:8px 12px!important;text-align:center!important}.enhanced-popup.fixed-popup .mapboxgl-popup-tip{display:none!important}.enhanced-popup.fixed-popup{z-index:9999!important}.enhanced-popup.fixed-popup .mapboxgl-popup-content{box-shadow:0 4px 16px #00000026!important}.create-buffer-icon{align-items:center;background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;color:#e0e0e0;cursor:pointer;display:flex;height:36px;justify-content:center;opacity:.85;position:fixed;right:135px;top:10px;transition:all .2s ease;width:36px;z-index:1000}.create-buffer-icon:hover{background:#3a3a3a;opacity:1;transform:scale(1.05)}.create-buffer-icon.active{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;opacity:1}.feature-info-icon{align-items:center;background:#2a2a2a;border:2px solid #ffffffe6;border-radius:6px;color:#e0e0e0;cursor:pointer;display:flex;height:36px;justify-content:center;opacity:.85;position:fixed;right:183px;top:10px;transition:all .2s ease;width:36px;z-index:1000}.feature-info-icon:hover{background:#3a3a3a;opacity:1;transform:scale(1.05)}.feature-info-icon.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;opacity:1}.feature-info-icon i{font-family:Georgia,Times New Roman,serif;font-size:20px;font-style:italic;font-weight:600}.feature-info-panel-compact{cursor:default;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;max-height:336px;position:fixed;right:60px;top:60px;width:238px;z-index:1000}.feature-card{background:#fff;border:2px solid #1f7cf4;border:2px solid var(--primary-blue);border-radius:2px;box-shadow:0 -4px 20px #0000004d;display:flex;flex-direction:column;max-height:336px;overflow:hidden}.feature-card-header{align-items:center;background:#f8faff;border-bottom:1px solid #e0e0e0;display:flex;flex-shrink:0;justify-content:space-between;min-height:28px;padding:6px 8px;-webkit-user-select:none;user-select:none}.feature-card-header h4{color:#1f2937;font-size:11px;font-weight:600;margin:0}.close-panel-btn{align-items:center;background:#0000;border:none;border-radius:2px;color:#6b7280;cursor:pointer;display:flex;font-size:16px;height:18px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:18px}.close-panel-btn:hover{background:#1f7cf41a;color:#1f7cf4;color:var(--primary-blue)}.feature-properties{background:#fff;display:block;max-height:280px;overflow-x:hidden;overflow-y:auto;padding:0;width:100%}.feature-properties>div{border-collapse:collapse;display:table;font-size:11px;table-layout:fixed;width:100%}.feature-properties::-webkit-scrollbar{width:8px}.feature-properties::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.feature-properties::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.feature-properties::-webkit-scrollbar-thumb:hover{background:#9ca3af}.property-row{display:table-row;transition:background .15s ease}.property-row:hover{background:#1f7cf408}.property-row:nth-child(2n){background:#f9fafb}.property-row:nth-child(2n):hover{background:#1f7cf40d}.property-key{color:#1f2937;font-weight:600;max-width:40%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:40%}.property-key,.property-value{border-bottom:1px solid #e5e7eb;display:table-cell;font-size:11px;line-height:1.2;padding:6px 8px;vertical-align:middle}.property-value{border-left:1px solid #e5e7eb;color:#4b5563;max-width:60%;overflow-wrap:break-word;width:60%;word-break:break-word}.layout-container{background:#fff;display:none;height:100vh;left:0;pointer-events:none;position:fixed;top:0;width:100vw;z-index:1500}.layout-container.active{display:block}.layout-page{background:#fff;border:.5px solid #000;box-shadow:0 4px 20px #00000026;margin:20px auto;overflow:hidden;position:relative}.layout-page.a4{height:1123px;padding:30px;width:794px}.layout-page.a3{height:1587px;padding:30px;width:1123px}.layout-map-area{align-items:center;background:#f5f5f5;border:1px solid #ccc;color:#666;display:flex;font-family:Times New Roman,serif;font-size:14px;justify-content:center;margin:0 auto;position:relative}.layout-page.a4 .layout-map-area{height:734px;margin-top:60px;width:734px}.layout-page.a3 .layout-map-area{height:1063px;margin-top:60px;width:1063px}.layout-title-section{font-family:Times New Roman,serif;margin-bottom:20px;text-align:center}.layout-title{color:#000;font-weight:700;margin:0 0 8px}.layout-subtitle{color:#333;margin:0}.layout-page.a4 .layout-title{font-size:18px}.layout-page.a4 .layout-subtitle{font-size:16px}.layout-page.a3 .layout-title{font-size:20px}.layout-page.a3 .layout-subtitle{font-size:14px}.layout-right-panel{position:absolute;right:30px;top:120px;width:200px}.layout-legend{background:#fff;border:.5px solid #000;font-family:Times New Roman,serif;font-size:12px;margin-bottom:15px;padding:12px}.layout-legend-title{font-weight:700;margin-bottom:8px;text-align:center}.layout-description{background:#fff;border:.5px solid #000;font-family:Times New Roman,serif;font-size:12px;padding:12px}.layout-description-title{font-weight:700;margin-bottom:8px;text-align:center}.layout-bottom-left{color:#666;font-family:Times New Roman,serif;left:30px}.layout-bottom-left,.layout-bottom-right{bottom:30px;font-size:10px;position:absolute}.layout-bottom-right{align-items:center;border:1px dashed #ccc;color:#999;display:flex;height:40px;justify-content:center;right:30px;width:80px}.layout-north-arrow{background:url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="m12 2 6 8h-4v12h-4V10H6z"/></svg>') no-repeat 50%;background-size:contain;height:15px;position:absolute;right:10px;top:10px;width:15px}.layout-controls{background:#242730;background:var(--bg-panel);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:8px;display:none;min-width:200px;padding:15px;position:fixed;right:20px;top:20px;z-index:1600}.layout-controls.active{display:block}.layout-controls h3{color:#f7f8fa;color:var(--text-primary);font-size:16px;margin:0 0 15px}.layout-size-buttons{display:flex;gap:10px;margin-bottom:15px}.layout-size-btn{background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#f7f8fa;color:var(--text-primary);cursor:pointer;flex:1 1;font-size:12px;padding:8px 12px;transition:all .2s ease}.layout-size-btn.active,.layout-size-btn:hover{background:#1f7cf4;background:var(--primary-blue);border-color:#1f7cf4;border-color:var(--primary-blue)}.layout-size-btn.active{color:#fff}.layout-input-group{margin-bottom:10px}.layout-input-group label{color:#a0a7b4;color:var(--text-secondary);display:block;font-size:12px;margin-bottom:4px}.layout-input-group input,.layout-input-group textarea{background:#1a1e26d3;background:var(--bg-input);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#f7f8fa;color:var(--text-primary);font-family:inherit;font-size:12px;padding:6px 8px;width:100%}.layout-input-group textarea{min-height:60px;resize:vertical}.layout-actions{display:flex;gap:8px;margin-top:15px}.layout-action-btn{background:#2a2f38;background:var(--bg-card);border:1px solid #3c414c;border:1px solid var(--border-color);border-radius:4px;color:#f7f8fa;color:var(--text-primary);cursor:pointer;flex:1 1;font-size:12px;padding:8px 12px;transition:all .2s ease}.layout-action-btn.primary,.layout-action-btn:hover{background:#1f7cf4;background:var(--primary-blue);border-color:#1f7cf4;border-color:var(--primary-blue)}.layout-action-btn.primary{color:#fff}@media print{.layout-container{background:#fff!important;height:auto!important;position:static!important;width:auto!important}.layout-controls{display:none!important}.layout-page{box-shadow:none!important;margin:0!important;page-break-after:always}}.mapbox-gl-map .mapboxgl-ctrl-top-left>*,.mapboxgl-ctrl-top-left,.mapboxgl-ctrl-top-left .mapboxgl-ctrl{display:none!important}.mapboxgl-ctrl-logo{margin-left:-300px!important}.mapboxgl-ctrl-top-right{right:100px!important}.mapboxgl-ctrl-top-right .mapboxgl-ctrl-group:not([class*=geocoder]){background:#0000!important;border-radius:0!important;box-shadow:none!important}.mapboxgl-ctrl-top-right .mapboxgl-ctrl-group:not([class*=geocoder]) button,.mapboxgl-ctrl-top-right>.mapboxgl-ctrl button{align-items:center!important;background-color:#2a2a2a!important;background:#2a2a2a!important;border:2px solid #ffffffe6!important;border-radius:6px!important;display:flex!important;height:36px!important;justify-content:center!important;margin:0 0 4px!important;max-height:36px!important;max-width:36px!important;min-height:36px!important;min-width:36px!important;opacity:.85!important;transition:all .2s ease!important;width:36px!important}.mapboxgl-ctrl-top-right .mapboxgl-ctrl-group:not([class*=geocoder]) button:last-child,.mapboxgl-ctrl-top-right>.mapboxgl-ctrl button:last-child{margin-bottom:0!important}.mapboxgl-ctrl-top-right .mapboxgl-ctrl-group:not([class*=geocoder]) button:hover,.mapboxgl-ctrl-top-right>.mapboxgl-ctrl button:hover{background-color:#3a3a3a!important;background:#3a3a3a!important;opacity:1!important;transform:scale(1.05)!important}.mapboxgl-ctrl-top-right .mapboxgl-ctrl-group:not([class*=geocoder]) button .mapboxgl-ctrl-icon,.mapboxgl-ctrl-top-right>.mapboxgl-ctrl button .mapboxgl-ctrl-icon{background-position:50%!important;background-size:18px 18px!important}.mapboxgl-ctrl-top-right .mapboxgl-ctrl-group:not([class*=geocoder]) button+button{border-top:2px solid #ffffffe6!important;margin-top:0!important}#root,.App{inset:0;margin:0;overflow:hidden;padding:0;position:fixed}.add-data-icon-btn.processing{cursor:not-allowed;opacity:.7}.add-data-icon-btn.processing:hover{background-color:inherit}.animate-spin{animation:spin 1s linear infinite}.btn-icon{background:none;color:var(--text-secondary);font-size:14px;padding:6px;transition:all .2s}.btn-icon:hover{background:var(--bg-input);color:var(--text-primary)}.tab-navigation{background:var(--bg-input);border-bottom:1px solid var(--border-color);display:flex;gap:2px;padding:4px}.tab-button{align-items:center;background:none;border-radius:8px;color:var(--text-secondary);display:flex;gap:6px;justify-content:center;min-height:40px;padding:10px 8px}.tab-button:hover:not(.disabled){background:var(--bg-card);color:var(--text-primary)}.tab-button.active{background:var(--primary-blue);box-shadow:0 2px 8px #1f7cf44d;color:#fff}.tab-button.disabled{cursor:not-allowed;opacity:.5}.tab-icon{font-size:14px}.tab-name{font-size:11px;font-weight:600}.tab-count{background:#fff3;border-radius:10px;font-size:10px;font-weight:700;padding:2px 6px}.tab-button.active .tab-count{background:#ffffff4d}.tab-content{flex:1 1}.layer-list,.tab-content{display:flex;flex-direction:column;overflow:hidden}.layer-list-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:16px 20px}.list-title{color:var(--text-primary);font-size:14px;font-weight:600}.list-actions{display:flex;gap:8px}.btn-sm{background:var(--bg-input);border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:10px;padding:4px 8px;transition:all .2s}.btn-sm:hover{background:var(--primary-blue);color:#fff}.layer-items{flex:1 1;overflow-y:auto;padding:8px}.layer-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;margin-bottom:8px}.layer-item.selected,.layer-item:hover{border-color:var(--primary-blue)}.layer-item.selected{box-shadow:0 0 0 1px var(--primary-blue)}.layer-header{cursor:pointer;padding:12px}.layer-info{align-items:center;display:flex;gap:10px}.expand-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:12px;transition:transform .2s;width:16px}.geometry-icon{font-size:16px;text-align:center;width:20px}.layer-details{flex:1 1;min-width:0}.layer-name{display:block}.layer-stats{color:var(--text-muted);font-size:11px}.layer-controls{gap:8px}.layer-controls input[type=checkbox]{margin:0}.delete-btn,.zoom-btn{background:none;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:12px;padding:4px;transition:all .2s}.zoom-btn:hover{background:var(--accent-teal);color:#fff}.delete-btn:hover{background:var(--error);color:#fff}.layer-expanded{background:var(--bg-input);border-top:1px solid var(--border-color);padding:12px}.layer-properties h5{color:var(--text-primary);font-size:12px;margin:0 0 8px}.property-list{display:flex;flex-direction:column;gap:4px}.property-item{align-items:center;display:flex;font-size:11px;justify-content:space-between}.property-type{color:var(--text-muted);font-style:italic}.no-properties,.property-more{color:var(--text-muted);font-size:11px;padding:8px;text-align:center}.layer-actions-expanded{border-top:1px solid var(--border-color);display:flex;gap:8px;margin-top:12px;padding-top:12px}.data-statistics-empty,.layer-legend-empty,.layer-list-empty,.visualization-controls-empty{align-items:center;display:flex;flex:1 1;justify-content:center;padding:40px}.empty-state{max-width:280px}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-state h4{color:var(--text-primary);font-size:16px;margin:0 0 8px}.empty-state p{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0 0 16px}.supported-formats{background:var(--bg-input);color:var(--text-muted);font-size:12px;padding:8px}.visualization-controls{flex:1 1;overflow-y:auto;padding:16px}.controls-header{margin-bottom:20px}.controls-header h4{color:var(--text-primary);font-size:16px;margin:0 0 8px}.geometry-info{color:var(--text-muted);display:flex;font-size:12px;gap:12px}.control-section{border-bottom:1px solid var(--border-color);margin-bottom:24px;padding-bottom:20px}.control-section:last-child{border-bottom:none;margin-bottom:0}.control-label{display:block;font-size:13px;margin-bottom:12px}.control-label,.control-section h5{color:var(--text-primary);font-weight:600}.control-section h5{font-size:14px;margin:0 0 16px}.mode-buttons{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.mode-btn{align-items:center;background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:column;font-size:10px;gap:4px;padding:12px 8px;transition:all .2s}.mode-btn:hover:not(.disabled){border-color:var(--primary-blue);color:var(--text-primary)}.mode-btn.active{background:var(--primary-blue);border-color:var(--primary-blue);color:#fff}.mode-btn.disabled{cursor:not-allowed;opacity:.5}.control-group{margin-bottom:16px}.control-group label{color:var(--text-primary);display:block;font-size:12px;font-weight:500;margin-bottom:6px}.control-group input[type=color]{border:none;border-radius:6px;cursor:pointer;height:36px;width:100%}.control-group input[type=range]{-webkit-appearance:none;background:var(--bg-input);border-radius:2px;height:4px;outline:none;width:100%}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:var(--primary-blue);border-radius:50%;cursor:pointer;height:16px;width:16px}.control-group select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:12px;padding:8px 12px;width:100%}.btn-primary,.btn-secondary{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;padding:10px 16px;transition:all .2s}.btn-primary{background:var(--primary-blue)}.btn-primary:hover{background:var(--primary-blue-hover)}.btn-secondary{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{border-color:var(--primary-blue)}.full-width{width:100%}.data-statistics{flex:1 1;overflow-y:auto;padding:16px}.stats-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.stats-header h4{color:var(--text-primary);font-size:16px;margin:0}.layer-selector{background:var(--bg-input);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:12px;padding:6px 12px}.stats-content{display:flex;flex-direction:column;gap:20px}.stats-section h5{color:var(--text-primary);font-size:14px;font-weight:600;margin:0 0 12px}.stats-grid{grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.stat-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:12px}.stat-label{color:var(--text-muted);display:block;font-size:11px;margin-bottom:4px}.stat-value{color:var(--text-primary);font-size:18px}.geometry-stats{display:flex;flex-direction:column;gap:8px}.geometry-stat{align-items:center;display:flex;gap:12px}.geometry-type{color:var(--text-primary);font-size:12px;font-weight:500;min-width:80px}.geometry-bar{background:var(--bg-input);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.geometry-fill{background:linear-gradient(90deg,var(--primary-blue),var(--accent-teal));border-radius:3px;height:100%}.geometry-count{color:var(--text-secondary);font-size:12px;font-weight:600;min-width:30px;text-align:right}.bounds-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.bound-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;padding:10px}.bound-label{color:var(--text-muted);display:block;font-size:11px;margin-bottom:4px}.bound-value{color:var(--text-primary);font-size:12px;font-weight:600}.property-stats{display:flex;flex-direction:column;gap:12px}.property-stat{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:12px}.property-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.property-name{color:var(--text-primary);font-size:13px;font-weight:600}.property-type{border-radius:10px;font-size:10px;font-weight:600;padding:2px 6px;text-transform:uppercase}.property-type.number{background:var(--success);color:#fff}.property-type.string{background:var(--primary-blue);color:#fff}.property-details{display:flex;flex-direction:column;gap:4px}.property-detail{display:flex;font-size:11px;justify-content:space-between}.property-detail span:first-child{color:var(--text-muted)}.property-detail span:last-child{color:var(--text-primary);font-weight:500}.layer-legend{flex:1 1;overflow-y:auto;padding:16px}.legend-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.legend-header h4{color:var(--text-primary);font-size:16px;margin:0}.layer-count{color:var(--text-muted);font-size:12px}.legend-items{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.legend-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;gap:12px;padding:10px}.legend-symbol{align-items:center;display:flex;height:20px;justify-content:center;min-width:20px;position:relative}.geometry-symbol{font-size:16px;font-weight:700}.heatmap-legend{background:linear-gradient(90deg,#2166ac00,#67a9cf 25%,#d1e5f0 50%,#fddbc7 75%,#ef6548);border-radius:6px;height:12px;width:20px}.heatmap-gradient{border-radius:inherit;height:100%;width:100%}.visualization-mode-icon{align-items:center;background:var(--bg-main);border-radius:50%;display:flex;font-size:10px;height:16px;justify-content:center;position:absolute;right:-4px;top:-4px;width:16px}.legend-info{flex:1 1;min-width:0}.legend-name{color:var(--text-primary);font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-details{color:var(--text-muted);font-size:11px}.legend-controls{align-items:center;display:flex}.opacity-indicator{color:var(--text-secondary);cursor:help;font-size:14px}.legend-section{border-bottom:1px solid var(--border-color);margin-bottom:16px;padding-bottom:12px}.legend-section:last-child{border-bottom:none;margin-bottom:0}.legend-section h5{color:var(--text-primary);font-size:12px;font-weight:600;margin:0 0 8px}.heatmap-scale{display:flex;flex-direction:column;gap:4px}.scale-gradient{background:linear-gradient(90deg,#2166ac00,#67a9cf 25%,#d1e5f0 50%,#fddbc7 75%,#ef6548);border-radius:6px;height:12px}.scale-labels{color:var(--text-muted);display:flex;font-size:10px;justify-content:space-between}.geometry-reference,.visualization-reference{display:flex;flex-wrap:wrap;gap:12px}.geometry-ref-item,.viz-ref-item{align-items:center;color:var(--text-secondary);display:flex;font-size:11px;gap:6px}.ref-symbol{color:var(--text-primary);font-weight:700}.ref-symbol,.viz-icon{font-size:12px}.legend-footer{border-top:1px solid var(--border-color);padding-top:12px;text-align:center}.legend-timestamp{color:var(--text-muted);font-size:10px}.company-branding{align-items:flex-end;display:flex;margin-top:auto;min-height:60px;padding:8px 8px 0}.company-logo{display:block;height:60px;opacity:.9;transition:opacity .2s ease;width:auto}.company-logo:hover{opacity:.9}.mapboxgl-map{-webkit-tap-highlight-color:rgb(0 0 0/0);font:12px/20px Helvetica Neue,Arial,Helvetica,sans-serif;overflow:hidden;position:relative}.mapboxgl-canvas{left:0;position:absolute;top:0}.mapboxgl-map:-webkit-full-screen{height:100%;width:100%}.mapboxgl-canary{background-color:salmon}.mapboxgl-canvas-container.mapboxgl-interactive,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass{cursor:grab;-webkit-user-select:none;user-select:none}.mapboxgl-canvas-container.mapboxgl-interactive.mapboxgl-track-pointer{cursor:pointer}.mapboxgl-canvas-container.mapboxgl-interactive:active,.mapboxgl-ctrl-group button.mapboxgl-ctrl-compass:active{cursor:grabbing}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate .mapboxgl-canvas{touch-action:pan-x pan-y}.mapboxgl-canvas-container.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:pinch-zoom}.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan,.mapboxgl-canvas-container.mapboxgl-touch-zoom-rotate.mapboxgl-touch-drag-pan .mapboxgl-canvas{touch-action:none}.mapboxgl-ctrl-bottom,.mapboxgl-ctrl-bottom-left,.mapboxgl-ctrl-bottom-right,.mapboxgl-ctrl-left,.mapboxgl-ctrl-right,.mapboxgl-ctrl-top,.mapboxgl-ctrl-top-left,.mapboxgl-ctrl-top-right{pointer-events:none;position:absolute;z-index:2}.mapboxgl-ctrl-top-left{left:0;top:0}.mapboxgl-ctrl-top{left:50%;top:0;transform:translateX(-50%)}.mapboxgl-ctrl-top-right{right:0;top:0}.mapboxgl-ctrl-right{right:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl-bottom-right{bottom:0;right:0}.mapboxgl-ctrl-bottom{bottom:0;left:50%;transform:translateX(-50%)}.mapboxgl-ctrl-bottom-left{bottom:0;left:0}.mapboxgl-ctrl-left{left:0;top:50%;transform:translateY(-50%)}.mapboxgl-ctrl{clear:both;pointer-events:auto;transform:translate(0)}.mapboxgl-ctrl-top-left .mapboxgl-ctrl{float:left;margin:10px 0 0 10px}.mapboxgl-ctrl-top .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-top-right .mapboxgl-ctrl{float:right;margin:10px 10px 0 0}.mapboxgl-ctrl-bottom-right .mapboxgl-ctrl,.mapboxgl-ctrl-right .mapboxgl-ctrl{float:right;margin:0 10px 10px 0}.mapboxgl-ctrl-bottom .mapboxgl-ctrl{float:left;margin:10px 0}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl,.mapboxgl-ctrl-left .mapboxgl-ctrl{float:left;margin:0 0 10px 10px}.mapboxgl-ctrl-group{background:#fff;border-radius:4px}.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px #0000001a}@media (-ms-high-contrast:active){.mapboxgl-ctrl-group:not(:empty){box-shadow:0 0 0 2px ButtonText}}.mapboxgl-ctrl-group button{background-color:initial;border:0;box-sizing:border-box;cursor:pointer;display:block;height:29px;outline:none;overflow:hidden;padding:0;width:29px}.mapboxgl-ctrl-group button+button{border-top:1px solid #ddd}.mapboxgl-ctrl button .mapboxgl-ctrl-icon{background-position:50%;background-repeat:no-repeat;display:block;height:100%;width:100%}@media (-ms-high-contrast:active){.mapboxgl-ctrl-icon{background-color:initial}.mapboxgl-ctrl-group button+button{border-top:1px solid ButtonText}}.mapboxgl-ctrl-attrib-button:focus,.mapboxgl-ctrl-group button:focus{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl button:disabled{cursor:not-allowed}.mapboxgl-ctrl button:disabled .mapboxgl-ctrl-icon{opacity:.25}.mapboxgl-ctrl-group button:first-child{border-radius:4px 4px 0 0}.mapboxgl-ctrl-group button:last-child{border-radius:0 0 4px 4px}.mapboxgl-ctrl-group button:only-child{border-radius:inherit}.mapboxgl-ctrl button:not(:disabled):hover{background-color:#0000000d}.mapboxgl-ctrl-group button:focus:focus-visible{box-shadow:0 0 2px 2px #0096ff}.mapboxgl-ctrl-group button:focus:not(:focus-visible){box-shadow:none}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-out .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M10 13c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h9c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-9z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-zoom-in .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M14.5 8.5c-.75 0-1.5.75-1.5 1.5v3h-3c-.75 0-1.5.75-1.5 1.5S9.25 16 10 16h3v3c0 .75.75 1.5 1.5 1.5S16 19.75 16 19v-3h3c.75 0 1.5-.75 1.5-1.5S19.75 13 19 13h-3v-3c0-.75-.75-1.5-1.5-1.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-fullscreen .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M24 16v5.5c0 1.75-.75 2.5-2.5 2.5H16v-1l3-1.5-4-5.5 1-1 5.5 4 1.5-3h1zM6 16l1.5 3 5.5-4 1 1-4 5.5 3 1.5v1H7.5C5.75 24 5 23.25 5 21.5V16h1zm7-11v1l-3 1.5 4 5.5-1 1-5.5-4L6 13H5V7.5C5 5.75 5.75 5 7.5 5H13zm11 2.5c0-1.75-.75-2.5-2.5-2.5H16v1l3 1.5-4 5.5 1 1 5.5-4 1.5 3h1V7.5z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-shrink .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='M18.5 16c-1.75 0-2.5.75-2.5 2.5V24h1l1.5-3 5.5 4 1-1-4-5.5 3-1.5v-1h-5.5zM13 18.5c0-1.75-.75-2.5-2.5-2.5H5v1l3 1.5L4 24l1 1 5.5-4 1.5 3h1v-5.5zm3-8c0 1.75.75 2.5 2.5 2.5H24v-1l-3-1.5L25 5l-1-1-5.5 4L17 5h-1v5.5zM10.5 13c1.75 0 2.5-.75 2.5-2.5V5h-1l-1.5 3L5 4 4 5l4 5.5L5 12v1h5.5z'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23333' viewBox='0 0 29 29'%3E%3Cpath d='m10.5 14 4-8 4 8h-8z'/%3E%3Cpath d='m10.5 16 4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 29 29'%3E%3Cpath d='m10.5 14 4-8 4 8h-8z'/%3E%3Cpath d='m10.5 16 4 8 4-8h-8z' fill='%23999'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-compass .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 29 29'%3E%3Cpath d='m10.5 14 4-8 4 8h-8z'/%3E%3Cpath d='m10.5 16 4 8 4-8h-8z' fill='%23ccc'/%3E%3C/svg%3E")}}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23333'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-buildings-toggle .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg fill='none' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath d='M3.333 11.667a1.667 1.667 0 1 0 3.334 0v-5h5a1.667 1.667 0 1 0 0-3.334H3.333v8.334ZM26.667 11.667a1.667 1.667 0 1 1-3.334 0v-5h-5a1.667 1.667 0 1 1 0-3.334h8.334v8.334ZM13.334 25c0 .92-.747 1.667-1.667 1.667H3.333v-8.334a1.667 1.667 0 1 1 3.334 0v5h5c.92 0 1.667.746 1.667 1.667ZM18.334 26.667a1.667 1.667 0 1 1 0-3.334h5v-5a1.667 1.667 0 1 1 3.333 0v8.334h-8.334Z' fill='currentColor'/%3E%3C/svg%3E");background-size:26px 26px}.mapboxgl-ctrl button.mapboxgl-ctrl-buildings-toggle.mapboxgl-ctrl-level-button-selected .mapboxgl-ctrl-icon{filter:invert(1) brightness(1)}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23aaa'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath d='m14 5 1 1-9 9-1-1 9-9z' fill='red'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-waiting .mapboxgl-ctrl-icon{animation:mapboxgl-spin 2s linear infinite}@media (-ms-high-contrast:active){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23fff'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23999'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath d='m14 5 1 1-9 9-1-1 9-9z' fill='red'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-active-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e58978'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%2333b5e5'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate.mapboxgl-ctrl-geolocate-background-error .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23e54e33'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3C/svg%3E")}.mapboxgl-ctrl button.mapboxgl-ctrl-geolocate:disabled .mapboxgl-ctrl-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill='%23666'%3E%3Cpath d='M10 4C9 4 9 5 9 5v.1A5 5 0 0 0 5.1 9H5s-1 0-1 1 1 1 1 1h.1A5 5 0 0 0 9 14.9v.1s0 1 1 1 1-1 1-1v-.1a5 5 0 0 0 3.9-3.9h.1s1 0 1-1-1-1-1-1h-.1A5 5 0 0 0 11 5.1V5s0-1-1-1zm0 2.5a3.5 3.5 0 1 1 0 7 3.5 3.5 0 1 1 0-7z'/%3E%3Ccircle cx='10' cy='10' r='2'/%3E%3Cpath d='m14 5 1 1-9 9-1-1 9-9z' fill='red'/%3E%3C/svg%3E")}}@keyframes mapboxgl-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='a' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 0 1 3.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='b' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 0 0-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 0 0 4.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 0 1-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 0 1 .3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 0 1-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='c'%3E%3Crect width='100%25' height='100%25' fill='%23fff'/%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/mask%3E%3Cg opacity='.3' stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23c)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23b' mask='url(%23c)'/%3E%3C/g%3E%3Cg opacity='.9' fill='%23fff'%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/g%3E%3C/svg%3E");background-repeat:no-repeat;cursor:pointer;display:block;height:23px;margin:0 0 -4px -4px;overflow:hidden;width:88px}a.mapboxgl-ctrl-logo.mapboxgl-compact{width:23px}@media (-ms-high-contrast:active){a.mapboxgl-ctrl-logo{background-color:initial;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='a' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 0 1 3.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='b' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 0 0-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 0 0 4.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 0 1-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 0 1 .3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 0 1-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='c'%3E%3Crect width='100%25' height='100%25' fill='%23fff'/%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/mask%3E%3Cg stroke='%23000' stroke-width='3'%3E%3Ccircle mask='url(%23c)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23b' mask='url(%23c)'/%3E%3C/g%3E%3Cg fill='%23fff'%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/g%3E%3C/svg%3E")}}@media (-ms-high-contrast:black-on-white){a.mapboxgl-ctrl-logo{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' fill-rule='evenodd' viewBox='0 0 88 23'%3E%3Cdefs%3E%3Cpath id='a' d='M11.5 2.25c5.105 0 9.25 4.145 9.25 9.25s-4.145 9.25-9.25 9.25-9.25-4.145-9.25-9.25 4.145-9.25 9.25-9.25zM6.997 15.983c-.051-.338-.828-5.802 2.233-8.873a4.395 4.395 0 0 1 3.13-1.28c1.27 0 2.49.51 3.39 1.42.91.9 1.42 2.12 1.42 3.39 0 1.18-.449 2.301-1.28 3.13C12.72 16.93 7 16 7 16l-.003-.017zM15.3 10.5l-2 .8-.8 2-.8-2-2-.8 2-.8.8-2 .8 2 2 .8z'/%3E%3Cpath id='b' d='M50.63 8c.13 0 .23.1.23.23V9c.7-.76 1.7-1.18 2.73-1.18 2.17 0 3.95 1.85 3.95 4.17s-1.77 4.19-3.94 4.19c-1.04 0-2.03-.43-2.74-1.18v3.77c0 .13-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V8.23c0-.12.1-.23.23-.23h1.4zm-3.86.01c.01 0 .01 0 .01-.01.13 0 .22.1.22.22v7.55c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V15c-.7.76-1.69 1.19-2.73 1.19-2.17 0-3.94-1.87-3.94-4.19 0-2.32 1.77-4.19 3.94-4.19 1.03 0 2.02.43 2.73 1.18v-.75c0-.12.1-.23.23-.23h1.4zm26.375-.19a4.24 4.24 0 0 0-4.16 3.29c-.13.59-.13 1.19 0 1.77a4.233 4.233 0 0 0 4.17 3.3c2.35 0 4.26-1.87 4.26-4.19 0-2.32-1.9-4.17-4.27-4.17zM60.63 5c.13 0 .23.1.23.23v3.76c.7-.76 1.7-1.18 2.73-1.18 1.88 0 3.45 1.4 3.84 3.28.13.59.13 1.2 0 1.8-.39 1.88-1.96 3.29-3.84 3.29-1.03 0-2.02-.43-2.73-1.18v.77c0 .12-.1.23-.23.23h-1.4c-.13 0-.23-.1-.23-.23V5.23c0-.12.1-.23.23-.23h1.4zm-34 11h-1.4c-.13 0-.23-.11-.23-.23V8.22c.01-.13.1-.22.23-.22h1.4c.13 0 .22.11.23.22v.68c.5-.68 1.3-1.09 2.16-1.1h.03c1.09 0 2.09.6 2.6 1.55.45-.95 1.4-1.55 2.44-1.56 1.62 0 2.93 1.25 2.9 2.78l.03 5.2c0 .13-.1.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.8 0-1.46.7-1.59 1.62l.01 4.68c0 .13-.11.23-.23.23h-1.41c-.13 0-.23-.11-.23-.23v-4.59c0-.98-.74-1.71-1.62-1.71-.85 0-1.54.79-1.6 1.8v4.5c0 .13-.1.23-.23.23zm53.615 0h-1.61c-.04 0-.08-.01-.12-.03-.09-.06-.13-.19-.06-.28l2.43-3.71-2.39-3.65a.213.213 0 0 1-.03-.12c0-.12.09-.21.21-.21h1.61c.13 0 .24.06.3.17l1.41 2.37 1.4-2.37a.34.34 0 0 1 .3-.17h1.6c.04 0 .08.01.12.03.09.06.13.19.06.28l-2.37 3.65 2.43 3.7c0 .05.01.09.01.13 0 .12-.09.21-.21.21h-1.61c-.13 0-.24-.06-.3-.17l-1.44-2.42-1.44 2.42a.34.34 0 0 1-.3.17zm-7.12-1.49c-1.33 0-2.42-1.12-2.42-2.51 0-1.39 1.08-2.52 2.42-2.52 1.33 0 2.42 1.12 2.42 2.51 0 1.39-1.08 2.51-2.42 2.52zm-19.865 0c-1.32 0-2.39-1.11-2.42-2.48v-.07c.02-1.38 1.09-2.49 2.4-2.49 1.32 0 2.41 1.12 2.41 2.51 0 1.39-1.07 2.52-2.39 2.53zm-8.11-2.48c-.01 1.37-1.09 2.47-2.41 2.47s-2.42-1.12-2.42-2.51c0-1.39 1.08-2.52 2.4-2.52 1.33 0 2.39 1.11 2.41 2.48l.02.08zm18.12 2.47c-1.32 0-2.39-1.11-2.41-2.48v-.06c.02-1.38 1.09-2.48 2.41-2.48s2.42 1.12 2.42 2.51c0 1.39-1.09 2.51-2.42 2.51z'/%3E%3C/defs%3E%3Cmask id='c'%3E%3Crect width='100%25' height='100%25' fill='%23fff'/%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/mask%3E%3Cg stroke='%23fff' stroke-width='3' fill='%23fff'%3E%3Ccircle mask='url(%23c)' cx='11.5' cy='11.5' r='9.25'/%3E%3Cuse xlink:href='%23b' mask='url(%23c)'/%3E%3C/g%3E%3Cuse xlink:href='%23a'/%3E%3Cuse xlink:href='%23b'/%3E%3C/svg%3E")}}.mapboxgl-ctrl.mapboxgl-ctrl-attrib{background-color:#ffffff80;margin:0;padding:0 5px}@media screen{.mapboxgl-ctrl-attrib.mapboxgl-compact{background-color:#fff;border-radius:12px;box-sizing:initial;margin:10px;min-height:20px;padding:2px 24px 2px 0;position:relative}.mapboxgl-ctrl-attrib.mapboxgl-compact-show{padding:2px 28px 2px 8px;visibility:visible}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show,.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact-show{border-radius:12px;padding:2px 8px 2px 28px}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-inner{display:none}.mapboxgl-ctrl-attrib-button{background-color:#ffffff80;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E");border:0;border-radius:12px;box-sizing:border-box;cursor:pointer;display:none;height:24px;outline:none;position:absolute;right:0;top:0;width:24px}.mapboxgl-ctrl-bottom-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-left .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-top-left .mapboxgl-ctrl-attrib-button{left:0}.mapboxgl-ctrl-attrib.mapboxgl-compact .mapboxgl-ctrl-attrib-button,.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-inner{display:block}.mapboxgl-ctrl-attrib.mapboxgl-compact-show .mapboxgl-ctrl-attrib-button{background-color:#0000000d}.mapboxgl-ctrl-bottom-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;right:0}.mapboxgl-ctrl-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0}.mapboxgl-ctrl-top-right>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{right:0;top:0}.mapboxgl-ctrl-top-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0;top:0}.mapboxgl-ctrl-bottom-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{bottom:0;left:0}.mapboxgl-ctrl-left>.mapboxgl-ctrl-attrib.mapboxgl-compact:after{left:0}}@media screen and (-ms-high-contrast:active){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd' fill='%23fff'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}@media screen and (-ms-high-contrast:black-on-white){.mapboxgl-ctrl-attrib.mapboxgl-compact:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg' fill-rule='evenodd'%3E%3Cpath d='M4 10a6 6 0 1 0 12 0 6 6 0 1 0-12 0m5-3a1 1 0 1 0 2 0 1 1 0 1 0-2 0m0 3a1 1 0 1 1 2 0v3a1 1 0 1 1-2 0'/%3E%3C/svg%3E")}}.mapboxgl-ctrl-attrib a{color:#000000bf;text-decoration:none}.mapboxgl-ctrl-attrib a:hover{color:inherit;text-decoration:underline}.mapboxgl-ctrl-attrib .mapbox-improve-map{font-weight:700;margin-left:2px}.mapboxgl-attrib-empty{display:none}.mapboxgl-ctrl-scale{background-color:#ffffffbf;border:2px solid #333;border-top:#333;box-sizing:border-box;color:#333;font-size:10px;padding:0 5px;white-space:nowrap}.mapboxgl-popup{display:flex;left:0;pointer-events:none;position:absolute;top:0;will-change:transform}.mapboxgl-popup-anchor-top,.mapboxgl-popup-anchor-top-left,.mapboxgl-popup-anchor-top-right{flex-direction:column}.mapboxgl-popup-anchor-bottom,.mapboxgl-popup-anchor-bottom-left,.mapboxgl-popup-anchor-bottom-right{flex-direction:column-reverse}.mapboxgl-popup-anchor-left{flex-direction:row}.mapboxgl-popup-anchor-right{flex-direction:row-reverse}.mapboxgl-popup-tip{border:10px solid #0000;height:0;width:0;z-index:1}.mapboxgl-popup-anchor-top .mapboxgl-popup-tip{align-self:center;border-bottom-color:#fff;border-top:none}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom-color:#fff;border-left:none;border-top:none}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom-color:#fff;border-right:none;border-top:none}.mapboxgl-popup-anchor-bottom .mapboxgl-popup-tip{align-self:center;border-bottom:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-tip{align-self:flex-start;border-bottom:none;border-left:none;border-top-color:#fff}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-tip{align-self:flex-end;border-bottom:none;border-right:none;border-top-color:#fff}.mapboxgl-popup-anchor-left .mapboxgl-popup-tip{align-self:center;border-left:none;border-right-color:#fff}.mapboxgl-popup-anchor-right .mapboxgl-popup-tip{align-self:center;border-left-color:#fff;border-right:none}.mapboxgl-popup-close-button{background-color:initial;border:0;border-radius:0 3px 0 0;cursor:pointer;position:absolute;right:0;top:0}.mapboxgl-popup-close-button:hover{background-color:#0000000d}.mapboxgl-popup-content{background:#fff;border-radius:3px;box-shadow:0 1px 2px #0000001a;padding:10px 10px 15px;pointer-events:auto;position:relative}.mapboxgl-popup-anchor-top-left .mapboxgl-popup-content{border-top-left-radius:0}.mapboxgl-popup-anchor-top-right .mapboxgl-popup-content{border-top-right-radius:0}.mapboxgl-popup-anchor-bottom-left .mapboxgl-popup-content{border-bottom-left-radius:0}.mapboxgl-popup-anchor-bottom-right .mapboxgl-popup-content{border-bottom-right-radius:0}.mapboxgl-popup-track-pointer{display:none}.mapboxgl-popup-track-pointer *{pointer-events:none;-webkit-user-select:none;user-select:none}.mapboxgl-map:hover .mapboxgl-popup-track-pointer{display:flex}.mapboxgl-map:active .mapboxgl-popup-track-pointer{display:none}.mapboxgl-marker{left:0;opacity:1;position:absolute;top:0;transition:opacity .2s;will-change:transform}.mapboxgl-user-location-dot,.mapboxgl-user-location-dot:before{background-color:#1da1f2;border-radius:50%;height:15px;width:15px}.mapboxgl-user-location-dot:before{animation:mapboxgl-user-location-dot-pulse 2s infinite;content:"";position:absolute}.mapboxgl-user-location-dot:after{border:2px solid #fff;border-radius:50%;box-shadow:0 0 3px #00000059;box-sizing:border-box;content:"";height:19px;left:-2px;position:absolute;top:-2px;width:19px}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading{height:0;width:0}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after,.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-bottom:7.5px solid #4aa1eb;content:"";position:absolute}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:before{border-left:7.5px solid #0000;transform:translateY(-28px) skewY(-20deg)}.mapboxgl-user-location-show-heading .mapboxgl-user-location-heading:after{border-right:7.5px solid #0000;transform:translate(7.5px,-28px) skewY(20deg)}@keyframes mapboxgl-user-location-dot-pulse{0%{opacity:1;transform:scale(1)}70%{opacity:0;transform:scale(3)}to{opacity:0;transform:scale(1)}}.mapboxgl-user-location-dot-stale{background-color:#aaa}.mapboxgl-user-location-dot-stale:after{display:none}.mapboxgl-user-location-accuracy-circle{background-color:#1da1f233;border-radius:100%;height:1px;width:1px}.mapboxgl-crosshair,.mapboxgl-crosshair .mapboxgl-interactive,.mapboxgl-crosshair .mapboxgl-interactive:active{cursor:crosshair}.mapboxgl-boxzoom{background:#fff;border:2px dotted #202020;height:0;left:0;opacity:.5;position:absolute;top:0;width:0}@media print{.mapbox-improve-map{display:none}}.mapboxgl-scroll-zoom-blocker,.mapboxgl-touch-pan-blocker{align-items:center;background:#000000b3;color:#fff;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;height:100%;justify-content:center;left:0;opacity:0;pointer-events:none;position:absolute;text-align:center;top:0;transition:opacity .75s ease-in-out;transition-delay:1s;width:100%}.mapboxgl-scroll-zoom-blocker-show,.mapboxgl-touch-pan-blocker-show{opacity:1;transition:opacity .1s ease-in-out}.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page,.mapboxgl-canvas-container.mapboxgl-touch-pan-blocker-override.mapboxgl-scrollable-page .mapboxgl-canvas{touch-action:pan-x pan-y}.mapboxgl-ctrl-separator{background-color:#e0e0e0;height:1px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button{color:#333;font-size:18px;font-weight:700;height:50px;width:50px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:last-child{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button:hover{background-color:#f5f5f5}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button-selected{background-color:#4a5568;color:#fff}.mapboxgl-ctrl button.mapboxgl-ctrl-level-button-selected:hover{background-color:#2d3748}.swipe-divider{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.swipe-divider:active{cursor:ew-resize!important}.layer-selection-modal-overlay{align-items:center;animation:fadeIn .2s ease-in-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.layer-selection-modal{animation:slideUp .3s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#161c26f2;border:1px solid #3c414c;border-radius:8px;box-shadow:0 25px 80px #0009;display:flex;flex-direction:column;max-height:70vh;max-width:90vw;width:700px}.layer-selection-header{align-items:center;background:#2a2f3899;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;padding:14px 18px}.layer-selection-header h2{color:#e0e0e0;font-size:16px;font-weight:600;letter-spacing:.3px;margin:0}.layer-selection-header .close-button{align-items:center;background:#ffffff0d;border:1px solid #3c414c;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:24px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:28px}.layer-selection-header .close-button:hover{background-color:#ffffff1a;border-color:#1f7cf4;color:#fff}.layer-selection-content{display:flex;flex:1 1;gap:16px;overflow:hidden;padding:16px}.layer-selection-column{display:flex;flex:1 1;flex-direction:column;min-width:0}.layer-selection-column h3{color:#999;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-align:center;text-transform:uppercase}.layer-list{background:#2a2f3866;border:1px solid #3c414c;border-radius:6px;flex:1 1;overflow-y:auto;padding:6px}.layer-list::-webkit-scrollbar{width:6px}.layer-list::-webkit-scrollbar-track{background:#0003;border-radius:3px}.layer-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.layer-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.layer-item{align-items:center;background:#2a2f3899;border:1px solid #3c414c;border-radius:4px;cursor:pointer;display:flex;gap:10px;margin-bottom:6px;padding:8px 10px;transition:all .2s}.layer-item:last-child{margin-bottom:0}.layer-item:hover{background:#2a2f38e6;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf44d}.layer-item.selected{background:#1f7cf426;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf466}.layer-name{color:#e0e0e0;font-size:13px;font-weight:500;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-meta{color:#888;font-size:11px}.selection-divider{padding-top:30px}.selection-divider,.vs-text{align-items:center;display:flex;justify-content:center}.vs-text{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:2px solid #ffffff1a;border-radius:50%;box-shadow:0 4px 16px #1f7cf480;color:#fff;font-size:14px;font-weight:700;height:40px;width:40px}.no-layers{color:#666;font-size:13px;padding:24px 16px;text-align:center}.layer-selection-footer{background:#2a2f3866;border-top:1px solid #3c414c;display:flex;gap:10px;justify-content:flex-end;padding:14px 18px}.cancel-button,.compare-button{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 20px;transition:all .2s}.compare-button{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;color:#fff}.compare-button:hover:not(:disabled){box-shadow:0 4px 16px #1f7cf480;transform:translateY(-1px)}.compare-button:disabled{background:#ffffff1a;cursor:not-allowed;opacity:.4}.comparison-modal-overlay{align-items:center;animation:fadeIn .3s ease-in-out;background-color:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10001}.comparison-modal-container{animation:scaleIn .3s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#161c26f2;border:1px solid #3c414c;border-radius:12px;box-shadow:0 25px 80px #0009;display:flex;flex-direction:column;height:88vh;overflow:hidden;width:80vw}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.comparison-modal-header{align-items:center;background:#2a2f38cc;border-bottom:1px solid #3c414c;color:#fff;display:flex;justify-content:space-between;padding:14px 18px}.comparison-modal-title{align-items:center;display:flex;flex:1 1;gap:16px}.layer-name-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#1f7cf433;border:1px solid #1f7cf44d;border-radius:20px;color:#e0e0e0;font-size:13px;font-weight:500;max-width:300px;overflow:hidden;padding:6px 14px;text-overflow:ellipsis;white-space:nowrap}.layer-name-badge.left,.layer-name-badge.right{background:#1f7cf440;border-color:#1f7cf466}.vs-indicator{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;border-radius:8px;color:#fff;font-size:16px;font-weight:700;padding:6px 12px}.comparison-close-button{align-items:center;background:#ffffff0d;border:1px solid #3c414c;border-radius:6px;color:#999;cursor:pointer;display:flex;font-size:28px;height:36px;justify-content:center;line-height:1;transition:all .2s;width:36px}.comparison-close-button:hover{background:#ffffff1a;border-color:#1f7cf4;color:#fff;transform:translateY(-1px)}.comparison-modal-content{background:#202630e6;display:flex;flex:1 1;overflow:hidden;position:relative}.comparison-map-container{height:100%;left:0;position:absolute;top:0;width:100%;will-change:clip-path}.comparison-map-full{height:100%;width:100%}.map-label{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2a2f38f2;border:1px solid #3c414c;border-radius:8px;box-shadow:0 4px 16px #0006;display:flex;flex-direction:column;gap:4px;padding:10px 16px;pointer-events:none;position:absolute;top:20px;z-index:1000}.map-label.left-label{left:20px}.map-label.right-label{right:20px}.map-label span:first-child{color:#e0e0e0;font-size:13px;font-weight:600}.viz-type{color:#999;font-size:10px;letter-spacing:.5px;text-transform:uppercase}.comparison-divider{background:#0000;bottom:0;cursor:ew-resize;position:absolute;top:0;transform:translateX(-50%);width:4px;will-change:left;z-index:10}.divider-handle{align-items:center;display:flex;height:100%;justify-content:center;position:relative;width:100%}.divider-line{background:linear-gradient(180deg,#1f7cf4cc,#1f7cf4 50%,#1f7cf4cc);bottom:0;box-shadow:0 0 12px #1f7cf499;left:50%;position:absolute;top:0;transform:translateX(-50%);width:3px}.divider-grip{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#2a2f38f2;border:2px solid #1f7cf4;border-radius:18px;box-shadow:0 4px 20px #1f7cf466;display:flex;gap:4px;height:72px;justify-content:center;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:all .2s;width:36px}.comparison-divider:hover .divider-grip{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border-color:#1f7cf4;box-shadow:0 6px 24px #1f7cf499;color:#fff}.divider-grip span{color:#1f7cf4;font-size:14px;line-height:1}.comparison-divider:hover .divider-grip span{color:#fff}.comparison-modal-content.dragging{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.comparison-map-container:before{background:#2a2f38cc;border:1px solid #3c414c;border-radius:8px;color:#999;content:"Loading map...";font-size:13px;font-weight:500;left:50%;padding:12px 24px;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:0}.comparison-map-container .mapboxgl-ctrl-attrib,.comparison-map-container .mapboxgl-ctrl-logo{display:none!important}.forgot-password-container{align-items:center;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.forgot-password-box{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(145deg,#1e293bf2,#0f172afa);border:1px solid #ffffff1a;border-radius:16px;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d;max-width:400px;padding:32px;position:relative;width:100%}.forgot-password-box h3{color:#fff;font-size:24px;font-weight:600;margin:0 0 24px;text-align:center}.back-button{align-items:center;background:#0000;border:none;border-radius:8px;color:#fff9;cursor:pointer;display:flex;justify-content:center;left:16px;padding:8px;position:absolute;top:16px;transition:all .2s ease}.back-button:hover{background:#ffffff1a;color:#fff}.forgot-password-steps{align-items:center;display:flex;gap:8px;justify-content:center;margin-bottom:28px}.forgot-password-steps .step{align-items:center;display:flex;flex-direction:column;gap:6px}.forgot-password-steps .step-number{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:50%;color:#ffffff80;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;transition:all .3s ease;width:32px}.forgot-password-steps .step span{color:#ffffff80;font-size:11px;font-weight:500;transition:color .3s ease}.forgot-password-steps .step.active .step-number{background:linear-gradient(135deg,#3b82f6,#2563eb);border-color:#3b82f6;box-shadow:0 0 20px #3b82f666;color:#fff}.forgot-password-steps .step.active span{color:#3b82f6}.forgot-password-steps .step.completed .step-number{background:linear-gradient(135deg,#10b981,#059669);border-color:#10b981;color:#fff}.forgot-password-steps .step.completed span{color:#10b981}.forgot-password-steps .step-line{background:#ffffff1a;height:2px;margin-bottom:18px;width:40px}.step-description{color:#ffffffb3;font-size:14px;line-height:1.5;margin-bottom:24px;text-align:center}.step-description strong{color:#3b82f6}.input-group{margin-bottom:16px}.forgot-password-box .login-input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;box-sizing:border-box;color:#fff;font-size:14px;padding:14px 16px;transition:all .2s ease;width:100%}.forgot-password-box .login-input:focus{background:#ffffff14;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none}.forgot-password-box .login-input::placeholder{color:#fff6}.forgot-password-box .login-input.input-error{background:#ef44440d;border-color:#ef4444}.forgot-password-box .login-input.input-error:focus{box-shadow:0 0 0 3px #ef444426}.error-text{color:#ef4444;display:block;font-size:12px;margin-top:6px;padding-left:4px}.otp-error{display:block;margin-top:8px;text-align:center}.otp-input-group{display:flex;gap:10px;justify-content:center;margin-bottom:8px}.otp-input{background:#ffffff0d;border:2px solid #ffffff1a;border-radius:12px;caret-color:#3b82f6;color:#fff;font-size:24px;font-weight:600;height:56px;text-align:center;transition:all .2s ease;width:48px}.otp-input:focus{background:#ffffff14;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626;outline:none;transform:translateY(-2px)}.otp-input.input-error{animation:shake .5s ease-in-out;border-color:#ef4444}.resend-otp{margin:16px 0 24px;text-align:center}.resend-otp span{color:#ffffff80;font-size:13px}.resend-btn{background:#0000;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;font-size:13px;font-weight:500;padding:4px 8px;transition:all .2s ease}.resend-btn:hover:not(:disabled){background:#3b82f61a;color:#60a5fa}.resend-btn:disabled{cursor:not-allowed;opacity:.5}.forgot-password-box .password-input-wrapper{align-items:center;display:flex;position:relative}.forgot-password-box .password-input-wrapper .login-input{padding-right:48px}.forgot-password-box .password-toggle-btn{align-items:center;background:#0000;border:none;color:#ffffff80;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px;transition:color .2s ease}.forgot-password-box .password-toggle-btn:hover{color:#fffc}.password-strength{align-items:center;display:flex;gap:12px;margin-top:10px}.strength-bar{display:flex;flex:1 1;gap:4px}.strength-segment{background:#ffffff1a;border-radius:2px;flex:1 1;height:4px;transition:background-color .3s ease}.strength-segment.active{background:#3b82f6}.strength-label{font-size:12px;font-weight:500;min-width:80px;text-align:right}.password-match{margin-top:8px}.password-match .match-error,.password-match .match-success{align-items:center;display:flex;font-size:12px;font-weight:500;gap:6px}.password-match .match-success{color:#10b981}.password-match .match-error{color:#ef4444}.password-requirements{background:#ffffff08;border:1px solid #ffffff0d;border-radius:10px;margin-bottom:20px;padding:14px 16px}.password-requirements p{color:#fff9;font-size:12px;font-weight:500;margin:0 0 10px}.password-requirements ul{grid-gap:6px;display:grid;gap:6px;grid-template-columns:1fr 1fr}.password-requirements li{align-items:center;color:#fff6;display:flex;font-size:11px;gap:6px;transition:color .2s ease}.password-requirements li:before{background:#fff3;border-radius:50%;content:"";height:6px;transition:background .2s ease;width:6px}.password-requirements li.valid{color:#10b981}.password-requirements li.valid:before{background:#10b981}.forgot-password-box .login-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;box-shadow:0 4px 15px #3b82f64d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:14px 24px;transition:all .3s ease;width:100%}.forgot-password-box .login-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 20px #3b82f666;transform:translateY(-1px)}.forgot-password-box .login-btn:active:not(:disabled){transform:translateY(0)}.forgot-password-box .login-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.forgot-password-box .message{animation:fadeIn .3s ease;border-radius:8px;font-size:13px;font-weight:500;margin-top:16px;padding:12px 16px;text-align:center}.forgot-password-box .message.error{background:#ef44441a;border:1px solid #ef444433;color:#ef4444}.forgot-password-box .message.success{background:#10b9811a;border:1px solid #10b98133;color:#10b981}.forgot-password-link{display:block;margin-top:16px;text-align:center}.forgot-password-link button{background:#0000;border:none;border-radius:4px;color:#3b82f6;cursor:pointer;font-size:13px;font-weight:500;padding:4px 8px;transition:all .2s ease}.forgot-password-link button:hover{background:#3b82f61a;color:#60a5fa;text-decoration:underline}@media (max-width:480px){.forgot-password-box{margin:16px;padding:24px}.otp-input{font-size:20px;height:48px;width:40px}.otp-input-group{gap:6px}.password-requirements ul{grid-template-columns:1fr}.forgot-password-steps .step-line{width:24px}}.layer-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;cursor:default;margin-bottom:8px;min-height:-webkit-fit-content;min-height:fit-content;padding:8px;position:relative;transition:all .3s ease}.layer-card:hover{border-color:var(--primary-blue);box-shadow:var(--shadow-lg)}.layer-card:active{cursor:grabbing}.layer-card.dragging{cursor:grabbing;opacity:.5;transform:rotate(2deg)}.layer-card.drag-over{background:#18d0cd1a;border-color:var(--accent-teal);box-shadow:0 8px 20px #18d0cd4d;transform:translateY(-2px)}.layer-card.minimized{margin-bottom:4px;padding:6px 8px}.layer-card.minimized .layer-header{margin-bottom:0}.layer-content{max-height:none;opacity:1;overflow:visible;transition:max-height .3s cubic-bezier(.4,0,.2,1),opacity .3s ease}.layer-content.minimized{max-height:0;opacity:0;overflow:hidden}.layer-header{cursor:default;gap:12px;justify-content:space-between;margin-bottom:0;min-height:32px}.layer-controls,.layer-header{align-items:center;display:flex}.layer-controls{flex-shrink:0;gap:6px}.color-picker,.data-viz-select,.layer-controls,button,input[type=color],select{-webkit-user-drag:none;user-drag:none;cursor:default!important;-moz-user-select:none}.layer-name{word-wrap:break-word;color:var(--text-primary);flex:2 1;gap:8px;margin-right:-20px;max-width:calc(100% + 25px);min-width:0;overflow:visible;white-space:normal}.layer-filename{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.layer-control-btn{align-items:center;background:#ffffff0d;border:1px solid #ffffff26;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;height:26px;justify-content:center;min-width:26px;overflow:hidden;padding:4px;position:relative;top:45px;transition:all .2s cubic-bezier(.4,0,.2,1)}.layer-control-btn:before{background:#3b82f633;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s ease,height .3s ease;width:0}.layer-control-btn:hover:not(:disabled){background:#3b82f61a;border-color:#3b82f666;box-shadow:0 2px 8px #3b82f633;color:var(--primary-blue);transform:translateY(-1px)}.layer-control-btn:hover:not(:disabled):before{height:100%;width:100%}.layer-control-btn:active:not(:disabled){box-shadow:0 1px 4px #3b82f633;transform:translateY(0)}.layer-control-btn:disabled{background:#ffffff05;cursor:not-allowed;opacity:.3}.layer-control-btn svg{height:14px;transition:transform .2s ease;width:14px}.layer-control-btn.minimized svg{transform:none}.layer-control-btn[data-action=move-up]:hover:not(:disabled) svg{transform:translateY(-2px)}.layer-control-btn[data-action=move-down]:hover:not(:disabled) svg{transform:translateY(2px)}.layer-minimize-btn{left:0;position:relative;top:1px!important}.layer-remove-btn,.layer-shift-down-btn,.layer-shift-up-btn{top:1px!important}.layer-remove-btn:hover:not(:disabled){background:#ef44441a;border-color:#ef444466;color:#ef4444}.layer-remove-btn:hover:not(:disabled) svg{animation:shake .3s ease}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-2px)}75%{transform:translateX(2px)}}.layer-toggle{background:var(--border-color);border-radius:9px;cursor:pointer;height:18px;position:relative;right:0;top:1px;transition:background-color .3s;width:36px}.layer-toggle.active{background:var(--primary-blue)}.layer-toggle:after{background:#fff;border-radius:50%;content:"";height:14px;left:2px;position:absolute;top:2px;transition:transform .3s;width:14px}.layer-toggle.active:after{transform:translateX(18px)}.modern-color-control{align-items:center;display:flex;flex-direction:column;gap:4px}.color-label{color:var(--text-muted);font-size:10px;line-height:1;text-align:center}.coloris-input{background:#0000;border:2px solid var(--border-color);border-radius:6px;cursor:pointer;height:32px;transition:all .2s ease;width:32px}.coloris-input:hover{border-color:var(--primary-blue);transform:scale(1.05)}.opacity-control-horizontal{align-items:center;display:flex;gap:6px;min-width:80px}.opacity-slider{-webkit-appearance:none;appearance:none;background:linear-gradient(to right,#0000 0,var(--primary-blue) 100%);border-radius:2px;cursor:pointer;flex:1 1;height:4px;outline:none}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:var(--primary-blue);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:12px;width:12px}.opacity-slider::-moz-range-thumb{background:var(--primary-blue);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0003;cursor:pointer;height:12px;width:12px}.opacity-value{color:var(--text-muted);font-size:10px;min-width:28px;text-align:right}.btn{background:var(--bg-button);border:1px solid var(--border-color);color:var(--text-primary);padding:8px 12px;text-decoration:none}.btn:hover{background:var(--bg-button-hover);border-color:var(--primary-blue);box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.btn.btn-secondary{background:var(--bg-secondary);border-color:var(--border-color)}.btn.btn-small{font-size:11px;padding:6px 10px}.layer-attribute-btn{background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;color:#ffffff92!important;font-weight:600!important;justify-content:center;letter-spacing:.5px;transition:all .2s ease}.layer-attribute-btn:hover{background:#3b82f61a!important;border-color:#3b82f666!important;box-shadow:0 2px 8px #3b82f633;color:#3b82f6!important;color:var(--primary-blue,#3b82f6)!important;transform:translateY(-1px)}.btn.btn-secondary.btn-small.layer-settings-btn{background:var(--bg-secondary)!important;border:1px solid var(--border-color)!important;color:#ffffff92!important;font-weight:600!important;justify-content:center;letter-spacing:.5px;transition:all .2s ease!important}.btn.btn-secondary.btn-small.layer-settings-btn:hover{background:#3b82f61a!important;border-color:#3b82f666!important;box-shadow:0 2px 8px #3b82f633!important;color:#3b82f6!important;color:var(--primary-blue,#3b82f6)!important;transform:translateY(-1px)!important}.btn.btn-secondary.btn-small.layer-settings-btn:hover svg{stroke:#3b82f6!important;stroke:var(--primary-blue,#3b82f6)!important}.btn.btn-secondary.btn-small.layer-settings-btn.active{background:#3b82f626!important;border-color:#3b82f680!important;color:#3b82f6!important;color:var(--primary-blue,#3b82f6)!important}.btn.btn-secondary.btn-small.layer-settings-btn.active svg{stroke:#3b82f6!important;stroke:var(--primary-blue,#3b82f6)!important}.section-chevron{display:inline-block;transition:transform .2s ease}.section-chevron.collapsed{transform:rotate(-90deg)}.data-viz-section,.labels-section{contain:layout style;margin-bottom:8px;position:relative;will-change:auto}.labels-content,.viz-content{contain:layout;min-height:auto;overflow:visible;padding:0 2px;transition:all .3s cubic-bezier(.4,0,.2,1);will-change:auto}.data-viz-select{transition:all .2s ease}.data-viz-select:focus{outline:2px solid var(--primary-blue);outline-offset:2px}.switch{display:inline-block;height:16px;position:relative;width:30px}.switch input{height:0;opacity:0;width:0}.slider{background-color:var(--border-color);bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.3s}.slider:before{background-color:#fff;bottom:3px;content:"";height:10px;left:3px;width:10px}.switch input:checked+.slider{background-color:var(--primary-blue)}.switch input:checked+.slider:before{transform:translateX(14px)}.slider.round{border-radius:20px}.slider.round:before{border-radius:50%}.slider-control-row{align-items:center;display:flex;gap:8px;margin-bottom:8px}.slider-label{color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.3px;min-width:40px;text-transform:uppercase}.slider-control-horizontal{align-items:center;display:flex;flex:1 1;gap:8px;min-width:80px}.terrain-slider,.uniform-slider,input[type=range]{-webkit-user-drag:none;user-drag:none;-webkit-appearance:none;appearance:none;background:linear-gradient(90deg,#2193b0 0,#6dd5ed 50%,#e2e8f0 0,#e2e8f0);background:linear-gradient(to right,#2193b0 0,#6dd5ed var(--value,50%),#e2e8f0 var(--value,50%),#e2e8f0 100%);border:none;border-radius:2px;cursor:pointer;flex:1 1;height:3px;min-width:100px;outline:none;touch-action:pan-x;transition:all .15s cubic-bezier(.25,.46,.45,.94);-moz-user-select:none}.terrain-slider:hover,.uniform-slider:hover,input[type=range]:hover{background:linear-gradient(90deg,#1a7da0 0,#36d1dc 50%,#e2e8f0 0,#e2e8f0);background:linear-gradient(to right,#1a7da0 0,#36d1dc var(--value,50%),#e2e8f0 var(--value,50%),#e2e8f0 100%);box-shadow:0 2px 8px #2193b033;height:4px}.terrain-slider:focus,.uniform-slider:focus,input[type=range]:focus{box-shadow:0 0 0 3px #2193b04d;outline:none}.terrain-slider::-webkit-slider-thumb,.uniform-slider::-webkit-slider-thumb,input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#36d1dc,#5b86e5);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #2193b04d,0 4px 16px #5b86e526;cursor:grab;height:14px;position:relative;-webkit-transition:all .2s cubic-bezier(.25,.46,.45,.94);transition:all .2s cubic-bezier(.25,.46,.45,.94);width:14px}.terrain-slider::-webkit-slider-thumb:hover,.uniform-slider::-webkit-slider-thumb:hover,input[type=range]::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#2193b0,#4a78f7);border-color:#fff;box-shadow:0 4px 16px #2193b066,0 8px 32px #5b86e540;cursor:grab;transform:scale(1.25)}.terrain-slider::-webkit-slider-thumb:active,.uniform-slider::-webkit-slider-thumb:active,input[type=range]::-webkit-slider-thumb:active{background:linear-gradient(135deg,#1a7da0,#3d68e6);box-shadow:0 2px 12px #2193b080,0 6px 24px #5b86e54d;cursor:grabbing;transform:scale(1.15);-webkit-transition:all .1s ease-out;transition:all .1s ease-out}.terrain-slider::-moz-range-thumb,.uniform-slider::-moz-range-thumb,input[type=range]::-moz-range-thumb{background:linear-gradient(135deg,#36d1dc,#5b86e5);border:2px solid #fff;border-radius:50%;box-shadow:0 2px 8px #2193b04d,0 4px 16px #5b86e526;cursor:grab;height:14px;-moz-transition:all .2s cubic-bezier(.25,.46,.45,.94);transition:all .2s cubic-bezier(.25,.46,.45,.94);width:14px}.terrain-slider::-moz-range-thumb:hover,.uniform-slider::-moz-range-thumb:hover,input[type=range]::-moz-range-thumb:hover{background:linear-gradient(135deg,#2193b0,#4a78f7);border-color:#fff;box-shadow:0 4px 16px #2193b066,0 8px 32px #5b86e540;transform:scale(1.25)}.terrain-slider::-moz-range-track,.uniform-slider::-moz-range-track,input[type=range]::-moz-range-track{background:#d1d5db;border:none;border-radius:2px;height:3px}.slider-value{font-feature-settings:"tnum";color:#6b7280;font-size:11px;font-variant-numeric:tabular-nums;font-weight:500;min-width:35px;text-align:center;transition:all .15s ease}.slider-control-horizontal:hover .slider-value{color:#374151}.terrain-slider:focus+.slider-value,.uniform-slider:focus+.slider-value,input[type=range]:focus+.slider-value{color:#1f2937}.terrain-slider:active+.slider-value,.uniform-slider:active+.slider-value,input[type=range]:active+.slider-value{color:#111827}.opacity-slider.dragging,input[type=range].dragging{cursor:grabbing!important}.opacity-slider.dragging::-webkit-slider-thumb,input[type=range].dragging::-webkit-slider-thumb{cursor:grabbing!important;transform:scale(1.2)}.opacity-slider.dragging::-moz-range-thumb,input[type=range].dragging::-moz-range-thumb{cursor:grabbing!important;transform:scale(1.2)}.filter-panel{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#161c26f2;border:1px solid #3c414c;border-radius:8px;box-shadow:0 25px 80px #0009;display:flex;flex-direction:column;max-height:75vh;position:fixed;right:60px;top:14px;width:265px;z-index:1001}.filter-panel-header{align-items:center;background:#2a2f3899;border-bottom:1px solid #3c414c;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:9px 11px}.filter-panel-header span{color:#e0e0e0;font-size:13px;font-weight:600;letter-spacing:.3px}.filter-panel-close,.filter-panel-minimize{align-items:center;background:#ffffff0d;border:1px solid #3c414c;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:16px;height:22px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:22px}.filter-panel-close:hover,.filter-panel-minimize:hover{background-color:#ffffff1a;border-color:#1f7cf4;color:#fff}.filter-panel-body{background:#0000;flex:1 1;overflow-y:auto;padding:9px}.filter-panel-body::-webkit-scrollbar{width:6px}.filter-panel-body::-webkit-scrollbar-track{background:#0003;border-radius:3px}.filter-panel-body::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.filter-panel-body::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.filter-section-title{color:#999;font-size:10px;font-weight:600;letter-spacing:.5px;margin-bottom:6px;text-transform:uppercase}.filter-label{color:#999;display:block;font-size:10px;font-weight:500;margin:4px 0 3px}.filter-input,.filter-select{background:#1a1e26;border:1px solid #3c414c;border-radius:4px;color:#fff;font-size:11px;margin-bottom:4px;outline:none;padding:6px 8px;transition:all .2s;width:100%}.filter-input:hover,.filter-select:hover{background:#22272e;border-color:#666}.filter-input:focus,.filter-select:focus{background:#22272e;border-color:#1f7cf4;box-shadow:0 0 0 2px #1f7cf41a}.filter-select:disabled{cursor:not-allowed;opacity:.5}.filter-select option{background:#1a1e26;color:#fff;padding:8px 10px}.filter-select option:checked,.filter-select option:hover{background:#2a3442;color:#fff}.filter-select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding-right:28px}.filter-button-row{display:flex;gap:5px;margin-top:8px}.filter-btn{border:none;border-radius:4px;cursor:pointer;flex:1 1;font-size:11px;font-weight:500;padding:6px 10px;transition:all .2s}.filter-btn-primary{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;color:#fff}.filter-btn-primary:hover:not(:disabled){box-shadow:0 2px 8px #1f7cf480;transform:translateY(-1px)}.filter-btn-primary:disabled{background:#ffffff1a;cursor:not-allowed;opacity:.4}.filter-btn-secondary{background:#ffffff14;border:1px solid #3c414c;color:#e0e0e0}.filter-btn-secondary:hover:not(:disabled){background:#ffffff1f;border-color:#666}.filter-btn-secondary:disabled{cursor:not-allowed;opacity:.4}.active-filters-list{background:#2a2f3866;border:1px solid #3c414c;border-radius:6px;margin-top:3px;max-height:180px;min-height:50px;overflow-y:auto;padding:6px}.active-filters-list::-webkit-scrollbar{width:5px}.active-filters-list::-webkit-scrollbar-track{background:#0003;border-radius:3px}.active-filters-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.active-filters-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.filter-item{align-items:center;background:#2a2f3899;border:1px solid #3c414c;border-radius:4px;display:flex;gap:6px;justify-content:space-between;margin-bottom:4px;padding:6px 8px;transition:all .2s}.filter-item:last-child{margin-bottom:0}.filter-item:hover{background:#2a2f38e6;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf44d}.filter-item-info{flex:1 1;min-width:0}.filter-item-layer{color:#e0e0e0;font-size:11px;font-weight:600;margin-bottom:2px}.filter-item-condition{color:#888;font-size:9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-item-remove{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:3px;color:#ef4444;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:18px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:18px}.filter-item-remove:hover{background:#ef444433;border-color:#ef4444;box-shadow:0 2px 6px #ef444466}.no-filters-message{color:#666;font-size:10px;font-style:italic;padding:12px 8px;text-align:center}.filter-value-autocomplete{position:relative;width:100%}.filter-suggestions{background:#202630fa;border:1px solid #3c414c;border-radius:0 0 4px 4px;border-top:none;box-shadow:0 4px 12px #0006;left:0;max-height:180px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1100}.filter-suggestions::-webkit-scrollbar{width:5px}.filter-suggestions::-webkit-scrollbar-track{background:#0003;border-radius:3px}.filter-suggestions::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.filter-suggestion-item{border-bottom:1px solid #3c414c80;color:#ccc;cursor:pointer;font-size:11px;padding:6px 10px;transition:all .15s}.filter-suggestion-item:last-child{border-bottom:none}.filter-suggestion-item.highlighted,.filter-suggestion-item:hover{background:#1f7cf433;color:#fff}.filter-suggestion-item.highlighted{background:#1f7cf44d}.suggestion-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.suggestion-highlight{color:#1f7cf4;font-weight:600}.filter-suggestions-header{background:#2a2f38cc;border-bottom:1px solid #3c414c;color:#888;font-size:9px;letter-spacing:.5px;padding:5px 10px;text-transform:uppercase}.filter-input[type=number]::-webkit-inner-spin-button,.filter-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.filter-input[type=number]{-moz-appearance:textfield}.time-series-modal-overlay{align-items:center;animation:fadeIn .2s ease-in-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000d9;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.time-series-modal{animation:slideUp .3s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#161c26f2;border:1px solid #3c414c;border-radius:8px;box-shadow:0 25px 80px #0009;display:flex;flex-direction:column;max-height:80vh;max-width:90vw;width:600px}.time-series-header{align-items:center;background:#2a2f3899;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;padding:14px 18px}.time-series-header h2{color:#e0e0e0;font-size:16px;font-weight:600;letter-spacing:.3px;margin:0}.time-series-header .close-button{align-items:center;background:#ffffff0d;border:1px solid #3c414c;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:24px;height:28px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:28px}.time-series-header .close-button:hover{background-color:#ffffff1a;border-color:#1f7cf4;color:#fff}.time-series-content{flex:1 1;gap:20px;overflow-y:auto;padding:16px}.time-series-content,.time-series-section{display:flex;flex-direction:column}.time-series-section h3{color:#999;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 10px;text-transform:uppercase}.field-list,.layer-list{background:#2a2f3866;border:1px solid #3c414c;border-radius:6px;max-height:250px;overflow-y:auto;padding:6px}.field-list::-webkit-scrollbar,.layer-list::-webkit-scrollbar{width:6px}.field-list::-webkit-scrollbar-track,.layer-list::-webkit-scrollbar-track{background:#0003;border-radius:3px}.field-list::-webkit-scrollbar-thumb,.layer-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.field-list::-webkit-scrollbar-thumb:hover,.layer-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.field-item,.layer-item{align-items:center;background:#2a2f3899;border:1px solid #3c414c;border-radius:4px;cursor:pointer;display:flex;gap:10px;margin-bottom:6px;padding:8px 10px;transition:all .2s}.field-item:last-child,.layer-item:last-child{margin-bottom:0}.field-item:hover,.layer-item:hover{background:#2a2f38e6;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf44d}.field-item.selected,.layer-item.selected{background:#1f7cf426;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf466}.layer-color-indicator{border:1px solid #fff3;border-radius:3px;box-shadow:0 2px 4px #0000004d;flex-shrink:0;height:24px;width:24px}.field-info,.layer-info{flex:1 1;min-width:0}.field-name,.layer-name{color:#e0e0e0;font-size:13px;font-weight:500;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.field-type,.layer-meta{color:#888;font-size:11px}.selected-indicator{align-items:center;background-color:#1f7cf4;border-radius:50%;box-shadow:0 2px 6px #1f7cf466;color:#fff;display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:20px;justify-content:center;width:20px}.no-fields,.no-layers{color:#666;font-size:13px;padding:24px 16px;text-align:center}.time-series-footer{background:#2a2f3866;border-top:1px solid #3c414c;display:flex;gap:10px;justify-content:flex-end;padding:14px 18px}.apply-button,.cancel-button{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 20px;transition:all .2s}.cancel-button{background:#ffffff14;border:1px solid #3c414c;color:#e0e0e0}.cancel-button:hover{background:#ffffff1f;border-color:#666}.apply-button{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;color:#fff}.apply-button:hover:not(:disabled){box-shadow:0 4px 16px #1f7cf480;transform:translateY(-1px)}.apply-button:disabled{background:#ffffff1a;cursor:not-allowed;opacity:.4}.site-suitability-button{box-shadow:0 2px 8px #0000004d}.site-suitability-button:hover{transform:translateY(-1px)}.site-suitability-button svg{pointer-events:none}.site-suitability-modal-overlay{animation:fadeIn .2s ease}.site-suitability-modal{animation:slideUp .25s ease}.site-suitability-modal ::-webkit-scrollbar{width:6px}.site-suitability-modal ::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.site-suitability-modal ::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.site-suitability-modal ::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.site-suitability-modal input[type=range]{-webkit-appearance:none;appearance:none;background:#374151;border-radius:3px;cursor:pointer;height:6px;outline:none;width:100%}.site-suitability-modal input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:currentColor;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:14px;-webkit-transition:transform .15s ease;transition:transform .15s ease;width:14px}.site-suitability-modal input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}.site-suitability-modal input[type=range]::-moz-range-thumb{background:currentColor;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:pointer;height:14px;width:14px}.site-suitability-modal select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;cursor:pointer;padding-right:28px!important}.site-suitability-modal select:focus{border-color:#10b981;box-shadow:0 0 0 2px #10b98133;outline:none}.site-suitability-modal .upload-dropzone{transition:all .2s ease}.site-suitability-modal .upload-dropzone.dragover{background:#10b98133;border-color:#10b981}.site-suitability-modal .layer-card{transition:border-color .2s ease}.site-suitability-modal .layer-card:hover{border-color:#fff3}.site-suitability-modal button{transition:all .15s ease}.suitability-legend{background:linear-gradient(90deg,#d73027 0,#fc8d59 25%,#fee08b 50%,#91cf60 75%,#1a9850)}.site-suitability-modal .loading-spinner{animation:spin 1s linear infinite}@media (max-width:640px){.site-suitability-modal{max-height:90vh!important;width:95vw!important}}.swipe-tool-button{box-shadow:0 2px 8px #0000004d}.swipe-tool-button.active{box-shadow:0 0 0 2px #0078d44d,0 2px 8px #0000004d}.swipe-tool-button svg{pointer-events:none}.swipe-config-panel{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.swipe-panel-overlay{animation:fadeIn .3s ease}.swipe-config-panel div::-webkit-scrollbar{width:6px}.swipe-config-panel div::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.swipe-config-panel div::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.swipe-config-panel div::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.route-management-panel{pointer-events:none!important}.route-management-panel>div{pointer-events:auto!important}.route-management-panel.dragging{cursor:move!important;opacity:.9;pointer-events:auto!important}.route-panel-header{cursor:move!important;-webkit-user-select:none!important;user-select:none!important}.route-management-panel .btn,.route-management-panel .form-control,.route-management-panel button,.route-management-panel input,.route-management-panel select,.route-management-panel textarea{cursor:pointer!important;pointer-events:auto!important}.route-management-panel .panel-content{max-height:calc(100vh - 180px);overflow-y:auto}.route-management-panel .panel-content::-webkit-scrollbar,.route-management-panel::-webkit-scrollbar{width:6px}.route-management-panel .panel-content::-webkit-scrollbar-track,.route-management-panel::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.route-management-panel .panel-content::-webkit-scrollbar-thumb,.route-management-panel::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.route-management-panel .panel-content::-webkit-scrollbar-thumb:hover,.route-management-panel::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.tab-button{background:#0000;border:none;border-bottom:2px solid #0000;color:#a0a7b4;cursor:pointer;flex:1 1;font-size:12px;font-weight:500;padding:10px;transition:all .2s}.tab-button:hover{background:#1f7cf40d;color:#f7f8fa}.tab-button.active{background:#1f7cf41a;border-bottom-color:#1f7cf4;color:#1f7cf4}.form-group{margin-bottom:15px}.form-group label{font-size:11px;margin-bottom:5px}.form-control{padding:8px 12px;transition:all .2s}.btn,.form-control{border-radius:4px;font-size:12px}.btn-primary{border:1px solid #1f7cf44d}.btn-outline{background:#0000;border:1px solid #3c414c;color:#a0a7b4}.btn-outline:hover:not(:disabled){background:#ffffff0d;border-color:#4a5568;color:#f7f8fa}.btn:disabled{cursor:not-allowed!important}.waypoint-item{gap:8px;margin-bottom:5px;transition:all .2s}.waypoint-marker{font-size:11px;font-weight:600}.route-card{background:#2a2f3899;border:1px solid #3c414c;border-radius:6px;margin-bottom:8px;padding:12px;transition:all .2s}.route-card:hover{background:#2a2f38e6;border-color:#1f7cf4;box-shadow:0 4px 12px #1f7cf466;transform:translateY(-1px)}@media (max-width:768px){.route-management-panel{right:20px!important;width:calc(100vw - 40px)!important}}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.route-management-panel{animation:slideIn .3s ease-out}.file-import-container{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:20px auto;max-width:600px;min-width:400px;padding:20px}.file-import-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:10px}.file-import-header h3{color:#333;font-size:20px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#999;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:all .2s;width:30px}.close-btn:hover{background:#f0f0f0;color:#333}.file-dropzone{align-items:center;background:#fafafa;border:2px dashed #d0d0d0;border-radius:8px;cursor:pointer;display:flex;justify-content:center;min-height:200px;padding:40px 20px;position:relative;text-align:center;transition:all .3s ease}.file-dropzone:hover:not(.processing){background:#f5fff5;border-color:#4caf50}.file-dropzone.dragging{background:#e3f2fd;border-color:#2196f3;transform:scale(1.02)}.file-dropzone.processing{background:#f5f5f5;cursor:not-allowed;opacity:.7}.dropzone-content{pointer-events:none}.upload-icon{font-size:48px;margin-bottom:16px;opacity:.6}.dropzone-content h4{color:#333;font-size:18px;font-weight:500;margin:0 0 8px}.supported-formats{color:#666;font-size:14px;margin:8px 0 20px}.browse-btn{background:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;pointer-events:auto;transition:background .2s}.browse-btn:hover{background:#1976d2}.upload-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#2196f3;height:40px;margin:0 auto 16px;width:40px}.error-message{align-items:center;background:#ffebee;border:1px solid #ffcdd2;border-radius:4px;color:#c62828;display:flex;font-size:14px;gap:8px;margin-top:16px;padding:12px 16px}.error-message span{font-size:18px}.file-import-info{border-top:1px solid #e0e0e0;margin-top:24px;padding-top:20px}.file-import-info h4{color:#555;font-size:14px;font-weight:600;margin:0 0 12px}.file-import-info ul{color:#666;font-size:13px;margin:0;padding-left:20px}.file-import-info li{line-height:1.4;margin-bottom:6px}.backend-upload-option{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:16px;padding:12px}.backend-upload-option label{align-items:center;cursor:pointer;display:flex;gap:10px;-webkit-user-select:none;user-select:none}.backend-upload-option input[type=checkbox]{cursor:pointer;height:18px;width:18px}.backend-upload-option span{color:#555;font-size:14px;font-weight:500}.progress-bar{background:#e0e0e0;border-radius:3px;height:6px;margin-top:16px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#4caf50,#66bb6a);border-radius:3px;height:100%;transition:width .3s ease}@media (max-width:640px){.file-import-container{margin:10px;max-width:100%;min-width:auto;padding:15px}.file-dropzone{min-height:150px;padding:30px 15px}.upload-icon{font-size:36px}.dropzone-content h4{font-size:16px}.supported-formats{font-size:12px}.backend-upload-option{padding:10px}.backend-upload-option span{font-size:13px}}.folder-selector{position:relative;width:100%}.folder-selector.disabled{opacity:.5;pointer-events:none}.folder-selector-trigger{align-items:center;background:#1a202c;border:1px solid #4a5568;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;min-height:38px;padding:8px 12px;transition:all .2s ease}.folder-selector-trigger:hover{border-color:#63b3ed}.folder-selector-trigger.open{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.folder-selector-value{align-items:center;color:#e2e8f0;display:flex;gap:8px}.folder-selector-placeholder{color:#718096}.folder-selector-arrow{color:#718096;transition:transform .2s ease}.folder-selector-arrow.open{transform:rotate(180deg)}.folder-selector-small .folder-selector-trigger{font-size:12px;min-height:30px;padding:4px 8px}.folder-selector-large .folder-selector-trigger{font-size:15px;min-height:46px;padding:12px 16px}.folder-selector-light .folder-selector-trigger{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#374151;font-size:.875rem;min-height:auto;padding:.625rem .875rem}.folder-selector-light .folder-selector-trigger:hover{border-color:#8b5cf6}.folder-selector-light .folder-selector-trigger.open{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.folder-selector-light .folder-selector-value{color:#374151;font-size:.875rem}.folder-selector-light .folder-selector-placeholder{color:#9ca3af;font-size:.875rem}.folder-selector-light .folder-selector-arrow{color:#6b7280}.folder-selector-light .folder-selector-dropdown{background:#fff;border:1px solid #e2e8f0;box-shadow:0 10px 40px #00000026}.folder-selector-light .folder-selector-option{color:#374151}.folder-selector-light .folder-selector-option:hover{background:#667eea1a}.folder-selector-light .folder-selector-option.selected{background:#667eea26}.folder-selector-light .folder-selector-option.default-folder{border-top:1px solid #e2e8f0}.folder-selector-light .folder-selector-option .default-badge{background:#6b72801a;color:#6b7280}.folder-selector-light .folder-selector-divider{background:#e2e8f0}.folder-selector-light .folder-selector-option.create-option{color:#667eea}.folder-selector-light .folder-selector-option.create-option:hover{background:#667eea1a}.folder-selector-light .folder-create-form{border-top:1px solid #e2e8f0}.folder-selector-light .folder-create-input{background:#f9fafb;border:1px solid #e2e8f0;color:#374151}.folder-selector-light .folder-create-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea26}.folder-selector-light .folder-create-input::placeholder{color:#9ca3af}.folder-selector-light .folder-color-option.selected{border-color:#374151;box-shadow:0 0 0 2px #37415133}.folder-selector-light .folder-btn-cancel{background:#f3f4f6;color:#6b7280}.folder-selector-light .folder-btn-cancel:hover{background:#e5e7eb;color:#374151}.folder-selector-light .folder-btn-create{background:#667eea;color:#fff}.folder-selector-light .folder-btn-create:hover{background:#5a67d8}.folder-selector-light .folder-btn-create:disabled{background:#d1d5db}.folder-selector-dropdown{animation:dropdownFadeIn .15s ease-out;background:#1e2533;border:1px solid #4a5568;border-radius:8px;box-shadow:0 10px 40px #0006;left:0;max-height:320px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.folder-selector-option{align-items:center;color:#e2e8f0;cursor:pointer;display:flex;gap:10px;padding:10px 12px;transition:background .15s ease}.folder-selector-option:hover{background:#3b82f626}.folder-selector-option.selected{background:#3b82f633}.folder-selector-option.default-folder{border-top:1px solid #4a5568}.folder-selector-option .folder-icon{font-size:16px}.folder-selector-option .folder-name{flex:1 1}.folder-selector-option .default-badge{background:#71809633;border-radius:4px;color:#718096;font-size:10px;padding:2px 6px}.folder-selector-divider{background:#4a5568;height:1px;margin:4px 0}.folder-selector-option.create-option{color:#63b3ed;font-weight:500}.folder-selector-option.create-option:hover{background:#63b3ed26}.folder-selector-option .create-icon{font-size:18px;font-weight:700}.folder-color-dot{border-radius:50%;flex-shrink:0;height:12px;width:12px}.folder-create-form{border-top:1px solid #4a5568;padding:12px}.folder-create-input-row{margin-bottom:10px}.folder-create-input{background:#1a202c;border:1px solid #4a5568;border-radius:4px;color:#e2e8f0;font-size:13px;outline:none;padding:8px 10px;width:100%}.folder-create-input:focus{border-color:#3b82f6}.folder-create-input::placeholder{color:#718096}.folder-color-picker{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.folder-color-option{border:2px solid #0000;border-radius:50%;cursor:pointer;height:22px;transition:all .15s ease;width:22px}.folder-color-option:hover{transform:scale(1.15)}.folder-color-option.selected{border-color:#fff;box-shadow:0 0 0 2px #ffffff4d}.folder-color-option.large{height:32px;width:32px}.folder-create-actions{display:flex;gap:8px;justify-content:flex-end}.folder-manager-overlay{align-items:center;animation:overlayFadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.folder-manager-modal{animation:modalSlideIn .25s ease-out;background:#1e2533;border-radius:12px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;max-height:80vh;max-width:480px;width:100%}.folder-manager-header{align-items:center;border-bottom:1px solid #3d4756;display:flex;justify-content:space-between;padding:16px 20px}.folder-manager-header h3{color:#e2e8f0;font-size:18px;font-weight:600;margin:0}.folder-manager-close{background:none;border:none;color:#718096;cursor:pointer;font-size:24px;line-height:1;padding:0;transition:color .15s ease}.folder-manager-close:hover{color:#e2e8f0}.folder-manager-body{flex:1 1;overflow-y:auto;padding:16px 20px}.folder-manager-footer{border-top:1px solid #3d4756;display:flex;gap:10px;justify-content:flex-end;padding:16px 20px}.folder-create-btn{align-items:center;background:#3b82f626;border:2px dashed #3b82f6;border-radius:8px;color:#63b3ed;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;margin-bottom:16px;padding:12px;transition:all .2s ease;width:100%}.folder-create-btn:hover{background:#3b82f640;border-color:#63b3ed}.folder-create-btn .plus-icon{font-size:20px;font-weight:700}.folder-list{display:flex;flex-direction:column;gap:8px}.folder-list-item{align-items:center;background:#252d3b;border-radius:8px;display:flex;justify-content:space-between;padding:12px 14px;transition:background .15s ease}.folder-list-item:hover{background:#2d3748}.folder-list-item.default{background:#1a202c;border:1px solid #3d4756}.folder-list-item-info{align-items:center;display:flex;flex:1 1;gap:10px;min-width:0}.folder-color-indicator{border-radius:4px;flex-shrink:0;height:14px;width:14px}.folder-list-item-name{color:#e2e8f0;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-list-item-count{color:#718096;flex-shrink:0;font-size:12px}.default-tag{background:#a0aec026;border-radius:4px;color:#a0aec0;flex-shrink:0;font-size:10px;padding:2px 8px}.folder-list-item-actions{align-items:center;display:flex;gap:6px;margin-left:10px}.folder-action-btn{align-items:center;background:#ffffff0d;border:none;border-radius:4px;color:#a0aec0;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .15s ease;width:28px}.folder-action-btn:hover{background:#ffffff1a;color:#e2e8f0}.folder-action-btn.edit:hover{background:#3b82f633;color:#63b3ed}.folder-action-btn.delete:hover{background:#ef444433;color:#fc8181}.folder-action-btn.confirm{background:#10b98133;color:#34d399}.folder-action-btn.cancel{background:#ef444433;color:#fc8181}.delete-confirm-text{color:#f6ad55;font-size:11px;margin-right:8px}.folder-empty-state{color:#718096;padding:24px;text-align:center}.folder-empty-state p{font-size:13px;margin:0}.folder-form{gap:20px}.folder-form,.folder-form-group{display:flex;flex-direction:column}.folder-form-group{gap:8px}.folder-form-group label{color:#a0aec0;font-size:13px;font-weight:500}.folder-form-input{background:#1a202c;border:1px solid #4a5568;border-radius:6px;color:#e2e8f0;font-size:14px;outline:none;padding:10px 12px;transition:border-color .15s ease}.folder-form-input:focus{border-color:#3b82f6}.folder-form-input::placeholder{color:#718096}.folder-color-grid{display:flex;flex-wrap:wrap;gap:10px}.folder-preview{align-items:center;background:#252d3b;border-radius:6px;color:#e2e8f0;display:flex;font-size:14px;gap:10px;padding:12px 14px}.folder-btn{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .15s ease}.folder-btn:disabled{cursor:not-allowed;opacity:.5}.folder-btn-cancel,.folder-btn-close{background:#2d3748;color:#a0aec0}.folder-btn-cancel:hover,.folder-btn-close:hover{background:#4a5568;color:#e2e8f0}.folder-btn-create,.folder-btn-save{background:#3b82f6;color:#fff}.folder-btn-create:hover,.folder-btn-save:hover{background:#2563eb}.folder-btn-create:disabled,.folder-btn-save:disabled{background:#4a5568}.folder-card{margin-bottom:12px;transition:border-color .2s ease}.folder-card-info{align-items:center;display:flex;gap:12px}.folder-card-color{border-radius:4px;height:18px;width:18px}.folder-card-count{color:#718096;font-size:13px;margin-left:8px}.folder-card-toggle{align-items:center;color:#718096;display:flex;justify-content:center;transition:transform .2s ease}.folder-card-toggle.expanded{transform:rotate(180deg)}.folder-card-content{display:none;padding:12px 16px}.folder-card-content.expanded{display:block}.folder-card-empty{color:#718096;font-size:13px;padding:20px;text-align:center}.folder-header-bar{background:#1a202c;border-radius:8px}.folder-header-title{align-items:center;display:flex;gap:10px}.folder-header-title svg{color:#63b3ed}.folder-header-actions{align-items:center;display:flex;gap:8px}.folder-header-btn{align-items:center;background:#2d3748;border:none;border-radius:6px;color:#a0aec0;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:8px 12px;transition:all .15s ease}.folder-header-btn:hover{background:#4a5568;color:#e2e8f0}.folder-header-btn.primary{background:#3b82f6;color:#fff}.folder-header-btn.primary:hover{background:#2563eb}.move-to-folder-menu{position:absolute;z-index:1000}.move-to-folder-header{border-bottom:1px solid #4a5568;color:#718096;font-size:12px;font-weight:600;padding:10px 12px;text-transform:uppercase}.move-to-folder-option{align-items:center;color:#e2e8f0;cursor:pointer;display:flex;gap:10px;padding:10px 12px;transition:background .15s ease}.move-to-folder-option:hover{background:#3b82f626}.move-to-folder-option.current{background:#3b82f61a;pointer-events:none}.move-to-folder-option .current-badge{color:#63b3ed;font-size:10px;margin-left:auto}.folder-header-bar{align-items:center;background:linear-gradient(135deg,#1a202c,#252d3b);border:1px solid #3d4756;border-radius:10px;display:flex;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.folder-header-left{align-items:center;display:flex;gap:10px}.folder-header-left svg{color:#63b3ed}.folder-header-title{color:#e2e8f0;font-size:16px;font-weight:600}.folder-count-badge{background:#3b82f633;border-radius:10px;color:#63b3ed;font-size:12px;font-weight:600;padding:2px 8px}.folder-header-right{align-items:center;display:flex;gap:10px}.folder-filter-select{background:#1a202c;border:1px solid #4a5568;border-radius:6px;color:#e2e8f0;cursor:pointer;font-size:13px;min-width:160px;outline:none;padding:8px 12px}.folder-filter-select:hover{border-color:#63b3ed}.folder-filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.btn-folder-manage{align-items:center;background:#2d3748;border:1px solid #4a5568;border-radius:6px;color:#a0aec0;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .15s ease}.btn-folder-manage:hover{background:#3d4756;border-color:#63b3ed;color:#e2e8f0}.btn-folder-manage svg{opacity:.8}.folders-container{display:flex;flex-direction:column;gap:12px}.folder-grid-container{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(6,1fr);margin-bottom:24px}@media (max-width:1400px){.folder-grid-container{grid-template-columns:repeat(5,1fr)}}@media (max-width:1200px){.folder-grid-container{grid-template-columns:repeat(4,1fr)}}@media (max-width:900px){.folder-grid-container{grid-template-columns:repeat(3,1fr)}}.folder-grid-item{align-items:center;background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #00000014;cursor:pointer;display:flex;flex-direction:column;padding:20px 12px;transition:all .2s ease}.folder-grid-item:hover{background:#f8fafc;border-color:#cbd5e1;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.folder-grid-item.selected{background:#fffbeb;border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b33}.folder-grid-icon{height:64px;margin-bottom:12px;width:64px}.folder-grid-name{color:#222427e9;font-size:14px;font-weight:600;margin-bottom:4px;max-width:100%;overflow:hidden;text-align:center;text-overflow:ellipsis;white-space:nowrap}.folder-grid-count{color:#718096;font-size:12px}.folder-popup-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.folder-popup-modal{animation:folderPopupSlideIn .2s ease-out;background:#1a202c;border:1px solid #3d4756;border-radius:16px;box-shadow:0 25px 50px -12px #00000080;display:flex;flex-direction:column;max-height:80vh;max-width:900px;width:90%}@keyframes folderPopupSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.folder-popup-header{align-items:center;background:#252d3b;border-bottom:1px solid #3d4756;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.folder-popup-title{align-items:center;display:flex;gap:12px}.folder-popup-title h3{color:#e2e8f0;font-size:18px;font-weight:600;margin:0}.folder-popup-body{flex:1 1;overflow-y:auto;padding:24px}.folder-popup-body::-webkit-scrollbar{width:8px}.folder-popup-body::-webkit-scrollbar-track{background:#1a202c;border-radius:4px}.folder-popup-body::-webkit-scrollbar-thumb{background:#4a5568;border-radius:4px}.folder-popup-body::-webkit-scrollbar-thumb:hover{background:#718096}.folder-datasets-section{background:#1e2533;border:1px solid #3d4756;border-radius:12px;margin-bottom:20px;overflow:hidden}.folder-datasets-header{align-items:center;background:#252d3b;border-bottom:1px solid #3d4756;display:flex;justify-content:space-between;padding:16px 20px}.folder-datasets-title{align-items:center;display:flex;gap:12px}.folder-datasets-title h3{color:#e2e8f0;font-size:16px;font-weight:600;margin:0}.folder-header-icon{height:28px;width:28px}.folder-datasets-count{background:#71809626;border-radius:12px;color:#718096;font-size:13px;padding:4px 10px}.btn-close-folder{align-items:center;background:#0000;border:1px solid #4a5568;border-radius:6px;color:#a0aec0;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s ease;width:32px}.btn-close-folder:hover{background:#2d3748;border-color:#718096;color:#e2e8f0}.folder-card{background:#1e2533;border:1px solid #3d4756;border-radius:10px;overflow:hidden;transition:all .2s ease}.folder-card:hover{border-color:#4a5568}.folder-card.expanded{border-color:#4a5568;box-shadow:0 4px 20px #0003}.folder-card-header{align-items:center;background:#252d3b;cursor:pointer;display:flex;justify-content:space-between;padding:14px 16px;transition:background .15s ease;-webkit-user-select:none;user-select:none}.folder-card-header:hover{background:#2d3748}.folder-card-left{align-items:center;display:flex;gap:12px}.folder-icon-img{flex-shrink:0;height:24px;width:24px}.folder-card-name{color:#e2e8f0;font-size:15px;font-weight:600}.default-folder-badge{background:#a0aec026;border-radius:4px;color:#a0aec0;font-size:10px;padding:2px 8px}.folder-card-right{align-items:center;display:flex;gap:12px}.folder-dataset-count{color:#718096;font-size:13px}.folder-expand-icon{color:#718096;transition:transform .2s ease}.folder-expand-icon.expanded{transform:rotate(180deg)}.folder-card-content{background:#1a202c;border-top:1px solid #3d4756;padding:16px}.folder-empty{color:#718096;padding:24px;text-align:center}.folder-empty p{font-size:13px;margin:0}.folder-datasets-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.move-to-folder-menu{animation:dropdownFadeIn .15s ease-out;background:#1e2533;border:1px solid #4a5568;border-radius:8px;box-shadow:0 10px 40px #0006;max-height:280px;min-width:200px;overflow-y:auto}.move-menu-header{border-bottom:1px solid #4a5568;color:#718096;font-size:11px;font-weight:600;letter-spacing:.5px;padding:10px 12px;text-transform:uppercase}.move-menu-item{align-items:center;color:#e2e8f0;cursor:pointer;display:flex;font-size:13px;gap:10px;padding:10px 12px;transition:background .15s ease}.move-menu-item:hover{background:#3b82f626}.move-menu-item.current{background:#3b82f61a;color:#63b3ed}.move-menu-item svg{color:#63b3ed;margin-left:auto}.btn-action-move{background:#3b82f61a;color:#63b3ed}.btn-action-move:hover{background:#3b82f633;transform:scale(1.05)}.ownership-badge.field-user{background:#f59e0b26;border:1px solid #f59e0b4d;color:#f59e0b}.folder-manager-body::-webkit-scrollbar,.folder-selector-dropdown::-webkit-scrollbar,.move-to-folder-menu::-webkit-scrollbar{width:6px}.folder-manager-body::-webkit-scrollbar-track,.folder-selector-dropdown::-webkit-scrollbar-track,.move-to-folder-menu::-webkit-scrollbar-track{background:#0000}.folder-manager-body::-webkit-scrollbar-thumb,.folder-selector-dropdown::-webkit-scrollbar-thumb,.move-to-folder-menu::-webkit-scrollbar-thumb{background:#4a5568;border-radius:3px}.folder-manager-body::-webkit-scrollbar-thumb:hover,.folder-selector-dropdown::-webkit-scrollbar-thumb:hover,.move-to-folder-menu::-webkit-scrollbar-thumb:hover{background:#718096}.btn-folder-compact{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:400;gap:.5rem;justify-content:center;padding:.625rem 1.25rem;transition:all .2s ease;white-space:nowrap}.btn-folder-compact:hover{background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-folder-compact:active{box-shadow:0 2px 6px #667eea4d;transform:translateY(0)}.btn-folder-compact svg{flex-shrink:0}.tab-actions-divider{display:none}.folder-filter-bar{align-items:center;background:#1a202c;border:1px solid #3d4756;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:16px;padding:10px 14px}.folder-filter-left{align-items:center;display:flex;gap:8px}.folder-filter-left svg{color:#63b3ed;flex-shrink:0}.folder-filter-label{color:#a0aec0;font-size:14px;font-weight:500}.folder-filter-select-compact{background:#252d3b;border:1px solid #4a5568;border-radius:5px;color:#e2e8f0;cursor:pointer;font-size:12px;min-width:140px;outline:none;padding:6px 10px;transition:all .15s ease}.folder-filter-select-compact:hover{border-color:#63b3ed}.folder-filter-select-compact:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.folder-filter-select-header{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 3px #0000001a;color:#374151;cursor:pointer;font-size:.875rem;font-weight:500;min-width:160px;outline:none;padding:.625rem 36px .625rem 1rem;transition:all .2s ease}.folder-filter-select-header:hover{border-color:#667eea;box-shadow:0 2px 6px #667eea26}.folder-filter-select-header:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea33}.folder-filter-select-header option{background:#fff;color:#374151;font-size:.875rem;padding:10px 12px}.folder-filter-select-header option:checked,.folder-filter-select-header option:hover{background:#3b82f6;color:#fff}.upload-data-modal-container{background:#2a2f38;border:1px solid #3c414c;border-radius:8px;box-shadow:0 8px 32px #0006;margin:0 auto;max-width:500px;width:90vw}.upload-modal-header{align-items:center;background:#242730;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;padding:16px 20px}.upload-modal-header h3{color:#f7f8fa;font-size:18px;font-weight:600;margin:0;text-shadow:0 1px 2px #0000004d}.upload-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.upload-close-btn:hover{background:#ffffff0d;color:#f7f8fa}.upload-modal-body{padding:20px}.upload-form-group{margin-bottom:16px}.upload-form-group label{color:#a0a7b4;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.upload-form-control{background:#353a44;border:1px solid #3c414c;border-radius:6px;color:#f7f8fa;font-size:14px;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.upload-form-control:focus{background:#353a44;border-color:#5b9bf4;box-shadow:0 0 0 3px #5b9bf433;outline:none}.upload-form-control:disabled{background:#2a2f38;color:#6b7280;cursor:not-allowed;opacity:.5}.format-locked-message{display:flex;flex-direction:column;gap:6px}.format-locked-message .upload-form-control{opacity:.7}.format-note{color:#63b3ed;display:block;font-size:11px;font-style:italic;padding-left:2px}.upload-form-control::placeholder{color:#6b7280}.save-location-options{display:flex;gap:12px}.save-location-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#242730;border:2px solid #3c414c;border-radius:8px;cursor:pointer;flex:1 1;padding:14px;position:relative;transition:all .2s}.save-location-card input[type=radio]{opacity:0;pointer-events:none;position:absolute}.save-location-card:hover{background:#5b9bf414;border-color:#5b9bf4;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.save-location-card.selected{background:linear-gradient(135deg,#5b9bf426,#5b9bf414);border-color:#5b9bf4;box-shadow:0 0 0 3px #5b9bf433,0 4px 16px #0000004d}.location-header{align-items:center;display:flex;gap:8px;margin-bottom:6px}.toggle-arrow{color:#6b7280;transition:transform .3s cubic-bezier(.4,0,.2,1),color .2s}.save-location-card.selected .toggle-arrow{color:#5b9bf4;transform:rotate(90deg)}.location-title{color:#a0a7b4;font-size:14px;font-weight:600}.save-location-card.selected .location-title{color:#f7f8fa}.location-description{color:#6b7280;display:block;font-size:12px;line-height:1.4}.save-location-card.selected .location-description{color:#a0a7b4}.upload-modal-footer{background:#242730;border-radius:0 0 8px 8px;border-top:1px solid #3c414c;display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.btn-primary{background:linear-gradient(135deg,#5b9bf4,#4a8fe7);box-shadow:0 2px 8px #5b9bf44d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#4a8fe7,#3d7ed8);box-shadow:0 4px 12px #5b9bf466}.btn-primary:active:not(:disabled){background:linear-gradient(135deg,#3d7ed8,#2d6ec9)}.upload-export-dialog-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10010}.upload-export-dialog{background:#29323c;border-radius:4px;box-shadow:0 8px 32px #00000080;max-width:90vw;overflow:hidden;width:380px}.upload-export-dialog .upload-export-header{align-items:center;background:#3a4552;border-bottom:1px solid #3a4552;display:flex;justify-content:space-between;padding:12px 16px}.upload-export-dialog .upload-export-title{align-items:center;display:flex;gap:8px}.upload-export-dialog .upload-export-title svg{color:#6a7485}.upload-export-dialog .upload-export-header h3{color:#a0a7b4;font-size:13px;font-weight:500;letter-spacing:.5px;margin:0;text-transform:uppercase}.upload-export-dialog .upload-export-close{align-items:center;background:none;border:none;border-radius:2px;color:#6a7485;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;width:24px}.upload-export-dialog .upload-export-close:hover{background:#ffffff14;color:#f7f8fa}.upload-export-dialog .upload-export-body{background:#29323c;padding:16px}.upload-export-dialog .upload-export-info{align-items:flex-start;background:#242730;border-radius:2px;display:flex;gap:8px;margin-bottom:12px;padding:10px 12px}.upload-export-dialog .upload-export-info svg{color:#6a7485;flex-shrink:0;margin-top:2px}.upload-export-dialog .upload-export-info span{color:#6a7485;font-size:11px;line-height:1.5}.upload-export-dialog .upload-export-options{display:flex;flex-direction:column;gap:8px}.upload-export-dialog .upload-export-btn{align-items:center;background:#3a4552;border:1px solid #4a5568;border-radius:2px;color:#a0a7b4;cursor:pointer;display:flex;gap:12px;padding:12px;text-align:left;transition:all .15s ease;width:100%}.upload-export-dialog .upload-export-btn:hover:not(:disabled){background:#4a5568;border-color:#5b9bf4}.upload-export-dialog .upload-export-btn:active:not(:disabled){background:#3a4552}.upload-export-dialog .upload-export-btn:disabled{cursor:not-allowed;opacity:.5}.upload-export-dialog .upload-export-btn.csv-btn:hover:not(:disabled){border-color:#77b96c}.upload-export-dialog .upload-export-btn.xlsx-btn:hover:not(:disabled){border-color:#5b9bf4}.upload-export-dialog .upload-export-icon{align-items:center;background:#29323c;border-radius:2px;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.upload-export-dialog .csv-btn .upload-export-icon{color:#77b96c}.upload-export-dialog .xlsx-btn .upload-export-icon{color:#5b9bf4}.upload-export-dialog .upload-export-content{display:flex;flex:1 1;flex-direction:column;gap:2px}.upload-export-dialog .upload-export-text{display:flex;flex-direction:column;gap:2px}.upload-export-dialog .upload-export-text strong{color:#f7f8fa;font-size:12px;font-weight:500}.upload-export-dialog .upload-export-text span{color:#6a7485;font-size:10px}.upload-export-dialog .upload-export-badge{align-items:center;border-radius:2px;display:inline-flex;font-size:9px;font-weight:500;letter-spacing:.3px;margin-top:4px;padding:2px 6px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.upload-export-dialog .upload-export-badge.csv{background:#77b96c26;color:#77b96c}.upload-export-dialog .upload-export-badge.xlsx{background:#5b9bf426;color:#5b9bf4}.upload-export-dialog .upload-export-arrow{color:#4a5568;flex-shrink:0;transition:all .15s ease}.upload-export-dialog .upload-export-btn:hover:not(:disabled) .upload-export-arrow{color:#a0a7b4;transform:translateX(2px)}.upload-export-dialog .csv-btn:hover:not(:disabled) .upload-export-arrow{color:#77b96c}.upload-export-dialog .xlsx-btn:hover:not(:disabled) .upload-export-arrow{color:#5b9bf4}@media (max-width:640px){.upload-data-modal-container{max-width:95vw}.save-location-options{flex-direction:column}.upload-modal-footer{flex-direction:column-reverse}.btn{width:100%}.export-dialog{width:95vw}}.add-data-modal-container{background:#2a2f38;border:1px solid #3c414c;border-radius:8px;box-shadow:0 8px 32px #0006;margin:0 auto;max-width:600px;width:90vw}.add-data-modal-header{align-items:center;background:#242730;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;padding:16px 20px}.add-data-modal-header h3{color:#f7f8fa;font-size:18px;font-weight:600;margin:0;text-shadow:0 1px 2px #0000004d}.add-data-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.add-data-close-btn:hover{background:#ffffff0d;color:#f7f8fa}.add-data-modal-body{padding:20px}.data-source-tabs{border-bottom:1px solid #3c414c;display:flex;gap:0;margin-bottom:20px}.data-source-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#a0a7b4;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px 16px;transition:all .2s ease}.data-source-tab.active{border-bottom-color:#1f7cf4;color:#1f7cf4}.data-source-tab:hover{background:#1f7cf40d;color:#f7f8fa}.tab-content{animation:fadeIn .3s ease;display:none}.tab-content.active{display:block}.file-drop-zone{background:#ffffff03;border:2px dashed #3c414c;border-radius:8px;cursor:pointer;padding:40px 20px;text-align:center;transition:all .3s ease}.file-drop-zone:hover{background:#1f7cf405;border-color:#1f7cf4}.file-drop-zone.drag-over{background:#1f7cf40d;border-color:#1f7cf4;transform:scale(1.02)}.drop-zone-content h4{color:#f7f8fa;font-size:16px;font-weight:600;margin:0 0 8px}.drop-zone-content p{color:#a0a7b4;font-size:14px;margin:0 0 16px}.supported-formats{background:#242730;border-radius:6px;color:#a0a7b4;font-size:13px;margin:16px 0;padding:12px}.supported-formats strong{color:#f7f8fa;margin-right:8px}.format-list{color:#6b7280}.server-data-section,.server-selector-section{text-align:center}.server-selector-section h4{color:#f7f8fa;font-size:16px;font-weight:600;margin:0 0 16px}.server-layer-selector label{color:#a0a7b4}.server-layers-list{margin-top:24px}.server-data-list{background:#242730;border:1px solid #3c414c;border-radius:6px;max-height:300px;overflow-y:auto}.server-layer-item{align-items:center;border-bottom:1px solid #3c414c;display:flex;gap:12px;justify-content:space-between;padding:12px 16px;transition:background .2s}.server-layer-item:last-child{border-bottom:none}.server-layer-item:hover{background:#1f7cf40d}.server-layer-item.is-favorite{background:#facc150d;border-left:3px solid #facc15}.server-layer-item.is-favorite:hover{background:#facc151a}.favorite-btn{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:6px;transition:all .2s ease}.favorite-btn:hover{background:#facc151a;color:#facc15}.favorite-btn.active{color:#facc15}.favorite-btn.active:hover{color:#eab308}.favorite-btn:disabled{cursor:not-allowed;opacity:.5}.favorite-btn svg{transition:transform .2s ease}.favorite-btn:hover svg{transform:scale(1.1)}.favorite-btn.active svg{filter:drop-shadow(0 0 4px rgba(250,204,21,.5))}.favorite-badge{background:#facc1526;border-radius:4px;color:#facc15;display:inline-block;font-size:10px;font-weight:600;letter-spacing:.5px;margin-left:8px;padding:2px 6px;text-transform:uppercase}.layer-info{flex:1 1;min-width:0;text-align:left}.layer-name{align-items:center;color:#f7f8fa;display:flex;flex-wrap:wrap;font-size:14px;font-weight:600;gap:4px;margin-bottom:4px}.layer-meta{color:#6b7280;font-size:12px}.empty-state,.loading-state{color:#a0a7b4;font-size:14px;padding:40px 20px}.remote-data-section{text-align:center}.remote-data-section h4{color:#f7f8fa;font-size:16px;font-weight:600;margin:0 0 16px}.remote-data-section label{color:#a0a7b4}.form-control{background:#353a44;border:1px solid #3c414c;border-radius:6px;box-sizing:border-box;color:#f7f8fa;font-size:14px;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.form-control:focus{background:#353a44;border-color:#1f7cf4;box-shadow:0 0 0 3px #1f7cf433;outline:none}.form-control:disabled{background:#2a2f38;color:#6b7280;cursor:not-allowed;opacity:.5}.form-control::placeholder{color:#6b7280}.add-data-modal-footer{background:#242730;border-radius:0 0 8px 8px;border-top:1px solid #3c414c;display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.btn-small{font-size:12px;padding:6px 12px}@media (max-width:640px){.add-data-modal-container{max-width:95vw}.data-source-tabs{border-bottom:none;flex-direction:column}.data-source-tab{border-bottom:1px solid #3c414c;border-left:2px solid #0000}.data-source-tab.active{border-bottom-color:#3c414c;border-left-color:#1f7cf4}.add-data-modal-footer{flex-direction:column-reverse}.btn{width:100%}}#route-management-modal{display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:90vw}#route-management-modal .modal-header{align-items:center;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;margin-bottom:16px;padding:0 0 16px}#route-management-modal .modal-header h3{color:#f7f8fa;font-size:18px;font-weight:600;margin:0}#route-management-modal .modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:32px}#route-management-modal .modal-close:hover{background:#ffffff0d;color:#f7f8fa}#route-management-modal .modal-body{flex:1 1;min-height:0;overflow-y:auto}#route-management-modal .route-management-panel{background:#0000;border:none;box-shadow:none;margin:0;padding:0;width:100%}#route-management-modal .panel-header{display:none}#route-management-modal .panel-content{max-height:none;overflow:visible;padding:0}#route-management-modal .route-creation-section,#route-management-modal .saved-routes-section{margin-bottom:20px}.route-getting-started{padding:40px 20px;text-align:center}.route-getting-started h4{color:#f7f8fa;font-size:20px;margin-bottom:12px}.route-getting-started p{color:#a0a7b4;font-size:14px;line-height:1.5;margin-bottom:20px}#route-management-modal .btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:inline-flex;font-size:12px;gap:6px;justify-content:center;padding:8px 16px;transition:all .2s ease}#route-management-modal .btn-primary{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;box-shadow:0 2px 8px #1f7cf44d;color:#fff}#route-management-modal .btn-primary:hover{background:linear-gradient(135deg,#0d47a1,#083d8a);box-shadow:0 4px 12px #1f7cf466;transform:translateY(-1px)}#route-management-modal .btn-secondary{background:#242730;border:1px solid #3c414c;color:#a0a7b4}#route-management-modal .btn-secondary:hover{background:#2a2f38;border-color:#4a5568;color:#f7f8fa}#route-management-modal .btn-outline{background:#0000;border:1px solid #3c414c;color:#a0a7b4}#route-management-modal .btn-outline:hover{background:#ffffff0d;border-color:#4a5568;color:#f7f8fa}#route-management-modal .form-group{margin-bottom:16px}#route-management-modal .form-group label{color:#a0a7b4;display:block;font-size:12px;font-weight:600;margin-bottom:6px}#route-management-modal .form-control{background:#353a44;border:1px solid #3c414c;border-radius:4px;color:#f7f8fa;font-size:12px;padding:8px 12px;transition:all .2s;width:100%}#route-management-modal .form-control:focus{background:#353a44;border-color:#1f7cf4;box-shadow:0 0 0 3px #1f7cf433;outline:none}#route-management-modal .form-control::placeholder{color:#6b7280}#route-management-modal .section-header{align-items:center;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}#route-management-modal .section-header h5{color:#f7f8fa;font-size:14px;font-weight:600;margin:0}@media (max-width:768px){#route-management-modal{max-height:95vh;width:95vw}#route-management-modal .modal-body{padding:5px}}@media (prefers-color-scheme:dark){#route-management-modal .form-control{background:#353a44;border-color:#3c414c}}.route-modal-dialog{margin:2vh auto!important;max-width:800px!important;width:90vw!important}.modal-dialog.route-modal-dialog,.modal-dialog:has(#route-management-modal){margin:2vh auto;max-width:800px;width:90vw}.waypoint-item{align-items:center;background:#2a2f3899;border:1px solid #3c414c;border-radius:4px;cursor:pointer;gap:12px;margin:4px 0;padding:8px}.waypoint-item:hover{background:#2a2f38e6;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf44d}.waypoint-item.selected{background:#1f7cf426;border-color:#1f7cf4;box-shadow:0 2px 8px #1f7cf466}.waypoint-marker{background:#1f7cf4;box-shadow:0 2px 6px #1f7cf466;color:#fff;font-size:12px;font-weight:700;height:24px;width:24px}.waypoint-item.selected .waypoint-marker{background:#0d47a1}.waypoint-info{flex:1 1}.waypoint-name{color:#f7f8fa;font-size:13px;font-weight:500;margin-bottom:2px}.waypoint-coords{color:#a0a7b4;font-family:monospace;font-size:11px}.waypoint-remove{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:3px;color:#ef4444;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:20px;justify-content:center;transition:all .2s ease;width:20px}.waypoint-remove:hover{background:#ef444433;border-color:#ef4444;box-shadow:0 2px 6px #ef444466}.map-routing-mode{cursor:crosshair!important}.map-routing-mode:after{background:#000c;border-radius:20px;color:#fff;content:"🗺️ Click to add waypoint";font-size:14px;left:50%;padding:8px 16px;pointer-events:none;position:absolute;top:10px;transform:translateX(-50%);z-index:1000}.waypoints-header{border-bottom:1px solid #3c414c;margin-bottom:12px;padding-bottom:8px}.waypoints-header h6{color:#f7f8fa;font-size:14px;margin:0 0 4px}.waypoints-header small{color:#a0a7b4;font-size:12px;line-height:1.4}.empty-waypoints{color:#6b7280;font-style:italic;padding:20px;text-align:center}.waypoints-list{max-height:200px;overflow-y:auto;padding:4px 0}.modal-overlay{animation:fadeIn .2s ease-out;background:#000000b3}.add-column-modal-container{animation:modalSlideIn .3s ease-out;background:#2a2f38;border:1px solid #3c414c;border-radius:8px;box-shadow:0 8px 32px #0006;margin:0 auto;max-width:500px;width:90vw}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.add-column-modal-header{align-items:center;background:#242730;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;padding:16px 20px}.add-column-modal-header h3{color:#f7f8fa;font-size:18px;font-weight:600;margin:0;text-shadow:0 1px 2px #0000004d}.add-column-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:all .2s;width:32px}.add-column-close-btn:hover{background:#ffffff0d;color:#f7f8fa}.modal-body{max-height:calc(90vh - 140px);padding:20px}.modal-body::-webkit-scrollbar{width:8px}.modal-body::-webkit-scrollbar-track{background:#242730}.modal-body::-webkit-scrollbar-thumb{background:#3c414c;border-radius:4px}.modal-body::-webkit-scrollbar-thumb:hover{background:#4a5568}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{color:#a0a7b4;display:block;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:8px}.form-input,.form-select{background:#353a44;border:1px solid #3c414c;border-radius:6px;box-sizing:border-box;color:#f7f8fa;font-size:14px;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.form-input::placeholder{color:#6b7280}.form-input:focus,.form-select:focus{background:#353a44;border-color:#1f7cf4;box-shadow:0 0 0 3px #1f7cf433;outline:none}.form-input:disabled,.form-select:disabled{background:#2a2f38;color:#6b7280;opacity:.5}.form-select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23a0a7b4' d='M6 9 1 4h10z'/%3E%3C/svg%3E");padding-right:36px}.form-select option{background:#2a2f38;color:#f7f8fa}.form-hint{color:#6b7280;display:block;font-size:12px;font-style:italic;line-height:1.4;margin-top:6px}.add-column-modal-footer{background:#242730;border-radius:0 0 8px 8px;border-top:1px solid #3c414c;display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.btn{font-size:14px;font-weight:500;outline:none;padding:10px 20px;transition:all .2s}.btn:disabled{opacity:.4}.btn-primary{background:linear-gradient(135deg,#1f7cf4,#0d47a1);box-shadow:0 2px 8px #1f7cf44d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#0d47a1,#083d8a);box-shadow:0 4px 12px #1f7cf466;transform:translateY(-1px)}.btn-primary:active:not(:disabled){background:linear-gradient(135deg,#083d8a,#062d6b);transform:translateY(0)}.btn-secondary{background:#242730;border:1px solid #3c414c;color:#a0a7b4}.btn-secondary:hover:not(:disabled){background:#2a2f38;border-color:#4a5568;color:#f7f8fa}.btn-secondary:active:not(:disabled){background:#242730}@media (max-width:640px){.add-column-modal-container{max-width:95vw}.add-column-modal-header{padding:14px 16px}.add-column-modal-header h3{font-size:16px}.modal-body{padding:16px}.add-column-modal-footer{flex-direction:column-reverse;padding:14px 16px}.btn{font-size:13px;padding:9px 16px;width:100%}}.attribute-panel{background:#fff;border-top:2px solid #3b82f6;bottom:0;box-shadow:0 -4px 20px #0000004d;display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;height:240px;left:320px;max-height:80vh;min-height:120px;overflow:hidden;position:fixed;right:0;z-index:950}.attribute-panel.hidden{display:none!important}.attribute-resize-handle{align-items:center;background:#0000;cursor:ns-resize;display:flex;height:10px;justify-content:center;left:0;position:absolute;right:0;top:-5px;z-index:951}.attribute-resize-handle:hover{background-color:#3b82f61a}.resize-handle-indicator{background:#3b82f6;border-radius:2px;height:3px;opacity:.6;width:40px}.attribute-resize-handle:hover .resize-handle-indicator{background:#3b82f6;opacity:1;width:60px}.attribute-panel.minimized{display:none!important}.attribute-panel.resizing{-webkit-user-select:none;user-select:none}.table-tabs-container{align-items:center;background:#f8f9fa;border-bottom:1px solid #e0e0e0;cursor:default;display:flex;justify-content:space-between;min-height:28px;padding:0 6px}.table-tabs{display:flex;flex:1 1;gap:2px;overflow-x:auto;overflow-y:hidden}.table-tabs::-webkit-scrollbar{height:2px}.table-tabs::-webkit-scrollbar-track{background:#0000}.table-tabs::-webkit-scrollbar-thumb{background:#ccc;border-radius:1px}.table-tab{align-items:center;background:#e9ecef;border:1px solid #dee2e6;border-bottom:none;border-radius:4px 4px 0 0;color:#495057;cursor:pointer;display:flex;font-size:10px;gap:4px;max-width:180px;min-width:100px;padding:4px 8px;position:relative;transition:all .2s ease;white-space:nowrap}.table-tab:hover{background:#dee2e6}.table-tab.active{background:#fff;border-color:#e0e0e0;border-bottom:1px solid #fff;color:#212529;margin-bottom:-1px;z-index:1}.table-tab-name{flex:1 1;overflow:hidden;text-overflow:ellipsis}.table-tab-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#6c757d;cursor:pointer;display:flex;font-size:10px;height:14px;justify-content:center;transition:all .2s ease;width:14px}.table-tab-close:hover{background:#dc3545;color:#fff}.attribute-panel-header-compact{align-items:center;background:linear-gradient(180deg,#fff,#f8f9fa);border-bottom:1px solid #e0e0e0;display:flex;font-size:11px;gap:8px;min-height:32px;padding:4px 8px}.attribute-panel-title{align-items:center;color:#212529;display:flex;font-weight:600;gap:4px;white-space:nowrap}.attribute-panel-title svg{color:#3b82f6;flex-shrink:0}.data-view-toggle{border:1px solid #d1d5db;border-radius:4px;display:flex;overflow:hidden}.data-view-toggle button{background:#fff;border:none;border-right:1px solid #d1d5db;color:#6b7280;cursor:pointer;font-size:9px;font-weight:500;padding:2px 6px;transition:all .2s ease}.data-view-toggle button:last-child{border-right:none}.data-view-toggle button:hover{background:#f3f4f6}.data-view-toggle button.active{background:#3b82f6;color:#fff}.row-count-indicator{align-items:center;color:#6b7280;display:flex;font-size:10px;gap:4px;white-space:nowrap}.row-count-indicator .count{color:#3b82f6;font-weight:600}.action-button{align-items:center;background:#0000;border:1px solid #d1d5db;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px 6px;transition:all .2s ease}.action-button:hover{background:#f3f4f6;border-color:#3b82f6;color:#3b82f6}.action-button.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.action-button.compact-btn{min-height:20px;min-width:24px;padding:2px 4px}.attribute-panel-controls{display:flex;gap:2px;margin-left:auto}.attribute-panel-content{background:#fff;flex:1 1;overflow:auto;scroll-behavior:smooth}.data-table-container{height:100%;overflow:auto;scroll-behavior:smooth;width:100%}.attribute-table{background:#fff;border-collapse:initial;border-spacing:0;font-size:11px;min-width:100%;table-layout:auto;width:auto}.attribute-table thead{background:#f8f9fa}.attribute-table th,.attribute-table thead{position:-webkit-sticky;position:sticky;top:0;z-index:10}.attribute-table th{background:linear-gradient(180deg,#f8f9fa,#e9ecef);border-bottom:2px solid #dee2e6;border-right:1px solid #dee2e6;color:#495057;cursor:pointer;font-weight:600;max-width:200px;padding:6px 10px;text-align:left;-webkit-user-select:none;user-select:none;white-space:nowrap}.attribute-table th:hover{background:linear-gradient(180deg,#e9ecef,#dee2e6)}.attribute-table th.sorted{background:linear-gradient(180deg,#d1e7fd,#b6dbfb);color:#0c5aa6}.attribute-table th.pinned{background:linear-gradient(180deg,#fff8dc,#ffeead);left:0;position:-webkit-sticky;position:sticky;z-index:11}.header-content{justify-content:space-between}.header-content,.header-left{align-items:center;display:flex;gap:4px}.header-left{flex:1 1}.header-text{align-items:center;display:flex;gap:4px}.column-name{font-weight:600}.sort-icon{color:#3b82f6;font-weight:700;margin-left:4px}.pin-icon{font-size:10px}.header-delete-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:3px;color:#6b7280;cursor:pointer;display:none;justify-content:center;margin-left:4px;padding:2px 4px;transition:all .15s ease}.table-header:hover .header-delete-btn{display:flex}.header-delete-btn:hover{background:#fee2e2;border-color:#ef4444;color:#ef4444}.header-delete-btn:active{background:#fecaca;transform:scale(.95)}.edit-mode-toggle-container{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;gap:8px;height:26px;padding:0 8px}.toggle-label{color:#374151;font-size:11px;font-weight:500;white-space:nowrap}.toggle-switch{cursor:pointer;display:inline-block;height:20px;margin:0;position:relative;width:38px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#d1d5db;border-radius:20px;bottom:0;box-shadow:inset 0 1px 3px #0000001a;cursor:pointer;left:0;right:0;top:0}.toggle-slider,.toggle-slider:before{position:absolute;transition:all .3s ease}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:2px;box-shadow:0 2px 4px #0003;content:"";height:16px;left:2px;width:16px}.toggle-switch input:checked+.toggle-slider{background-color:#3b82f6}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(18px)}.toggle-switch:hover .toggle-slider{box-shadow:inset 0 1px 3px #0003,0 0 0 3px #3b82f61a}.add-column-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:6px;box-shadow:0 2px 4px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:6px;padding:5px 12px;transition:all .2s ease;white-space:nowrap}.add-column-btn:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #3b82f666;transform:translateY(-1px)}.add-column-btn:active{box-shadow:0 1px 2px #3b82f64d;transform:translateY(0)}.add-column-btn .btn-text{font-size:11px}.add-point-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 2px 4px #10b9814d;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:500;gap:6px;padding:5px 12px;transition:all .2s ease;white-space:nowrap}.add-point-btn:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.add-point-btn:active{box-shadow:0 1px 2px #10b9814d;transform:translateY(0)}.add-point-btn.active{animation:pulse 1.5s ease-in-out infinite;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d}.add-point-btn.active:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 8px #f59e0b66}.add-point-btn .btn-text{font-size:11px}.delete-btn{background:#fee2e2!important;border:1px solid #ef4444!important;color:#ef4444!important}.delete-btn:hover{background:#fecaca!important;border-color:#dc2626!important;color:#dc2626!important}.delete-btn:active{background:#fca5a5!important;transform:scale(.95)}.attribute-table tbody tr{border-bottom:1px solid #f3f4f6;cursor:pointer;transition:background-color .15s ease}.attribute-table tbody tr:hover{background-color:#f8f9fa}.attribute-table tbody tr.selected{background-color:#dbeafe!important;border-left:3px solid #3b82f6}.attribute-table tbody tr.selected:hover{background-color:#bfdbfe!important}.attribute-table td{border-right:1px solid #f3f4f6;color:#374151;max-width:200px;overflow:hidden;padding:6px 10px;text-overflow:ellipsis;white-space:nowrap}.attribute-table td.photo-field{max-width:60px;min-width:60px;padding:4px;text-align:center;width:60px}.table-cell.editable-cell{cursor:text}.table-cell.editable-cell:hover{background-color:#f0f9ff;outline:1px solid #3b82f6}.table-cell.edit-mode-active{background:#3b82f60d;border:1px solid #3b82f633;cursor:pointer;transition:all .2s ease}.table-cell.edit-mode-active:hover{background:#3b82f61a;border-color:#3b82f666}.table-cell.editing{background:#fff;outline:2px solid #3b82f6;padding:0}.cell-input{background:#0000;border:none;color:#374151;font-family:inherit;font-size:11px;height:100%;outline:none;padding:6px 8px;width:100%}.context-menu{background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:180px;padding:4px 0;z-index:10001}.context-menu-item{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:12px;gap:8px;padding:8px 12px;transition:all .15s ease}.context-menu-item:hover{background:#f3f4f6}.context-menu-item.disabled{background:#0000;color:#9ca3af;cursor:not-allowed}.context-menu-item.disabled:hover{background:#0000}.context-menu-item svg{color:#6b7280;flex-shrink:0}.context-menu-item:hover svg{color:#374151}.attribute-minimized-icon{align-items:center;background:#3b82f6;border-radius:8px;bottom:10px;box-shadow:0 4px 12px #0000004d;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:600;gap:6px;padding:8px 12px;position:fixed;right:10px;transition:all .2s ease;z-index:949}.attribute-minimized-icon:hover{background:#2563eb;box-shadow:0 6px 16px #0006;transform:translateY(-2px)}@media (max-width:1200px){.attribute-panel-header-compact{flex-wrap:wrap;gap:4px}.attribute-panel-header-compact .compact-btn{font-size:9px!important;padding:1px 4px!important}.attribute-panel-header-compact .compact-btn svg{height:10px!important;width:10px!important}}@media (max-width:900px){.attribute-panel{left:0}.attribute-panel-header-compact{padding:2px 6px}.attribute-panel-header-compact .attribute-panel-title span{display:none}.attribute-panel-header-compact .data-view-toggle button{font-size:8px;padding:1px 4px}}.data-table-container::-webkit-scrollbar{height:10px;width:10px}.data-table-container::-webkit-scrollbar-track{background:#f3f4f6}.data-table-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:5px}.data-table-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.attribute-search-container{flex-shrink:0;margin:0 8px;position:relative}.attribute-search-input{background:#ffffffe6;border:1px solid #cbd5e1;border-radius:6px;color:#1f2937;font-size:11px;padding:6px 30px 6px 28px;transition:all .2s;width:200px}.attribute-search-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.attribute-search-container .search-icon{color:#6b7280;height:12px;left:8px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:12px}.attribute-search-container .search-clear-icon-btn{align-items:center;background:#ef44441a;border:1px solid #ef444433;border-radius:3px;color:#ef4444;cursor:pointer;display:flex;font-size:16px;height:20px;justify-content:center;line-height:1;padding:0;position:absolute;right:4px;top:50%;transform:translateY(-50%);transition:all .2s;width:20px}.attribute-search-container .search-clear-icon-btn:hover{background:#ef444433;border-color:#ef444466}.attribute-search-results{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 4px 16px #00000026;left:0;max-height:250px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:9999}.attribute-search-results .search-results-header{background:#3b82f60d;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:9px;font-weight:600;letter-spacing:.5px;padding:6px 10px;position:-webkit-sticky;position:sticky;text-transform:uppercase;top:0;z-index:1}.attribute-search-results .search-result-item{border-bottom:1px solid #f3f4f6;cursor:pointer;font-size:10px;padding:8px 10px;transition:all .15s}.attribute-search-results .search-result-item:hover{background:#3b82f614}.attribute-search-results .search-result-item:last-child{border-bottom:none}.attribute-search-results .search-result-details{align-items:center;display:flex;flex-wrap:wrap;gap:4px}.attribute-search-results .search-result-field{color:#3b82f6;font-size:10px;font-weight:600}.attribute-search-results .search-result-value{color:#4b5563;font-size:10px;word-break:break-word}.highlight-row{animation:highlightRow 2s ease-out}@keyframes highlightRow{0%{background-color:#3b82f64d}50%{background-color:#3b82f626}to{background-color:initial}}.table-cell.photo-field{max-width:56px;min-width:56px;padding:4px;text-align:center;vertical-align:middle;width:56px}.photo-cell{align-items:center;display:flex;justify-content:center}.photo-cell img{transition:transform .2s ease,box-shadow .2s ease}.photo-cell img:hover{box-shadow:0 4px 12px #0003;transform:scale(1.1);z-index:10}.export-dialog-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10010}.export-dialog{background:#29323c;border-radius:4px;box-shadow:0 8px 32px #00000080;max-width:90vw;overflow:hidden;width:380px}.export-dialog-header{align-items:center;background:#3a4552;border-bottom:1px solid #3a4552;display:flex;justify-content:space-between;padding:12px 16px}.export-dialog-title{align-items:center;display:flex;gap:8px}.export-dialog-title svg{color:#6a7485}.export-dialog-header h3{color:#a0a7b4;font-size:13px;font-weight:500;letter-spacing:.5px;margin:0;text-transform:uppercase}.export-dialog-close{align-items:center;background:none;border:none;border-radius:2px;color:#6a7485;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;width:24px}.export-dialog-close:hover{background:#ffffff14;color:#f7f8fa}.export-dialog-body{background:#29323c;padding:16px}.export-dialog-info{align-items:flex-start;background:#242730;border-radius:2px;display:flex;gap:8px;margin-bottom:12px;padding:10px 12px}.export-dialog-info svg{color:#6a7485;flex-shrink:0;margin-top:2px}.export-dialog-info span{color:#6a7485;font-size:11px;line-height:1.5}.export-options{flex-direction:column;gap:8px}.export-option-btn{align-items:center;background:#3a4552;border:1px solid #4a5568;border-radius:2px;color:#a0a7b4;cursor:pointer;display:flex;gap:12px;padding:12px;text-align:left;transition:all .15s ease;width:100%}.export-option-btn:hover:not(:disabled){background:#4a5568;border-color:#5b9bf4}.export-option-btn:active:not(:disabled){background:#3a4552}.export-option-btn:disabled{cursor:not-allowed;opacity:.5}.export-option-btn.csv-btn:hover:not(:disabled){border-color:#77b96c}.export-option-btn.xlsx-btn:hover:not(:disabled){border-color:#5b9bf4}.export-option-icon{align-items:center;background:#29323c;border-radius:2px;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.csv-btn .export-option-icon{color:#77b96c}.xlsx-btn .export-option-icon{color:#5b9bf4}.export-option-content{flex:1 1}.export-option-content,.export-option-text{display:flex;flex-direction:column;gap:2px}.export-option-text strong{color:#f7f8fa;font-size:12px;font-weight:500}.export-option-text span{color:#6a7485;font-size:10px}.export-option-badge{align-items:center;border-radius:2px;display:inline-flex;font-size:9px;font-weight:500;letter-spacing:.3px;margin-top:4px;padding:2px 6px;text-transform:uppercase;width:-webkit-fit-content;width:fit-content}.export-option-badge.csv{background:#77b96c26;color:#77b96c}.export-option-badge.xlsx{background:#5b9bf426;color:#5b9bf4}.export-option-arrow{color:#4a5568;flex-shrink:0;transition:all .15s ease}.export-option-btn:hover:not(:disabled) .export-option-arrow{color:#a0a7b4;transform:translateX(2px)}.csv-btn:hover:not(:disabled) .export-option-arrow{color:#77b96c}.xlsx-btn:hover:not(:disabled) .export-option-arrow{color:#5b9bf4}.simple-draggable-panel{background:#2a2f38;border:1px solid #3c414c;border-radius:8px;box-shadow:0 8px 32px #0006;color:#f7f8fa;display:flex;flex-direction:column;left:calc(50% - 175px);max-height:550px;max-height:90vh;max-width:90vw;min-height:200px;min-width:300px;overflow:hidden;position:fixed;resize:both;top:calc(50% - 275px);width:350px;z-index:9999}.resize-handle{position:absolute;z-index:10}.resize-n{cursor:n-resize;top:0}.resize-n,.resize-s{height:5px;left:0;right:0}.resize-s{bottom:0;cursor:s-resize}.resize-e{cursor:e-resize;right:0}.resize-e,.resize-w{bottom:0;top:0;width:5px}.resize-w{cursor:w-resize;left:0}.resize-ne{cursor:ne-resize;right:0}.resize-ne,.resize-nw{height:10px;top:0;width:10px}.resize-nw{cursor:nw-resize;left:0}.resize-se{cursor:se-resize;right:0}.resize-se,.resize-sw{bottom:0;height:10px;width:10px}.resize-sw{cursor:sw-resize;left:0}.resize-ne:after,.resize-nw:after,.resize-se:after,.resize-sw:after{border-radius:2px;content:"";height:8px;position:absolute;width:8px}.resize-se:after{bottom:2px;right:2px}.resize-sw:after{bottom:2px;left:2px}.resize-ne:after{right:2px;top:2px}.resize-nw:after{left:2px;top:2px}.resize-handle:hover:after{background:#1f7cf4}.resize-ne:after,.resize-nw:after,.resize-se:after,.resize-sw:after{background:#3c414c}.simple-draggable-panel.hidden{display:none}.simple-draggable-panel.dragging{transition:none;-webkit-user-select:none;user-select:none}.simple-panel-header{align-items:center;background:#242730;border-bottom:1px solid #3c414c;border-radius:8px 8px 0 0;cursor:move;display:flex;justify-content:space-between;padding:10px 14px;-webkit-user-select:none;user-select:none}.simple-panel-header span{color:#f7f8fa;font-size:13px;font-weight:600}.simple-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:18px;height:22px;justify-content:center;transition:all .2s ease;width:22px}.simple-close-btn:hover{background:#ffffff0d;color:#f7f8fa}.simple-panel-body{background:#2a2f38;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;padding:12px}.simple-panel-body::-webkit-scrollbar{width:6px}.simple-panel-body::-webkit-scrollbar-track{background:#0003;border-radius:3px}.simple-panel-body::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.simple-panel-body::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.simple-section{flex-shrink:0;margin-bottom:12px}.simple-section:last-child{margin-bottom:0}.simple-section.points-table-section{display:flex;flex:1 1;flex-direction:column;flex-shrink:1;min-height:0}.simple-section.points-table-section>label{flex-shrink:0}.simple-section label{color:#a0a7b4;display:block;font-size:11px;font-weight:600;margin-bottom:5px}.simple-section input[type=text]{background:#353a44;border:1px solid #3c414c;border-radius:4px;color:#f7f8fa;font-size:11px;padding:6px 8px;transition:border-color .2s ease;width:100%}.simple-section input[type=text]:focus{border-color:#1f7cf4;box-shadow:0 0 0 3px #1f7cf433;outline:none}.simple-section input[type=text]::placeholder{color:#6b7280}.simple-btn-row{display:flex;gap:4px;margin-bottom:6px}.simple-btn{background:#242730;border:1px solid #3c414c;border-radius:6px;color:#a0a7b4;cursor:pointer;font-size:10px;font-weight:500;padding:4px 10px;transition:all .2s ease}.simple-btn:hover:not(:disabled){background:#2a2f38;border-color:#4a5568;color:#f7f8fa;transform:translateY(-1px)}.simple-btn.primary{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;color:#fff}.simple-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#0d47a1,#083d8a);box-shadow:0 4px 12px #1f7cf466}.simple-btn:disabled{cursor:not-allowed;opacity:.4}.simple-btn.active{background:#10b981;border-color:#10b981}.marking-indicator{animation:pulse-green 2s infinite;background-color:#0f0;border:1px solid #fff;border-radius:50%;box-shadow:0 0 4px #00ff0080;height:8px;position:absolute;right:-2px;top:-2px;width:8px}@keyframes pulse-green{0%{box-shadow:0 0 4px #00ff0080}50%{box-shadow:0 0 8px #0f0c}to{box-shadow:0 0 4px #00ff0080}}.simple-table-container{background:#242730;border:1px solid #3c414c;border-radius:6px;box-shadow:inset 0 2px 4px #0000001a;flex:1 1;max-height:600px;min-height:150px;overflow-y:auto;position:relative}.table-resize-handle{align-items:center;cursor:ns-resize;display:flex;height:8px;justify-content:center;margin:4px 0;position:relative;-webkit-user-select:none;user-select:none;z-index:5}.table-resize-line{background:#3c414c;border-radius:2px;height:3px;transition:all .2s ease;width:40px}.table-resize-handle:hover .table-resize-line{background:#1f7cf4;height:4px;width:60px}.simple-table-container::-webkit-scrollbar{width:6px}.simple-table-container::-webkit-scrollbar-track{background:#0003;border-radius:3px}.simple-table-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.simple-table{border-collapse:collapse;font-size:11px;width:100%}.simple-table thead{background:#1a202ce6;position:-webkit-sticky;position:sticky;top:0;z-index:10}.simple-table th{background:#242730e6;border-bottom:2px solid #3c414c;color:#a0a7b4;font-size:10px;font-weight:600;padding:6px 8px;text-align:left}.simple-table td{border-bottom:1px solid #3c414c4d;color:#f7f8fa;font-size:10px;padding:6px 8px}.simple-table tbody tr{cursor:pointer;transition:background-color .15s ease}.simple-table tbody tr:hover{background:#1f7cf41a}.simple-table tbody tr.selected{background:#1f7cf440;border-left:3px solid #1f7cf4}.simple-table td.empty{color:#6b7280;font-style:italic;padding:20px;text-align:center}.delete-point-btn{align-items:center;background:#ef4444;border:none;border-radius:3px;color:#fff;cursor:pointer;display:flex;font-size:14px;height:20px;justify-content:center;transition:all .2s ease;width:20px}.delete-point-btn:hover{background:#dc2626;transform:scale(1.1)}.simple-expandable-header{align-items:center;background:#242730;border:1px solid #3c414c;border-radius:4px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:8px;padding:8px 10px;transition:all .2s ease}.simple-expandable-header:hover{background:#2a2f38;border-color:#1f7cf4}.simple-expandable-header span{color:#a0a7b4;font-size:11px;font-weight:600}.simple-toggle-icon{color:#1f7cf4;font-size:10px;transition:transform .2s ease}.simple-advanced-content{background:#242730;border:1px solid #3c414c;border-radius:4px;border-top:none;border-top-left-radius:0;border-top-right-radius:0;margin-top:-8px;padding:10px}.simple-panel-footer{align-items:center;background:#242730;border-radius:0 0 8px 8px;border-top:1px solid #3c414c;display:flex;gap:8px;justify-content:space-between;padding:10px 12px}.simple-panel-footer .simple-btn{font-size:11px;padding:6px 16px}.simple-panel-footer select{background:#2d3748;border:1px solid #4a5568;border-radius:4px;color:#e2e8f0;cursor:pointer;font-size:10px;padding:4px 8px;transition:border-color .2s ease}.simple-panel-footer select:hover{border-color:#1f7cf4}.simple-panel-footer select:focus{border-color:#1f7cf4;box-shadow:0 0 0 2px #1f7cf433;outline:none}.create-layer-minimized-icon{align-items:center;background:#1f7cf4;border-radius:50%;bottom:20px;box-shadow:0 4px 12px #1f7cf466;color:#fff;cursor:pointer;display:flex;flex-direction:column;height:56px;justify-content:center;position:fixed;right:20px;transition:all .3s ease;width:56px;z-index:9998}.create-layer-minimized-icon:hover{box-shadow:0 6px 20px #1f7cf499;transform:scale(1.1)}.create-layer-minimized-icon.active-marking{animation:pulse-icon 2s infinite;background:#10b981}@keyframes pulse-icon{0%,to{box-shadow:0 4px 12px #10b98166}50%{box-shadow:0 6px 20px #10b981cc}}.create-layer-minimized-icon span{font-size:11px;font-weight:600;margin-top:2px}.calendar-container{position:relative;width:100%}.calendar-input{align-items:center;background:#1a202c;border:1px solid #4a5568;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:10px;justify-content:space-between;min-height:30px;padding:6px 10px;transition:all .2s ease}.calendar-input:hover{background:#252b3a;border-color:#007cbf}.calendar-input .placeholder{color:#a0aec0}.calendar-input .has-value{color:#10b981;font-weight:500}.calendar-icon{color:#a0aec0;font-size:8px;margin-left:6px}.calendar-dropdown{animation:slideDown .2s ease;background:#1a202c;border:1px solid #4a5568;border-radius:6px;box-shadow:0 4px 12px #00000080;margin-top:4px;min-width:280px;padding:12px;position:fixed;z-index:10000}.calendar-header{align-items:center;border-bottom:1px solid #4a5568;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.calendar-nav-btn{align-items:center;background:#2a2d3a;border:1px solid #4a5568;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:12px;height:28px;justify-content:center;transition:all .2s ease;width:28px}.calendar-nav-btn:hover{background:#007cbf;border-color:#007cbf}.calendar-month-year{color:#fff;flex:1 1;font-size:12px;font-weight:600;text-align:center}.calendar-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.calendar-weekday{color:#a0aec0;font-size:9px;font-weight:600;padding:4px 0;text-align:center}.calendar-days{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:12px}.calendar-day{align-items:center;aspect-ratio:1;background:#2a2d3a;border:1px solid #0000;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:500;justify-content:center;transition:all .2s ease}.calendar-day.empty{background:#0000;cursor:default}.calendar-day.disabled{background:#1a1d2a;color:#4a5568;cursor:not-allowed;opacity:.3}.calendar-day.disabled:hover{background:#1a1d2a;border-color:#0000;transform:none}.calendar-day:not(.empty):not(.disabled):hover{background:#3a3d4a;border-color:#007cbf;transform:scale(1.05)}.calendar-day.today{background:#3a3310;border-color:#ffc107;color:#ffc107;font-weight:700}.calendar-day.selected{background:#007cbf;border-color:#007cbf;color:#fff;font-weight:700}.calendar-day.today.selected{background:#09f;border-color:#09f;color:#fff}.calendar-footer{border-top:1px solid #4a5568;display:flex;gap:6px;padding-top:8px}.calendar-footer-btn{background:#007cbf;border:1px solid #007cbf;border-radius:4px;color:#fff;cursor:pointer;flex:1 1;font-size:10px;font-weight:600;padding:6px 12px;transition:all .2s ease}.calendar-footer-btn:hover{background:#09f;border-color:#09f}.calendar-footer-btn.clear{background:#2a2d3a;border-color:#4a5568;color:#a0aec0}.calendar-footer-btn.clear:hover{background:#dc2626;border-color:#dc2626;color:#fff}.route-draggable-panel{background:#2a2f38;border:1px solid #3c414c;border-radius:8px;box-shadow:0 8px 32px #0006;color:#f7f8fa;display:flex;flex-direction:column;left:calc(50% - 200px);max-height:650px;max-height:90vh;max-width:90vw;min-height:300px;min-width:350px;position:fixed;top:calc(50% - 300px);width:400px;z-index:9999}.route-draggable-panel.hidden{display:none}.route-panel-header{align-items:center;background:#242730;border-bottom:1px solid #3c414c;border-radius:8px 8px 0 0;cursor:move;display:flex;justify-content:space-between;padding:10px 14px;-webkit-user-select:none;user-select:none}.route-panel-header span{color:#f7f8fa;font-size:13px;font-weight:600}.route-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:18px;height:22px;justify-content:center;transition:all .2s ease;width:22px}.route-close-btn:hover{background:#ffffff0d;color:#f7f8fa}.route-tabs{background:#242730;border-bottom:1px solid #3c414c;display:flex}.route-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#a0a7b4;cursor:pointer;flex:1 1;font-size:11px;font-weight:500;padding:8px 12px;transition:all .2s ease}.route-tab.active{background:#1f7cf41a;border-bottom-color:#1f7cf4;color:#1f7cf4}.route-tab:hover{background:#1f7cf40d;color:#f7f8fa}.route-panel-body{background:#2a2f38;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;padding:12px}.route-panel-body::-webkit-scrollbar{width:6px}.route-panel-body::-webkit-scrollbar-track{background:#0003;border-radius:3px}.route-panel-body::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.route-panel-body::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.route-section{flex-shrink:0;margin-bottom:12px}.route-section label{color:#a0a7b4;display:block;font-size:11px;font-weight:600;margin-bottom:5px}.route-section input[type=text]{background:#353a44;border:1px solid #3c414c;border-radius:4px;color:#f7f8fa;font-size:11px;padding:6px 8px;transition:border-color .2s ease;width:100%}.route-section input[type=text]:focus{border-color:#1f7cf4;box-shadow:0 0 0 3px #1f7cf433;outline:none}.route-options-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.route-option{display:flex;flex-direction:column}.route-select{background:#353a44;border:1px solid #3c414c;border-radius:4px;color:#f7f8fa;cursor:pointer;font-size:10px;padding:6px 8px}.route-select:focus{border-color:#1f7cf4;box-shadow:0 0 0 3px #1f7cf433;outline:none}.route-btn-row{display:flex;flex-wrap:wrap;gap:4px}.route-btn{background:#242730;border:1px solid #3c414c;border-radius:4px;color:#a0a7b4;cursor:pointer;font-size:10px;font-weight:500;padding:6px 12px;transition:all .2s ease}.route-btn:hover:not(:disabled){background:#2a2f38;border-color:#4a5568;color:#f7f8fa}.route-btn:disabled{cursor:not-allowed;opacity:.5}.route-btn.primary{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;box-shadow:0 2px 8px #1f7cf44d;color:#fff}.route-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#0d47a1,#083d8a);box-shadow:0 4px 12px #1f7cf466;transform:translateY(-1px)}.route-btn.primary.active{animation:pulse 2s infinite}.route-btn.optimize{background:#10b981;border-color:#10b981;color:#fff}.route-btn.optimize:hover:not(:disabled){background:#059669}.route-btn.small{font-size:9px;padding:4px 8px}.route-stats{background:#2a2f3899;border:1px solid #3c414c;border-radius:4px;display:flex;gap:12px;margin-bottom:12px;padding:8px}.route-stat{display:flex;flex-direction:column;gap:2px}.route-stat-label{color:#a0a7b4;font-size:9px;font-weight:600;text-transform:uppercase}.route-stat-value{color:#1f7cf4;font-size:14px;font-weight:700}.route-table-section{display:flex;flex:1 1;flex-direction:column;min-height:0}.route-table-container{background:#242730;border:1px solid #3c414c;border-radius:6px;box-shadow:inset 0 2px 4px #0000001a;flex:1 1;min-height:150px;overflow-y:auto}.route-table-container::-webkit-scrollbar{width:6px}.route-table-container::-webkit-scrollbar-track{background:#0003;border-radius:3px}.route-table-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.route-table{border-collapse:collapse;font-size:10px;width:100%}.route-table thead{background:#242730e6;position:-webkit-sticky;position:sticky;top:0;z-index:1}.route-table th{border-bottom:2px solid #3c414c;color:#a0a7b4;font-size:10px;font-weight:600;padding:6px 8px;text-align:left}.route-table td{border-bottom:1px solid #3c414c4d;color:#f7f8fa;padding:6px 8px}.route-table tbody tr{cursor:pointer;transition:background .2s ease}.route-table tbody tr:hover{background:#1f7cf41a}.route-table tbody tr.selected{background:#1f7cf440;border-left:3px solid #1f7cf4}.route-table tbody tr.selected td:first-child{padding-left:5px}.route-table td.empty{color:#6b7280;font-style:italic;padding:20px;text-align:center}.delete-waypoint-btn{align-items:center;background:#ef4444;border:none;border-radius:3px;color:#fff;cursor:pointer;display:flex;font-size:14px;height:20px;justify-content:center;transition:all .2s ease;width:20px}.delete-waypoint-btn:hover{background:#dc2626;transform:scale(1.1)}.saved-routes-list{max-height:450px;overflow-y:auto}.empty-routes{color:#6b7280;font-size:11px;font-style:italic;padding:20px;text-align:center}.saved-route-item{background:#2a2f3899;border:1px solid #3c414c;border-radius:6px;margin-bottom:8px;padding:10px;transition:all .2s ease}.saved-route-item:hover{background:#2a2f38e6;border-color:#1f7cf4;box-shadow:0 4px 12px #1f7cf466;transform:translateY(-1px)}.saved-route-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.saved-route-name{color:#f7f8fa;font-size:12px;font-weight:600}.saved-route-priority{border-radius:3px;font-size:9px;font-weight:600;padding:2px 6px;text-transform:uppercase}.saved-route-priority.priority-high{background:#dc2626;color:#fff}.saved-route-priority.priority-medium{background:#ffc107;color:#242730}.saved-route-priority.priority-low{background:#28a745;color:#fff}.saved-route-info{align-items:center;color:#a0a7b4;display:flex;font-size:10px;gap:6px;margin-bottom:6px}.saved-route-actions{display:flex;gap:4px;justify-content:flex-end}.route-panel-footer{background:#242730;border-radius:0 0 8px 8px;border-top:1px solid #3c414c;display:flex;gap:8px;justify-content:flex-end;padding:10px 12px}.route-panel-footer .route-btn{font-size:11px;padding:6px 16px}.route-minimized-icon{align-items:center;background:linear-gradient(135deg,#1f7cf4,#1e6fd4);border-radius:50%;bottom:20px;box-shadow:0 4px 12px #0000004d;color:#fff;cursor:pointer;display:flex;flex-direction:column;height:56px;justify-content:center;position:fixed;right:20px;transition:all .3s ease;width:56px;z-index:9998}.route-minimized-icon:hover{box-shadow:0 6px 20px #1f7cf466;transform:scale(1.1)}.route-minimized-icon svg{margin-bottom:2px}.route-minimized-icon span{font-size:11px;font-weight:600}.route-minimized-icon.active-drawing{animation:pulse 2s infinite;background:linear-gradient(135deg,#10b981,#059669)}.route-tracking-tab{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.route-tracking-tab.live-view{gap:.25rem}.route-tracking-tab.live-view .tab-header{margin-bottom:0;padding-bottom:0}.route-tracking-tab.live-view .route-tracking-nav{margin-bottom:0;padding:.75rem}.route-tracking-tab.live-view .route-tracking-content{margin-top:0}.tab-subtitle{color:#6b7280;font-size:.875rem;font-weight:400;margin:0}.route-tracking-nav{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;gap:.5rem;overflow-x:auto;padding:1rem}.nav-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s ease;white-space:nowrap}.nav-btn:hover{background:#f3f4f6;color:#374151}.nav-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.nav-btn.active svg{filter:brightness(0) invert(1)}.route-filters{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.filters-row{grid-gap:1rem;align-items:end;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.filter-group{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.filter-group label{align-items:center;color:#374151;display:flex;font-size:.8125rem;font-weight:600;gap:.5rem;letter-spacing:.03em;text-transform:uppercase}.filter-group label svg{color:#667eea;flex-shrink:0}.filter-group input[type=date],.filter-group select{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#1f2937;cursor:pointer;font-size:.9375rem;padding:.625rem .875rem;transition:all .2s ease}.filter-group input[type=date]:hover,.filter-group select:hover{border-color:#cbd5e0}.filter-group input[type=date]:focus,.filter-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-group select option{background:#fff;color:#1f2937;padding:10px 12px}.filter-group select option:focus,.filter-group select option:hover{background:#667eea;color:#fff}.filter-group select option:checked{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.date-range-filter-section{border-top:1.5px solid #e5e7eb;display:flex;flex-direction:column;gap:1rem;padding-top:1rem}.date-range-label{align-items:center;color:#374151;display:flex;font-size:.8125rem;font-weight:600;gap:.5rem;letter-spacing:.03em;text-transform:uppercase}.date-range-label svg{color:#667eea;flex-shrink:0}.date-range-horizontal{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem}.date-presets-row{display:flex;flex:1 1;flex-wrap:wrap;gap:.5rem;min-width:0}.date-preset-chip{background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;color:#4b5563;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.date-preset-chip:hover{background:#f5f7ff;border-color:#667eea;color:#667eea;transform:translateY(-1px)}.date-preset-chip.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 8px #667eea4d;color:#fff;font-weight:600}.date-inputs-inline{align-items:center;background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;display:flex;flex-shrink:0;gap:.75rem;padding:.5rem 1rem}.date-input-compact{display:flex;flex-direction:column;gap:.25rem}.date-input-compact label{color:#6b7280;font-size:.6875rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.date-input-compact input[type=date]{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#1f2937;cursor:pointer;font-size:.875rem;min-width:140px;padding:.5rem .75rem;transition:all .2s ease}.date-input-compact input[type=date]:hover{border-color:#cbd5e0}.date-input-compact input[type=date].active,.date-input-compact input[type=date]:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.date-arrow{color:#9ca3af;font-size:1.25rem;font-weight:300;padding-top:1rem}.statistics-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{box-shadow:0 2px 8px #00000014;padding:1.25rem;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:56px;justify-content:center;width:56px}.stat-info{flex:1 1;min-width:0}.stat-label{color:#6b7280;font-size:.75rem;font-weight:500;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.stat-value{color:#1f2937;font-size:1.5rem;line-height:1.2}.stat-card.fuel-settings-card{align-items:stretch;background:linear-gradient(135deg,#f8f9fa,#fff);flex-direction:column;padding:1rem}.fuel-settings-inline{display:flex;flex-direction:column;gap:1rem;width:100%}.fuel-setting-item{display:flex;flex-direction:column;gap:.5rem}.fuel-setting-item label{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.fuel-input-group{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:.5rem;padding:.5rem .75rem;transition:all .2s ease}.fuel-input-group:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.fuel-input-compact{background:#0000;border:none;color:#1f2937;flex:1 1;font-size:1rem;font-weight:600;min-width:0;outline:none}.fuel-input-compact::-webkit-inner-spin-button,.fuel-input-compact::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.fuel-unit{color:#6b7280;font-size:.875rem;font-weight:500;white-space:nowrap}.route-tracking-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;min-height:400px;padding:1.5rem}.route-tracking-tab.live-view .route-tracking-content{background:#0000;border-radius:0;box-shadow:none;padding:0}.route-tracking-content.transparent-bg,.route-tracking-tab .route-tracking-content.transparent-bg{background:#0000!important;background-color:initial!important;border:none!important;border-radius:0!important;box-shadow:none!important;min-height:auto!important;padding:0!important}.route-history-list{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.route-card{background:#f9fafb}.route-card.selected{background:#f5f7ff;border-color:#667eea}.route-card-header{align-items:center;border-bottom:1px solid #e5e7eb;margin-bottom:.875rem;padding-bottom:.875rem}.route-user{align-items:center;gap:.75rem}.user-avatar{font-size:1rem;height:40px;width:40px}.user-name{color:#1f2937;font-size:.9375rem}.route-date{margin-top:.125rem}.route-status{border-radius:6px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:capitalize}.status-active{background:#d1fae5;color:#065f46}.status-completed{background:#e0e7ff;color:#3730a3}.status-paused{background:#f3e8ff;color:#7c3aed}.route-time{align-items:center;color:#4b5563;display:flex;font-size:.875rem;gap:.5rem}.route-stats-mini{display:flex;gap:1rem}.stat-mini{align-items:center;color:#6b7280;display:flex;font-size:.8125rem;gap:.375rem}.route-details-view{display:flex;flex-direction:column;gap:1.5rem}.route-details-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.back-btn{align-items:center;background:#f3f4f6;border:none;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.back-btn:hover{background:#e5e7eb}.route-details-title h3{color:#1f2937;font-size:1.25rem;margin:0}.route-details-title p{color:#6b7280;font-size:.875rem;margin:.25rem 0 0}.route-details-actions{display:flex;gap:.5rem}.route-details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.details-card{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;overflow:hidden}.details-card-header{background:#fff;border-bottom:1.5px solid #e5e7eb;padding:1rem 1.25rem}.details-card-header h4{color:#1f2937;font-size:1rem;font-weight:600;margin:0}.details-stats{display:flex;flex-direction:column;gap:.75rem;padding:1.25rem}.detail-row{align-items:center;display:flex;justify-content:space-between;padding:.5rem 0}.detail-row:not(:last-child){border-bottom:1px solid #e5e7eb}.detail-label{color:#6b7280;font-size:.875rem;font-weight:500}.detail-value{color:#1f2937;font-size:.9375rem;font-weight:600}.detail-row.highlight{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:none;border-radius:6px;margin-top:.5rem;padding:.75rem}.detail-row.highlight .detail-value{color:#065f46}.route-timeline{max-height:500px;overflow-y:auto;padding:1.25rem}.timeline-point{display:flex;gap:1rem;margin-bottom:1rem;position:relative}.timeline-point:not(:last-child):after{background:#e5e7eb;content:"";height:calc(100% + 1rem);left:14px;position:absolute;top:32px;width:2px}.timeline-marker{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:28px;justify-content:center;width:28px;z-index:1}.timeline-content{flex:1 1;padding-top:.125rem}.timeline-coords{color:#1f2937;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.timeline-meta{color:#6b7280;font-size:.75rem}.timeline-more{color:#6b7280;font-size:.875rem;font-style:italic;padding:1rem;text-align:center}.fuel-settings-view,.live-tracking-view,.reports-view{max-width:800px}.fuel-settings-view h3,.live-tracking-view h3,.reports-view h3{color:#1f2937;font-size:1.5rem;margin:0 0 .5rem}.fuel-settings-description,.live-tracking-description,.reports-description{color:#6b7280;font-size:.9375rem;margin:0 0 2rem}.fuel-settings-form{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;margin-bottom:2rem;padding:1.5rem}.fuel-settings-form .form-group{margin-bottom:1.25rem}.fuel-settings-form .form-group:last-of-type{margin-bottom:1.5rem}.fuel-settings-form label{color:#374151;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.fuel-settings-form input,.fuel-settings-form select{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#1f2937;font-size:.875rem;padding:.625rem .875rem;transition:all .2s ease;width:100%}.fuel-settings-form input:focus,.fuel-settings-form select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.fuel-settings-form small{color:#6b7280;display:block;font-size:.75rem;margin-top:.375rem}.fuel-estimate-preview{background:linear-gradient(135deg,#f5f7ff,#e0e7ff);border-radius:10px;padding:1.5rem}.fuel-estimate-preview h4{color:#3730a3;font-size:1.125rem;margin:0 0 .5rem}.fuel-estimate-preview p{color:#4338ca;font-size:.875rem;margin:0 0 1rem}.preview-calculation{display:flex;flex-direction:column;gap:.75rem}.calc-row{align-items:center;background:#fff;border-radius:6px;display:flex;justify-content:space-between;padding:.75rem}.calc-row span{color:#4b5563;font-size:.875rem}.calc-row strong{color:#1f2937;font-size:1rem}.live-tracking-view{max-width:100%!important}.live-tracking-view ::-webkit-scrollbar{width:6px}.live-tracking-view ::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.live-tracking-view ::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.live-tracking-view ::-webkit-scrollbar-thumb:hover{background:#94a3b8}.live-users-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.live-user-card{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;overflow:hidden;transition:all .2s ease}.live-user-card.active{border-color:#10b981;box-shadow:0 4px 12px #10b98126}.live-user-header{align-items:center;background:#fff;border-bottom:1.5px solid #e5e7eb;display:flex;gap:1rem;padding:1rem 1.25rem}.user-avatar-large{background:linear-gradient(135deg,#667eea,#764ba2);font-size:1.25rem;height:48px;width:48px}.user-info h4{color:#1f2937;font-size:1rem;margin:0}.user-info p{color:#6b7280;font-size:.75rem;margin:.25rem 0 0}.status-indicator{border-radius:6px;font-size:.75rem;font-weight:600;padding:.375rem .75rem}.status-indicator.online{background:#d1fae5;color:#065f46}.status-indicator.offline{background:#f3f4f6;color:#6b7280}.live-user-details{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));padding:1.25rem}.live-stat{display:flex;flex-direction:column;gap:.25rem}.live-stat-label{color:#6b7280;font-size:.75rem;font-weight:500}.live-stat-value{color:#1f2937;font-size:.9375rem;font-weight:600}.live-user-offline{padding:2rem 1.25rem;text-align:center}.live-user-offline p{color:#9ca3af;font-size:.875rem;margin:0}.report-types{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.report-card{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:10px;display:flex;flex-direction:column;gap:.75rem;padding:1.5rem}.report-card h4{color:#1f2937;font-size:1.125rem;margin:0}.report-card p{color:#6b7280;flex:1 1;font-size:.875rem;margin:0}.export-options{display:flex;gap:.5rem}.btn-export{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.5rem;transition:all .2s ease}.btn-export:hover{background:#f5f7ff;border-color:#667eea;color:#667eea}.empty-state{align-items:center;color:#9ca3af;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state h3{color:#6b7280;font-size:1.25rem;margin:0 0 .5rem}.empty-state p{color:#9ca3af;font-size:.9375rem;margin:0}@media (max-width:1024px){.statistics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.route-details-grid,.route-history-list{grid-template-columns:1fr}}@media (max-width:768px){.route-tracking-nav{-webkit-overflow-scrolling:touch;overflow-x:auto}.route-filters{padding:1rem}.filters-row{gap:1rem;grid-template-columns:1fr}.filter-group{min-width:100%}.date-range-horizontal{align-items:stretch;flex-direction:column;gap:1rem}.date-presets-row{justify-content:center}.date-preset-chip{flex:1 1;min-width:100px;text-align:center}.date-inputs-inline{justify-content:space-between;width:100%}.date-input-compact input[type=date]{min-width:120px}.date-arrow{padding-top:1rem}.statistics-grid{grid-template-columns:1fr}.route-details-header{align-items:stretch;flex-direction:column}.live-users-grid,.report-types{grid-template-columns:1fr}.stat-card{gap:.75rem}.stat-icon{height:48px;width:48px}.stat-value{font-size:1.25rem}}.view-tabs{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;margin-bottom:.5rem;padding:.375rem}.view-tab,.view-tabs{display:flex;gap:.5rem}.view-tab{align-items:center;background:#0000;border:none;border-radius:8px;color:#6b7280;cursor:pointer;flex:1 1;font-size:.9375rem;font-weight:500;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease}.view-tab:hover{background:#f3f4f6;color:#374151}.view-tab.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.assigned-routes-section{display:flex;flex-direction:column;gap:1rem}.assigned-routes-filters{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;gap:1rem;padding:1rem 1.5rem}.filter-group-inline{align-items:center;display:flex;gap:.5rem}.filter-group-inline label{color:#374151;font-size:.875rem;font-weight:500}.filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#fff!important;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23667eea' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")!important;background-position:right 12px center!important;background-repeat:no-repeat!important;border:1.5px solid #e5e7eb;border-radius:8px;color:#374151!important;cursor:pointer;font-size:.875rem;min-width:140px;padding:.5rem 36px .5rem 1rem;transition:all .2s ease}.filter-select:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea33}.filter-select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea26;outline:none}.filter-select option{background:#fff!important;color:#374151!important;font-size:.875rem;padding:12px 16px}.filter-select option:hover{background:#f3f4f6!important;color:#667eea!important}.filter-select option:checked{background:#667eea!important;color:#fff!important;font-weight:500}.btn-back{align-items:center;background:#f3f4f6;border:none;border-radius:6px;color:#374151;cursor:pointer;display:inline-flex;font-size:.875rem;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem}.btn-back:hover{background:#e5e7eb}.assigned-routes-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.progress-circle-container{flex-shrink:0;height:100px;width:100px}.circular-chart .circle-progress{fill:none;stroke:#667eea;stroke-width:3.5;stroke-linecap:round;animation:progress-animation 1s ease-out forwards}.circular-chart .percentage-text{fill:#1f2937;text-anchor:middle;font-size:.5rem;font-weight:700}@keyframes progress-animation{0%{stroke-dasharray:0 100}}.waypoint-status-badge{border-radius:20px;flex-shrink:0;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.waypoint-status-badge.completed{background:#d1fae5;color:#065f46}.waypoint-status-badge.pending{background:#fef3c7;color:#92400e}.route-description{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-top:1rem;padding:1.5rem}.route-description h4{color:#374151;font-size:1rem;margin:0 0 .75rem}.route-description p{color:#6b7280;line-height:1.6;margin:0}.assigned-routes-list{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.assigned-route-card{background:#fff;border-left:4px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #00000014;cursor:pointer;padding:1.25rem;transition:all .2s ease}.assigned-route-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.assigned-route-card.status-pending{border-left-color:#fbbf24}.assigned-route-card.status-in_progress{border-left-color:#3b82f6}.assigned-route-card.status-completed{border-left-color:#10b981}.assigned-route-card.status-paused{border-left-color:#8b5cf6}.assigned-route-card .route-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.assigned-route-card .route-info .route-name{color:#1f2937;font-size:1rem;font-weight:600;margin:0 0 .25rem}.assigned-route-card .route-user{align-items:center;color:#6b7280;display:flex;font-size:.8125rem;gap:.375rem;margin:0}.route-status-badge{border-radius:20px;font-size:.75rem;padding:.25rem .75rem;text-transform:capitalize}.route-status-badge.status-pending{background:#fef3c7;color:#92400e}.route-status-badge.status-in_progress{background:#dbeafe;color:#1e40af}.route-status-badge.status-completed{background:#d1fae5;color:#065f46}.route-status-badge.status-paused{background:#f3e8ff;color:#7c3aed}.route-progress-section{margin-bottom:1rem}.progress-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.progress-label{color:#6b7280;font-size:.75rem;letter-spacing:.03em;text-transform:uppercase}.progress-text{color:#374151;font-size:.8125rem;font-weight:600}.progress-bar-container{background:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width .3s ease}.progress-percentage{color:#667eea;font-size:.75rem;font-weight:600;margin-top:.25rem;text-align:right}.route-card-footer{border-top:1px solid #f3f4f6;display:flex;flex-wrap:wrap;gap:1rem;padding-top:.75rem}.route-card-footer .route-date,.route-card-footer .route-time{align-items:center;color:#6b7280;display:flex;font-size:.8125rem;gap:.375rem}.btn-refresh{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1rem;transition:all .2s ease}.btn-refresh:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-refresh:disabled{cursor:not-allowed;opacity:.7}.assigned-route-details{max-width:900px}.assigned-route-details .route-details-header{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem}.assigned-route-details .route-details-title h3{color:#1f2937;font-size:1.25rem;margin:0}.assigned-route-details .route-details-title p{color:#6b7280;font-size:.875rem;margin:.25rem 0 0}.route-progress-overview{align-items:center;background:#0000;border-radius:12px;box-shadow:none;display:flex;gap:2rem;margin-bottom:1.5rem;padding:1.5rem}.progress-circle{flex-shrink:0;height:120px;width:120px}.circular-chart{height:100%;width:100%}.circular-chart .circle-bg{fill:none;stroke:#e5e7eb;stroke-width:3.5}.circular-chart .circle{fill:none;stroke:url(#progress-gradient);stroke:#667eea;stroke-width:3.5;stroke-linecap:round;animation:progress 1s ease-out forwards}.circular-chart .percentage{fill:#1f2937;text-anchor:middle;font-size:.5rem;font-weight:700}@keyframes progress{0%{stroke-dasharray:0 100}}.progress-stats{display:flex;gap:2rem}.progress-stats .stat-item{text-align:center}.progress-stats .stat-value{color:#1f2937;display:block;font-size:1.75rem;font-weight:700}.progress-stats .stat-label{color:#6b7280;font-size:.75rem;letter-spacing:.03em;text-transform:uppercase}.progress-stats .stat-item.completed .stat-value{color:#10b981}.progress-stats .stat-item.pending .stat-value{color:#f59e0b}.waypoints-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem;padding:1.5rem}.waypoints-section h4{color:#374151;font-size:1rem;margin:0 0 1rem}.waypoints-list{display:flex;flex-direction:column;gap:.75rem}.waypoint-item{align-items:flex-start;background:#f9fafb;border-left:3px solid #e5e7eb;border-radius:8px;display:flex;gap:1rem;padding:1rem;transition:all .2s ease}.waypoint-item.completed{background:#ecfdf5;border-left-color:#10b981}.waypoint-item.pending{border-left-color:#fbbf24}.waypoint-marker{align-items:center;background:#e5e7eb;border-radius:50%;color:#374151;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.waypoint-item.completed .waypoint-marker{background:#10b981;color:#fff}.waypoint-number{font-size:.875rem;font-weight:600}.waypoint-content{flex:1 1;min-width:0}.waypoint-name{color:#1f2937;font-weight:600;margin-bottom:.25rem;word-break:break-word}.waypoint-meta{color:#6b7280;display:flex;flex-wrap:wrap;font-size:.75rem;gap:.75rem}.waypoint-coords{font-family:SF Mono,Monaco,monospace}.waypoint-completed-time{color:#059669}.waypoint-customer-data{border-top:1px dashed #e5e7eb;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;padding-top:.5rem}.customer-field{background:#fff;border-radius:4px;color:#6b7280;font-size:.75rem;padding:.25rem .5rem}.customer-field strong{color:#374151}.waypoint-status{border-radius:20px;flex-shrink:0;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.waypoint-status.completed{background:#d1fae5;color:#065f46}.waypoint-status.pending{background:#fef3c7;color:#92400e}.route-description-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem}.route-description-section h4{color:#374151;font-size:1rem;margin:0 0 .75rem}.route-description-section p{color:#6b7280;line-height:1.6;margin:0}@media (max-width:768px){.assigned-routes-list{grid-template-columns:1fr}.route-progress-overview{flex-direction:column;text-align:center}.progress-stats{justify-content:center}.waypoint-item{flex-direction:column}.waypoint-marker{align-self:flex-start}}.time-range-slider{-webkit-appearance:none;appearance:none;background:#0000;cursor:pointer;height:100%;left:0;margin:0;padding:0;position:absolute;top:0;width:100%}.time-range-start{z-index:3}.time-range-end{z-index:4}.time-range-slider::-webkit-slider-runnable-track{background:#0000;border-radius:3px;cursor:pointer;height:6px;width:100%}.time-range-slider::-moz-range-track{background:#0000;border-radius:3px;cursor:pointer;height:6px;width:100%}.time-range-start::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#667eea,#5a67d8);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #667eea80;cursor:grab;height:20px;margin-top:-7px;-webkit-transition:transform .1s ease,box-shadow .1s ease;transition:transform .1s ease,box-shadow .1s ease;width:20px}.time-range-start::-moz-range-thumb{background:linear-gradient(135deg,#667eea,#5a67d8);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #667eea80;cursor:grab;height:20px;-moz-transition:transform .1s ease,box-shadow .1s ease;transition:transform .1s ease,box-shadow .1s ease;width:20px}.time-range-end::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(135deg,#10b981,#059669);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #10b98180;cursor:grab;height:20px;margin-top:-7px;-webkit-transition:transform .1s ease,box-shadow .1s ease;transition:transform .1s ease,box-shadow .1s ease;width:20px}.time-range-end::-moz-range-thumb{background:linear-gradient(135deg,#10b981,#059669);border:3px solid #fff;border-radius:50%;box-shadow:0 2px 8px #10b98180;cursor:grab;height:20px;-moz-transition:transform .1s ease,box-shadow .1s ease;transition:transform .1s ease,box-shadow .1s ease;width:20px}.time-range-start:hover::-webkit-slider-thumb{box-shadow:0 4px 12px #667eea99;transform:scale(1.15)}.time-range-start:hover::-moz-range-thumb{box-shadow:0 4px 12px #667eea99;transform:scale(1.15)}.time-range-end:hover::-webkit-slider-thumb{box-shadow:0 4px 12px #10b98199;transform:scale(1.15)}.time-range-end:hover::-moz-range-thumb{box-shadow:0 4px 12px #10b98199;transform:scale(1.15)}.time-range-start:active::-webkit-slider-thumb{box-shadow:0 4px 16px #667eeab3;cursor:grabbing;transform:scale(1.2)}.time-range-start:active::-moz-range-thumb{box-shadow:0 4px 16px #667eeab3;cursor:grabbing;transform:scale(1.2)}.time-range-end:active::-webkit-slider-thumb{box-shadow:0 4px 16px #10b981b3;cursor:grabbing;transform:scale(1.2)}.time-range-end:active::-moz-range-thumb{box-shadow:0 4px 16px #10b981b3;cursor:grabbing;transform:scale(1.2)}.time-range-slider:focus{outline:none}.time-range-start:focus::-webkit-slider-thumb{box-shadow:0 0 0 4px #667eea4d,0 2px 8px #667eea80}.time-range-end:focus::-webkit-slider-thumb{box-shadow:0 0 0 4px #10b9814d,0 2px 8px #10b98180}.btn-view-tracking{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;margin-top:.75rem;padding:.625rem 1rem;transition:all .2s ease;width:100%}.btn-view-tracking:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-view-tracking:active{transform:translateY(0)}.route-tracking-map-modal{align-items:center;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.route-tracking-map-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;left:0;position:absolute;right:0;top:0}.route-tracking-map-content{background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;height:85vh;max-width:1400px;overflow:hidden;position:relative;width:95%}.route-tracking-map-header{align-items:flex-start;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1rem 1.5rem}.route-tracking-map-title h3{font-size:1.25rem;font-weight:600;margin:0 0 .25rem}.route-tracking-map-title p{font-size:.875rem;margin:0;opacity:.9}.btn-close-map{align-items:center;background:#fff3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.25rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.btn-close-map:hover{background:#ffffff4d}.route-tracking-map-body{flex:1 1;min-height:500px;overflow:hidden;position:relative}.route-tracking-map-footer{background:#f9fafb;border-top:1px solid #e5e7eb;padding:1rem 1.5rem}.route-info-row{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem}.route-info-item{color:#374151;font-size:.875rem;font-weight:500}@media (max-width:768px){.route-tracking-map-content{border-radius:12px;height:90vh;width:100%}.route-tracking-map-header{padding:1rem}.route-tracking-map-title h3{font-size:1.1rem}.route-tracking-map-title p{font-size:.8rem}.route-info-row{gap:.75rem;justify-content:center}.route-info-item{font-size:.8rem}}.map-loading-overlay{align-items:center;background:#f9fafb;display:flex;flex-direction:column;gap:1rem;height:100%;justify-content:center}.map-loading-overlay .spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;height:48px;width:48px}.map-loading-overlay p{color:#6b7280;font-size:.95rem}.map-no-data{align-items:center;background:#f9fafb;display:flex;height:100%;justify-content:center}.map-no-data p{color:#6b7280;font-size:1rem}.route-popup-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.route-popup-modal{animation:routePopupSlideIn .2s ease-out;background:#fff;border-radius:12px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;max-height:85vh;max-width:700px;width:90%}@keyframes routePopupSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.route-popup-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.route-popup-title{color:#6366f1;font-size:20px;font-weight:600;margin:0}.route-popup-close{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;transition:all .15s ease;width:36px}.route-popup-close:hover{background:#e5e7eb;color:#374151}.route-popup-body{flex:1 1;overflow-y:auto;padding:24px}.waypoints-popup-title{color:#374151;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 16px;text-transform:uppercase}.waypoints-popup-list{display:flex;flex-direction:column;gap:12px}.waypoint-popup-item{align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-radius:10px;display:flex;gap:16px;padding:16px;transition:all .15s ease}.waypoint-popup-item:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000d}.waypoint-popup-item.completed{background:#f0fdf4;border-color:#bbf7d0}.waypoint-popup-marker{align-items:center;background:#6366f1;border-radius:50%;color:#fff;display:flex;font-size:14px;font-weight:600;height:32px;justify-content:center;min-width:32px;width:32px}.waypoint-popup-item.completed .waypoint-popup-marker{background:#22c55e}.waypoint-popup-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.waypoint-popup-name{color:#1f2937;font-size:15px;font-weight:600}.waypoint-popup-address{color:#6b7280;font-size:13px}.waypoint-popup-coords{align-items:center;color:#6366f1;display:flex;font-family:Monaco,Menlo,Consolas,monospace;font-size:12px;gap:6px}.waypoint-popup-coords .coords-icon{color:#ef4444;font-size:10px}.waypoint-popup-completed-time{align-items:center;color:#22c55e;display:flex;font-size:12px;gap:6px;margin-top:4px}.waypoint-popup-completed-time .completed-icon{font-size:12px;font-weight:600}.waypoint-popup-status{align-items:center;border-radius:20px;display:flex;font-size:12px;font-weight:500;justify-content:center;padding:4px 12px;white-space:nowrap}.waypoint-popup-status.completed{background:#dcfce7;color:#166534}.waypoint-popup-status.pending{background:#fef3c7;color:#92400e}.waypoint-metadata-section{margin-top:10px;width:100%}.metadata-toggle-btn{align-items:center;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:13px;gap:8px;padding:8px 12px;transition:all .2s ease;width:100%}.metadata-toggle-btn:hover{background:#e5e7eb;border-color:#d1d5db}.metadata-toggle-btn.expanded{background:#eff6ff;border-bottom-left-radius:0;border-bottom-right-radius:0;border-color:#bfdbfe;color:#1d4ed8}.metadata-icon{font-size:14px}.metadata-label{flex:1 1;font-weight:500;text-align:left}.metadata-arrow{color:#6b7280;font-size:10px;transition:transform .2s ease}.metadata-arrow.expanded{color:#1d4ed8;transform:rotate(180deg)}.metadata-table-container{animation:slideDown .2s ease;background:#fff;border:1px solid #e5e7eb;border-radius:0 0 6px 6px;border-top:none;overflow:hidden}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:500px;opacity:1}}.metadata-table{border-collapse:collapse;font-size:12px;width:100%}.metadata-table thead{background:#f9fafb}.metadata-table th{border-bottom:1px solid #e5e7eb;color:#374151;font-size:11px;font-weight:600;letter-spacing:.5px;padding:8px 12px;text-align:left;text-transform:uppercase}.metadata-table tbody tr{transition:background .15s ease}.metadata-table tbody tr:hover{background:#f9fafb}.metadata-table tbody tr:not(:last-child){border-bottom:1px solid #f3f4f6}.metadata-table td{color:#4b5563;padding:8px 12px}.metadata-key{color:#1f2937;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.metadata-value{color:#6b7280;max-width:200px;word-break:break-word}.time-slider-unified{cursor:pointer;height:20px;position:relative;width:100%}.time-slider-track{background:#e2e8f0;left:0;right:0}.time-slider-range,.time-slider-track{border-radius:2px;height:4px;position:absolute;top:50%;transform:translateY(-50%)}.time-slider-range{background:linear-gradient(90deg,#667eea,#8b5cf6 50%,#10b981);transition:left .05s ease-out,width .05s ease-out}.time-slider-thumb{border:2px solid #fff;border-radius:50%;cursor:grab;height:18px;position:absolute;top:50%;transform:translate(-50%,-50%);transition:transform .15s ease,box-shadow .15s ease;width:18px;z-index:10}.time-slider-thumb:hover{transform:translate(-50%,-50%) scale(1.15)}.time-slider-thumb:active{cursor:grabbing;transform:translate(-50%,-50%) scale(1.2)}.time-slider-thumb-start{background:linear-gradient(135deg,#667eea,#5a67d8);box-shadow:0 2px 6px #667eea80}.time-slider-thumb-start:hover{box-shadow:0 3px 10px #667eea99}.time-slider-thumb-start:active{box-shadow:0 4px 12px #667eeab3}.time-slider-thumb-end{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 6px #10b98180}.time-slider-thumb-end:hover{box-shadow:0 3px 10px #10b98199}.time-slider-thumb-end:active{box-shadow:0 4px 12px #10b981b3}.time-slider-segment{border-radius:2px;height:4px;position:absolute;top:50%;transform:translateY(-50%);z-index:1}.time-slider-segment.has-data{background:linear-gradient(90deg,#10b981,#34d399)}.time-slider-segment.no-data{background:linear-gradient(90deg,#ef4444,#f87171);opacity:.8}.time-slider-selection{background:#667eea1a;border:2px solid #667eea99;border-radius:4px;height:8px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:5}.help-support-tab{background:#f8fafc;display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}.help-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0;padding:24px 32px}.help-header h1{font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0}.help-subtitle{font-size:14px;margin:8px 0 0;opacity:.9}.help-layout{display:flex;flex:1 1;min-height:0;overflow:hidden}.help-nav{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;min-width:260px;overflow-y:auto;width:260px}.help-nav-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e2e8f0;color:#1e293b;display:flex;font-size:14px;font-weight:600;gap:10px;padding:16px 20px}.nav-icon{font-size:18px}.help-nav-list{list-style:none;margin:0;padding:8px}.help-nav-item{align-items:center;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:13px;gap:10px;margin:2px 0;padding:10px 14px;transition:all .2s ease}.help-nav-item:hover{background:#f1f5f9;color:#1e293b}.help-nav-item.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-weight:500}.nav-item-icon{font-size:16px;text-align:center;width:20px}.nav-item-label{flex:1 1}.help-content{flex:1 1;overflow-y:auto;padding:24px 32px}.help-section{background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #00000014;margin-bottom:8px;margin-top:8;overflow:hidden}.help-section:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000001a}.section-header{background:#fff;border-radius:10px;cursor:pointer;padding:14px 16px;transition:background-color .15s ease}.section-header:hover{background:#f8fafc}.section-header h2{align-items:center;color:#1e293b;display:flex;font-size:14px;font-weight:600;gap:10px;margin:20px}.section-icon{display:inline-block;font-size:16px;line-height:1}.expand-icon{color:#94a3b8;font-size:10px;margin:20px;transition:transform .2s ease,color .2s ease}.section-header:hover .expand-icon{color:#6366f1}.expand-icon.expanded{color:#6366f1;transform:rotate(180deg)}.section-content{background:#f8fafc;display:none}.section-content.expanded{border-top:1px solid #e2e8f0;display:block;padding:16px 20px}.subsection{margin-bottom:24px}.subsection:last-child{margin-bottom:0}.subsection h3{border-bottom:2px solid #e2e8f0;color:#334155;font-size:15px;font-weight:600;margin:0 0 12px;padding-bottom:8px}.subsection h4{color:#475569;font-size:14px;font-weight:600;margin:16px 0 8px}.subsection p{color:#64748b;font-size:14px;line-height:1.6;margin:0 0 12px}.info-card{background:#f8fafc;border-left:4px solid #667eea;border-radius:10px;margin-bottom:20px;padding:16px 20px}.info-card.highlight{background:linear-gradient(135deg,#667eea14,#764ba214);border-left-color:#764ba2}.info-card h3{color:#1e293b;font-size:16px;font-weight:600;margin:0 0 8px}.info-card h4{color:#334155;font-size:14px;font-weight:600;margin:0 0 12px}.info-card p{color:#64748b;font-size:14px;line-height:1.6;margin:0}.styled-list{list-style:none;margin:0;padding:0}.styled-list li{color:#475569;font-size:14px;line-height:1.5;padding:8px 0 8px 24px;position:relative}.styled-list li:before{color:#667eea;content:"•";font-weight:700;left:8px;position:absolute}.styled-list li strong{color:#1e293b}.numbered-list{margin:0;padding-left:20px}.numbered-list li{color:#475569;font-size:14px;line-height:1.5;padding:6px 0}.numbered-list li::marker{color:#667eea;font-weight:600}.numbered-list ul{margin:8px 0;padding-left:20px}.numbered-list ul li{padding:4px 0}.feature-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.feature-item{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px}.feature-icon{font-size:28px;margin-bottom:12px}.feature-item h4{color:#1e293b;font-size:15px;font-weight:600;margin:0 0 10px}.feature-item ul{list-style:none;margin:0;padding:0}.feature-item li{color:#64748b;font-size:13px;line-height:1.4;padding:4px 0}.feature-item li strong{color:#334155}.control-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:12px}.control-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;gap:12px;padding:10px 14px}.control-key{color:#667eea;font-size:13px;font-weight:600;min-width:60px}.control-desc{color:#64748b;font-size:13px}.format-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-top:12px}.format-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;padding:12px;text-align:center}.format-ext{background:#f1f5f9;border-radius:4px;color:#667eea;font-family:monospace;font-size:13px;font-weight:600;margin-bottom:6px;padding:4px 10px}.format-name{color:#64748b;font-size:12px}.viz-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr);margin-bottom:20px}.viz-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px;text-align:center;transition:all .2s ease}.viz-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26}.viz-icon{font-size:32px;margin-bottom:10px}.viz-card h4{color:#1e293b;font-size:14px;font-weight:600;margin:0 0 8px}.viz-card p{color:#64748b;font-size:12px;line-height:1.4;margin:0}.operator-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.operator-item{background:#f8fafc;border-radius:8px;display:flex;flex-direction:column;padding:12px}.op-name{color:#667eea;font-family:monospace;font-size:13px;font-weight:600;margin-bottom:4px}.op-desc{color:#64748b;font-size:12px}.tools-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:20px}.tool-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:16px;text-align:center;transition:all .2s ease}.tool-card:hover{border-color:#667eea;box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.tool-icon{font-size:28px;margin-bottom:10px}.tool-card h4{color:#1e293b;font-size:14px;font-weight:600;margin:0 0 6px}.tool-card p{color:#64748b;font-size:12px;line-height:1.4;margin:0}.shortcuts-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr)}.shortcut-item{align-items:center;background:#f8fafc;border-radius:8px;display:flex;gap:16px;padding:12px 16px}.shortcut-keys{background:#334155;border-radius:6px;color:#fff;font-family:monospace;font-size:13px;font-weight:600;min-width:80px;padding:6px 12px;text-align:center}.shortcut-action{color:#475569;font-size:13px}.trouble-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.trouble-card{background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;padding:16px}.trouble-card h4{color:#c2410c;font-size:14px;font-weight:600;margin:0 0 12px}.trouble-card ul{list-style:none;margin:0;padding:0}.trouble-card li{color:#78350f;font-size:13px;padding:4px 0 4px 20px;position:relative}.trouble-card li:before{color:#16a34a;content:"✓";font-weight:700;left:0;position:absolute}.contact-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}.contact-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:20px;text-align:center}.contact-icon{font-size:32px;margin-bottom:12px}.contact-card h4{color:#1e293b;font-size:14px;font-weight:600;margin:0 0 10px}.contact-card a{color:#667eea;font-size:14px;text-decoration:none;transition:color .2s ease}.contact-card a:hover{color:#764ba2;text-decoration:underline}.status-grid{display:flex;flex-direction:column;gap:10px}.status-item{align-items:center;background:#f8fafc;border-radius:8px;color:#475569;display:flex;font-size:13px;gap:10px;padding:10px 14px}.status-dot{border-radius:50%;height:10px;width:10px}.status-item.active .status-dot{background:#22c55e}.status-item.inactive .status-dot{background:#ef4444}@media (max-width:1200px){.tools-grid,.viz-grid{grid-template-columns:repeat(2,1fr)}.contact-grid{grid-template-columns:1fr}}@media (max-width:900px){.help-layout{flex-direction:column}.help-nav{border-bottom:1px solid #e2e8f0;border-right:none;max-height:200px;min-width:auto;width:100%}.help-nav-list{display:flex;flex-wrap:wrap;gap:4px}.help-nav-item{flex:0 0 auto}.format-grid{grid-template-columns:repeat(2,1fr)}.control-grid{grid-template-columns:1fr}.operator-grid{grid-template-columns:repeat(2,1fr)}.shortcuts-grid,.trouble-grid{grid-template-columns:1fr}}.help-content::-webkit-scrollbar,.help-nav::-webkit-scrollbar{width:6px}.help-content::-webkit-scrollbar-track,.help-nav::-webkit-scrollbar-track{background:#0000}.help-content::-webkit-scrollbar-thumb,.help-nav::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.help-content::-webkit-scrollbar-thumb:hover,.help-nav::-webkit-scrollbar-thumb:hover{background:#94a3b8}.user-profile-overlay{align-items:center;animation:fadeIn .3s ease-in-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.user-profile-container{animation:slideUp .3s ease-out;background:#f5f7fa;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;height:95vh;max-width:1600px;overflow:hidden;width:95vw}.profile-navbar{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;justify-content:space-between;padding:.375rem 2rem}.navbar-brand,.profile-navbar{align-items:center;display:flex}.navbar-brand{gap:1rem}.navbar-logo{height:60px;margin-left:47px;object-fit:contain;width:auto}.navbar-title{color:#fff;font-size:1.5rem;font-weight:700}.navbar-actions{display:flex;gap:1rem}.navbar-btn{background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:calc(.5rem + 3px) 1.5rem;transition:all .3s ease}.navbar-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.navbar-btn-logout{background:#ef4444cc}.navbar-btn-logout:hover{background:#ef4444}.profile-layout{display:flex;flex:1 1;overflow:hidden}.profile-sidebar{background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;overflow-y:auto;width:280px}.sidebar-user-info{background:linear-gradient(135deg,#667eea15,#764ba215);border-bottom:1px solid #e2e8f0;padding:2rem 1.5rem;text-align:center}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;box-shadow:0 4px 12px #667eea4d;color:#fff;display:flex;font-size:2rem;font-weight:700;height:80px;justify-content:center;margin:0 auto 1rem;width:80px}.user-name{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.user-email{color:#718096;font-size:.85rem;margin:0 0 .75rem}.user-role-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.sidebar-menu{flex:1 1;padding:1rem 0}.sidebar-menu-item{align-items:center;background:#0000;border:none;border-left:3px solid #0000;color:#4a5568;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.75rem;padding:1rem 1.5rem;transition:all .2s ease;width:100%}.sidebar-menu-item:hover{background:#f7fafc;color:#667eea}.sidebar-menu-item.active{background:linear-gradient(90deg,#667eea15,#0000);border-left-color:#667eea;color:#667eea;font-weight:600}.menu-item-icon{align-items:center;display:flex;font-size:1.25rem;justify-content:center}.menu-item-svg-icon{height:24px;object-fit:contain;width:24px}.menu-item-label{flex:1 1;text-align:left}.profile-main-content{background:#f5f7fa;flex:1 1;overflow-y:auto;padding:2rem}.profile-main-content:has(.help-support-tab){overflow:hidden;padding:0}.tab-title{border-bottom:3px solid #e2e8f0;color:#1a202c;display:inline-block;font-size:2rem;font-weight:700;margin:0 0 2rem;padding-bottom:1rem;position:relative}.tab-title:after{background:linear-gradient(135deg,#667eea,#764ba2);bottom:-3px;content:"";height:3px;left:0;position:absolute;transform:scaleX(.5);transform-origin:left;transition:transform .3s ease;width:100%}.dataset-assign-tab{display:flex;flex-direction:column;gap:.5rem}.assignments-section{margin-top:0}.tab-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.tab-actions{display:flex;gap:.75rem}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:400;gap:6px;justify-content:center;padding:8px 16px;transition:all .2s ease}.btn:disabled{cursor:not-allowed;opacity:.5}.btn:active:not(:disabled){transform:translateY(0)}.btn svg{flex-shrink:0;height:16px;width:16px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 4px #667eea4d;color:#fff;overflow:hidden;position:relative}.btn-primary:before{background:linear-gradient(135deg,#fff3,#fff0);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .3s ease;width:100%}.btn-primary:hover:before{left:100%}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #667eea80;transform:translateY(-2px)}.btn-secondary{background:#f8fafc;border:1.5px solid #cbd5e0;color:#4a5568}.btn-secondary:hover:not(:disabled){background:#edf2f7;border-color:#a0aec0;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.btn-success{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 4px #22c55e4d;color:#fff}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 8px #22c55e66;transform:translateY(-2px)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d;color:#fff}.btn-warning:hover:not(:disabled){background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 8px #f59e0b66;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 4px #ef44444d;color:#fff}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 8px #ef444466;transform:translateY(-2px)}.btn-danger-outline{background:#0000;border:1.5px solid #dc2626;color:#dc2626}.btn-danger-outline:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 8px #ef444466;color:#fff;transform:translateY(-2px)}.btn-info{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d;color:#fff}.btn-info:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #3b82f666;transform:translateY(-2px)}.btn-group{display:flex;gap:.5rem}.assign-form-card,.profile-form-card{background:#fff;border:1px solid #e2e8f0cc;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:2rem;padding:1.75rem;transition:all .3s ease}.assign-form-card:hover{border-color:#667eea4d;box-shadow:0 4px 16px #0000001f}.assign-form-card h3{border-bottom:2px solid #e2e8f0;color:#1a202c;font-size:1.25rem;font-weight:600;margin:0 0 1.5rem;padding-bottom:1rem;position:relative}.assign-form-card h3:after{background:linear-gradient(135deg,#667eea,#764ba2);bottom:-2px;content:"";height:2px;left:0;position:absolute;width:60px}.card-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.card-header h3{color:#2d3748;font-size:1.375rem;font-weight:600;margin:0}.form-grid{grid-gap:.85rem;display:grid;gap:.85rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.form-grid-single-row{grid-gap:1rem;align-items:end!important;display:grid;gap:1rem;grid-template-columns:2fr 2fr 1.5fr 1.5fr}.form-grid-single-row .form-group{align-items:stretch!important;display:flex!important;flex-direction:column!important;gap:.5rem!important;justify-content:flex-end!important;margin:0!important;padding:0!important}.form-grid-single-row .form-input,.form-grid-single-row .form-select{box-sizing:border-box!important;height:42px!important;line-height:normal!important;padding:.625rem .875rem!important}.form-grid-single-row .form-group label{display:block!important;font-size:.75rem!important;height:1.2rem!important;line-height:1.2rem!important;margin-bottom:0!important;max-height:1.2rem!important;min-height:1.2rem!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-grid-single-row input[type=date]{background:#fff!important;border:1.5px solid #e2e8f0!important;border-radius:8px!important;box-sizing:border-box!important;color:#374151!important;cursor:pointer;font-size:.9rem!important;font-weight:500!important;height:42px!important;line-height:normal!important;padding:.625rem .875rem!important;transition:all .2s ease;vertical-align:bottom!important}.form-grid-single-row input[type=date]:hover{background:#fff!important;border-color:#667eea!important;box-shadow:0 2px 6px #667eea1a!important}.form-grid-single-row input[type=date]:focus{background:#fff!important;border-color:#667eea!important;box-shadow:0 0 0 4px #667eea26!important;outline:none!important}.assign-form-card .btn-primary{margin-top:1.25rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{color:#4a5568;font-size:.8rem;font-weight:500;letter-spacing:.3px;text-transform:uppercase}.form-input,.form-select,.form-textarea{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;color:#374151;font-size:.9rem;padding:.625rem .875rem;transition:all .2s ease}.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;cursor:pointer;font-weight:500;padding-right:40px}.form-select option{background:#fff;color:#374151;font-size:.9rem;padding:12px 16px}.form-select option:checked,.form-select option:hover{background:#3b82f6;color:#fff}.form-input:hover,.form-select:hover,.form-textarea:hover{background:#fff;border-color:#667eea;box-shadow:0 2px 6px #667eea1a}.form-input:focus,.form-select:focus,.form-textarea:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 4px #667eea26;outline:none}.form-input:disabled,.form-select:disabled{background:#f7fafc;cursor:not-allowed}.form-textarea{font-family:inherit;resize:vertical}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .3s ease}.stat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-4px)}.stat-card-blue{border-left-color:#3b82f6}.stat-card-green{border-left-color:#10b981}.stat-card-purple{border-left-color:#8b5cf6}.stat-card-orange{border-left-color:#f59e0b}.stat-icon{font-size:2.5rem}.stat-content{flex:1 1}.stat-value{color:#2d3748;font-size:2rem;font-weight:700;margin:0 0 .25rem}.stat-label{color:#718096;font-size:.875rem;margin:0}.assignments-grid,.datasets-grid,.users-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.assignment-card,.dataset-card,.user-card{background:#fff;border:1px solid #e2e8f099;border-radius:10px;box-shadow:0 2px 8px #00000014;overflow:hidden;padding:1rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.assignment-card:before,.dataset-card:before,.user-card:before{background:linear-gradient(135deg,#667eea,#764ba2);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.assignment-card:hover,.dataset-card:hover,.user-card:hover{border-color:#667eea4d;box-shadow:0 8px 24px #0000001f;transform:translateY(-6px)}.assignment-card:hover:before,.dataset-card:hover:before,.user-card:hover:before{opacity:1}.assignment-card-header,.dataset-card-header{align-items:flex-start;display:flex;gap:.75rem;justify-content:space-between;margin-bottom:.75rem}.assignment-card-header h3,.assignment-card-header h4,.dataset-card-header h3{color:#1a202c;flex:1 1;font-size:1rem;font-weight:600;line-height:1.3;margin:0;word-break:break-word}.dataset-type-badge{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:5px;box-shadow:0 2px 4px #667eea4d;color:#fff;font-size:.65rem;font-weight:600;letter-spacing:.5px;padding:.25rem .6rem;text-transform:uppercase;white-space:nowrap}.dataset-badges{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}.ownership-badge{border-radius:5px;font-size:.65rem;font-weight:600;letter-spacing:.5px;padding:.25rem .6rem;text-transform:uppercase;white-space:nowrap}.ownership-badge.owned{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d;color:#fff}.ownership-badge.assigned{color:#fff}.ownership-badge.assigned.permission-view{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d}.ownership-badge.assigned.permission-edit{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d}.ownership-badge.assigned.permission-download{background:linear-gradient(135deg,#8b5cf6,#7c3aed);box-shadow:0 2px 4px #8b5cf64d}.route-status-badge{border-radius:5px;color:#fff;font-size:.65rem;font-weight:600;letter-spacing:.5px;padding:.25rem .6rem;text-transform:uppercase;white-space:nowrap}.route-status-badge.badge-pending{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d}.route-status-badge.badge-in_progress{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d}.route-status-badge.badge-completed{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d}.priority-badge{border-radius:4px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.3px;padding:.125rem .5rem;text-transform:capitalize}.priority-badge.priority-low{background:#dbeafe;color:#1e40af}.priority-badge.priority-medium{background:#fef3c7;color:#92400e}.priority-badge.priority-high{background:#fee2e2;color:#991b1b}.assignment-card-body,.dataset-card-body{display:flex;flex-direction:column}.dataset-description{color:#4a5568;font-size:.8rem;line-height:1.4;margin-bottom:.6rem}.dataset-meta{display:flex}.assignment-meta,.dataset-meta{flex-direction:column;gap:.5rem;padding:.25rem 0}.assignment-meta-grid{display:flex;flex-direction:column;gap:.35rem;padding:.25rem 0}.meta-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.assignment-meta-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;padding:.25rem 0}.assignment-meta-left,.assignment-meta-right{display:flex;flex-direction:column;gap:.5rem}.assignment-meta-left{text-align:left}.assignment-meta-right{text-align:right}.assignment-meta-right .meta-item{justify-content:flex-end}.meta-item{align-items:center;border-bottom:1px solid #f7fafc;display:flex;font-size:.8rem;justify-content:space-between;padding:.35rem 0}.meta-item:last-child{border-bottom:none}.meta-label{align-items:center;color:#718096;display:flex;flex-shrink:0;font-size:.75rem;font-weight:500;gap:.3rem;text-align:left}.meta-value{color:#1a202c;flex-shrink:0;font-size:.8rem;font-weight:600;margin-left:auto;text-align:right}.meta-value.expiring{color:#f59e0b;font-weight:700}.permission-badge,.role-badge,.status-badge,.visibility-badge{border-radius:4px;font-size:.75rem;font-weight:600;padding:.25rem .5rem;text-transform:uppercase}.visibility-badge.public{background:#d1fae5;color:#065f46}.visibility-badge.private{background:#fee2e2;color:#991b1b}.permission-badge{box-shadow:0 2px 4px #00000026}.permission-view{background:linear-gradient(135deg,#60a5fa,#3b82f6)}.permission-edit{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.permission-delete{background:linear-gradient(135deg,#f87171,#ef4444)}.status-badge{color:#fff}.status-badge.active{background:#10b981}.status-badge.inactive{background:#6b7280}.role-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.assignment-notes{background:linear-gradient(135deg,#f7fafc,#edf2f7);border-left:3px solid #667eea;border-radius:6px;color:#4a5568;font-size:.8rem;line-height:1.5;margin-top:.75rem;padding:.75rem}.assignment-notes strong{color:#2d3748;font-weight:600}.dataset-card-actions{align-items:center;border-top:2px solid #f7fafc;display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.dataset-card-actions .btn-action-add-map{margin-right:auto}.assignment-card-actions,.user-card-actions{align-items:center;border-top:2px solid #f7fafc;display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.assignment-card-actions .btn-action-add-map{margin-right:auto}.btn-action{display:inline-flex;font-size:13px;font-weight:400;gap:6px;padding:8px 14px}.btn-action:active{transform:translateY(0)}.btn-action svg{flex-shrink:0;height:14px;width:14px}.btn-action-add-map{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 4px #22c55e4d;color:#fff}.btn-action-add-map:hover{background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 8px #22c55e66;transform:translateY(-2px)}.btn-action-delete{background:#0000;border:1.5px solid #dc2626;color:#dc2626}.btn-action-delete:hover{background:#dc2626;box-shadow:0 4px 8px #ef444466;color:#fff;transform:translateY(-2px)}.btn-action-download{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 4px #3b82f64d;color:#fff}.btn-action-download:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 8px #3b82f666;transform:translateY(-2px)}.btn-action-edit{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 4px #667eea4d;color:#fff}.btn-action-edit:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);box-shadow:0 4px 8px #667eea66;transform:translateY(-2px)}.btn-action-view{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 4px #6b72804d}.btn-action-view:hover{background:linear-gradient(135deg,#4b5563,#374151);box-shadow:0 4px 8px #6b728066;transform:translateY(-2px)}.btn-action-favorite{color:#6b7280;transition:all .2s ease}.btn-action-favorite:hover{background:#facc1526;color:#facc15}.btn-action-favorite.active,.btn-action-favorite.is-favorite{color:#facc15}.btn-action-favorite.active:hover,.btn-action-favorite.is-favorite:hover{background:#facc1533;color:#eab308}.btn-action-favorite:disabled{cursor:not-allowed;opacity:.5}.btn-action-favorite svg{transition:transform .2s ease}.btn-action-favorite:hover svg{transform:scale(1.1)}.btn-action-favorite.active svg,.btn-action-favorite.is-favorite svg{filter:drop-shadow(0 0 4px rgba(250,204,21,.5))}.user-card{display:flex;gap:1rem}.user-card-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:60px;justify-content:center;width:60px}.user-card-info{flex:1 1}.user-card-info h4{color:#2d3748;font-size:1rem;font-weight:600;margin:0 0 .25rem}.user-card-email{color:#718096;font-size:.85rem;margin:0 0 .5rem}.user-card-meta{display:flex;gap:.5rem;margin-bottom:.5rem}.user-card-date{color:#a0aec0;font-size:.8rem;margin:0}.user-card-actions{position:absolute;right:1rem;top:1rem}.user-management-section{margin-top:2rem}.section-header{align-items:center;border-bottom:2px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1rem;position:relative}.section-header:after{background:linear-gradient(135deg,#667eea,#764ba2);bottom:-2px;content:"";height:2px;left:0;position:absolute;width:80px}.section-header h3{align-items:center;color:#1a202c;display:flex;font-size:1.5rem;gap:.5rem;margin:0}.user-view-tabs{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;gap:.5rem;padding:.25rem}.tab-btn{background:#0000;border:none;border-radius:6px;color:#4a5568;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.tab-btn:hover{background:#f7fafc}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-overlay{align-items:flex-start!important;padding-top:100px!important;z-index:10001}.modal-content{max-height:80vh;max-width:500px;padding:2rem}.modal-header{margin-bottom:1.5rem;padding-bottom:1rem}.modal-header h3{font-size:1.5rem}.modal-close{background:#0000;font-size:1.75rem;height:32px;transition:all .2s ease;width:32px}.modal-actions{border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem}.coming-soon,.empty-state,.loading-state{align-items:center;background:linear-gradient(135deg,#fafbfc,#f7fafc);border:2px dashed #e2e8f0;border-radius:12px;color:#718096;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:4rem 2rem;text-align:center}.spinner{border:4px solid #e2e8f0;box-shadow:0 2px 8px #667eea33;height:48px;width:48px}.empty-state p,.loading-state p{color:#4a5568;font-size:1rem;font-weight:500;margin-top:1.5rem}.loading-spinner{flex-direction:column;min-height:400px}.loading-spinner,.user-profile-loading-container{align-items:center;display:flex;justify-content:center}.user-profile-loading-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#f5f7faf2;border-radius:12px;height:100%;width:100%}.loading-spinner-wrapper{align-items:center;display:flex;flex-direction:column;gap:1.5rem;justify-content:center;padding:3rem}.professional-spinner{height:80px;position:relative;width:80px}.spinner-ring{animation:spin-ring 1.5s cubic-bezier(.5,0,.5,1) infinite;border:3px solid #0000;border-radius:50%;border-top-color:#667eea;height:100%;position:absolute;width:100%}.spinner-ring:first-child{animation-delay:-.45s;border-top-color:#667eea}.spinner-ring:nth-child(2){animation-delay:-.3s;border-top-color:#764ba2}.spinner-ring:nth-child(3){animation-delay:-.15s;border-top-color:#f093fb}.spinner-ring:nth-child(4){border-top-color:#4facfe}@keyframes spin-ring{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{color:#2d3748;font-size:1.25rem;font-weight:600;letter-spacing:.5px;margin:0}.loading-subtext{color:#718096;font-size:.95rem;font-weight:400;margin:0}.coming-soon{background:#fff;border-radius:8px;padding:3rem}.coming-soon p{font-size:1.1rem;margin:.5rem 0}.coming-soon ul{line-height:1.8;margin:1.5rem auto 0;max-width:400px;text-align:left}.welcome-message{background:#fff;border-radius:8px;padding:2rem;text-align:center}.welcome-message h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 1rem}.welcome-message p{color:#718096;font-size:1rem;margin:0}@media (max-width:768px){.profile-layout{flex-direction:column}.profile-sidebar{max-height:200px;width:100%}.assignments-grid,.datasets-grid,.stats-grid,.users-grid{grid-template-columns:1fr}.navbar-title{display:none}.form-grid{grid-template-columns:1fr}.tab-header{align-items:flex-start;flex-direction:column;gap:1rem}.user-view-tabs{width:100%}}.field-users-table{margin-top:1.5rem;overflow-x:auto}.data-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 4px #0000000d;overflow:hidden;width:100%}.data-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.data-table th{font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left}.data-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:.9rem;padding:1rem}.data-table tbody tr:hover{background:#f7fafc}.data-table tbody tr.inactive-row{background:#fef2f2;opacity:.6}.user-cell{gap:.75rem}.user-avatar-small,.user-cell{align-items:center;display:flex}.user-avatar-small{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;flex-shrink:0;font-size:.9rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-name-cell{color:#2d3748;font-weight:600;margin-bottom:.25rem}.user-branch{color:#718096;font-size:.8rem}.form-input-inline{border:1px solid #cbd5e0;border-radius:4px;color:#000;font-size:.9rem;padding:.5rem;width:100%}.form-input-inline:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.action-buttons{gap:.5rem}.action-buttons,.btn-icon{align-items:center;display:flex}.btn-icon{border:none;border-radius:6px;box-shadow:0 1px 3px #0000001f;cursor:pointer;font-size:.875rem;font-weight:500;height:36px;justify-content:center;overflow:hidden;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);width:36px}.btn-icon:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-icon:active{box-shadow:0 1px 3px #0000001f;transform:translateY(0)}.btn-primary-icon{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary-icon:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f)}.btn-success-icon{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success-icon:hover{background:linear-gradient(135deg,#059669,#047857)}.btn-secondary-icon{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.btn-secondary-icon:hover{background:linear-gradient(135deg,#4b5563,#374151)}.btn-info-icon{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-info-icon:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.btn-danger-icon{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.btn-danger-icon:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.assignments-row{background:#f8f9fa}.assignments-container{background:#fff;border:2px solid #e2e8f0;border-radius:8px;margin:.5rem;padding:1.5rem}.assignments-container h4{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0 0 1rem}.assignments-list{display:flex;flex-direction:column;gap:.75rem}.assignment-item{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:1rem;padding:.75rem}.assignment-icon{font-size:1.5rem}.assignment-details{flex:1 1}.assignment-name{color:#2d3748;font-weight:600;margin-bottom:.25rem}.assignment-meta{align-items:center;display:flex;font-size:.85rem;gap:1rem}.permission-badge{background:#667eea;border-radius:12px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.assignment-date{color:#718096}.no-assignments{color:#718096;font-size:.9rem;margin:0;padding:1rem;text-align:center}.section-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.section-header>div{flex:1 1}.section-header h3{color:#2d3748;font-size:1.3rem;font-weight:600;margin:0 0 .5rem}.section-description{color:#718096;font-size:.9rem;margin:0}.modal-overlay{align-items:center;background:#00000080}.modal-content{border-radius:8px;max-width:450px;overflow-y:auto;width:90%}.modal-header{border-bottom:1px solid #e2e8f0;padding:1rem 1.25rem}.modal-header h3{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#718096;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:background .2s ease}.modal-close:hover{background:#f7fafc;color:#2d3748}.add-user-form{padding:1.25rem}.add-user-form .form-group{margin-bottom:1rem}.add-user-form .form-group:last-of-type{margin-bottom:0}.add-user-form label{color:#2d3748;display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem}.add-user-form .form-input{border:1px solid #cbd5e0;border-radius:6px;color:#000;font-size:.9rem;padding:.6rem;transition:all .2s ease;width:100%}.add-user-form .form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:.6rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.btn-create-db{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;justify-content:center;padding:.625rem 1.25rem;transition:all .2s ease}.btn-create-db:hover{background:linear-gradient(135deg,#764ba2,#667eea);box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-create-db:active{box-shadow:0 2px 6px #667eea4d;transform:translateY(0)}.modal-overlay-designer{align-items:center;animation:fadeIn .2s ease-in-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000bf;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:100000}.form-designer-modal{max-height:85vh;max-width:700px}.form-designer-modal,.upload-dataset-modal{animation:modalSlideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;overflow:hidden;width:90%}.upload-dataset-modal{max-width:500px;min-height:600px}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.form-designer-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #ffffff1a;color:#fff;display:flex;justify-content:space-between;padding:1rem 1.5rem}.form-designer-header h2{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;margin:0}.btn-close-designer{align-items:center;background:#fff3;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.btn-close-designer:hover{background:#ffffff4d;transform:rotate(90deg)}.form-designer-body{background:#f9fafb;flex:1 1;overflow-y:auto;padding:1.25rem}.designer-section{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #00000014;margin-bottom:1rem;padding:1rem}.section-title{color:#1f2937;font-size:1rem}.required-asterisk{color:#ef4444;font-size:1rem;margin-left:4px}.form-group-designer{margin-bottom:1rem}.form-group-designer:last-child{margin-bottom:0}.label-designer{color:#374151;display:block;font-size:.8125rem;font-weight:600;margin-bottom:.4rem}.input-designer,.textarea-designer{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#1f2937;font-family:inherit;font-size:.875rem;padding:.625rem .875rem;transition:all .2s ease;width:100%}.input-designer:focus,.textarea-designer:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.textarea-designer{min-height:50px;resize:vertical}.csv-import-container{display:flex;flex-direction:column;gap:.5rem}.btn-csv-import{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 2px 6px #10b98140;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.625rem 1rem;transition:all .2s ease;width:-webkit-fit-content;width:fit-content}.btn-csv-import:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 10px #10b98159;transform:translateY(-1px)}.btn-csv-import:active{box-shadow:0 2px 4px #10b98140;transform:translateY(0)}.btn-csv-import.loading{background:linear-gradient(135deg,#6b7280,#4b5563);cursor:not-allowed;opacity:.7}.btn-csv-import.loading:hover{box-shadow:0 2px 6px #6b728040;transform:none}.btn-csv-import svg{height:16px;width:16px}.csv-import-hint{color:#6b7280;font-size:.75rem;line-height:1.4;margin:0}.geometry-type-selector{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr}.geometry-type-btn{align-items:center;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex-direction:row;font-weight:600;gap:.75rem;justify-content:flex-start;padding:.875rem 1rem;transition:all .2s ease}.geometry-type-btn:hover{background:#faf5ff;border-color:#8b5cf6;transform:translateX(3px)}.geometry-type-btn.active{background:linear-gradient(135deg,#f3e8ff,#faf5ff);border-color:#8b5cf6;box-shadow:0 0 0 2px #8b5cf626;color:#7c3aed}.geom-icon{font-size:1.5rem}.geom-label{font-size:.875rem}.section-header-with-action{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.btn-add-field{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 2px 6px #10b98133;color:#fff;cursor:pointer;display:inline-flex;font-size:.8125rem;font-weight:600;gap:5px;padding:.5rem .875rem;transition:all .2s ease}.btn-add-field:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 10px #10b98159;transform:translateY(-1px)}.fields-list{display:flex;flex-direction:column;gap:1rem}.field-definition-card{background:#f9fafb;border:1.5px solid #e5e7eb;border-radius:8px;overflow:hidden;transition:all .2s ease}.field-definition-card:hover{border-color:#d1d5db;box-shadow:0 2px 6px #0000000a}.field-card-header{align-items:center;background:#f3f4f6;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:.625rem .875rem}.field-number{color:#6b7280;font-size:.8125rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase}.field-header-left{align-items:center;display:flex;gap:.625rem}.required-tag{align-items:center;background:linear-gradient(135deg,#dc2626,#ef4444);border-radius:10px;box-shadow:0 1px 2px #dc26264d;color:#fff;display:inline-flex;font-size:.6875rem;font-weight:600;gap:4px;letter-spacing:.05em;padding:2px 8px;text-transform:uppercase}.required-tag svg{flex-shrink:0}.btn-remove-field{align-items:center;background:#0000;border:none;border-radius:4px;color:#ef4444;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.btn-remove-field:hover{background:#fee2e2;color:#dc2626}.field-card-body{padding:1rem}.field-row{display:flex;gap:.875rem;margin-bottom:.875rem}.field-row:last-child{margin-bottom:0}.field-col,.field-col-full{flex:1 1}.label-designer-small{color:#4b5563;display:block;font-size:.75rem;font-weight:600;margin-bottom:.375rem}.input-designer-small,.select-designer-small{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#1f2937;font-size:.8125rem;padding:.5rem .75rem;transition:all .2s ease;width:100%}.input-designer-small:focus,.select-designer-small:focus{border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a;outline:none}.checkbox-label{align-items:center;color:#4b5563;cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:.5rem}.checkbox-label input[type=checkbox]{accent-color:#8b5cf6;cursor:pointer;height:16px;width:16px}.form-designer-footer{align-items:center;background:#fff;border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:space-between;padding:1rem 1.25rem}.btn-designer-cancel{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:all .2s ease}.btn-designer-cancel:hover{background:#f9fafb;border-color:#d1d5db;color:#374151}.btn-designer-create{align-items:center;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:6px;box-shadow:0 3px 10px #8b5cf640;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:all .2s ease}.btn-designer-create:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 5px 14px #8b5cf659;transform:translateY(-1px)}.btn-designer-create:active{box-shadow:0 2px 8px #8b5cf640;transform:translateY(0)}.photo-field-info{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #bae6fd;border-radius:8px;padding:.875rem}.photo-field-header{align-items:center;color:#0369a1;display:flex;gap:.5rem;margin-bottom:.625rem}.photo-field-title{color:#0369a1;font-size:.8125rem;font-weight:600}.photo-metadata-info{padding-left:.25rem}.photo-info-text{color:#0c4a6e;font-size:.75rem;line-height:1.4;margin:0 0 .5rem}.metadata-list{list-style:none;margin:0;padding-left:1rem}.metadata-list li{color:#075985;font-size:.6875rem;margin-bottom:.25rem;padding-left:.75rem;position:relative}.metadata-list li:before{background:#0ea5e9;border-radius:50%;content:"";height:4px;left:0;position:absolute;top:.375rem;width:4px}.metadata-list li strong{color:#0369a1;font-weight:600}.dropdown-field-info{background:linear-gradient(135deg,#faf5ff,#f3e8ff);border:1px solid #e9d5ff;border-radius:8px;padding:.875rem}.dropdown-field-header{align-items:center;color:#7c3aed;display:flex;gap:.5rem;margin-bottom:.75rem}.dropdown-field-title{color:#7c3aed;font-size:.8125rem;font-weight:600}.dropdown-preset-badge{background:linear-gradient(135deg,#7c3aed,#8b5cf6);border-radius:10px;color:#fff;font-size:.625rem;font-weight:600;letter-spacing:.05em;margin-left:auto;padding:2px 8px;text-transform:uppercase}.dropdown-options-input{margin-bottom:.625rem}.dropdown-options-input .label-designer-small{color:#6b21a8}.dropdown-info-note{align-items:flex-start;background:#7c3aed14;border-radius:4px;display:flex;gap:.5rem;padding:.5rem}.dropdown-info-note svg{color:#7c3aed;flex-shrink:0;margin-top:.125rem}.dropdown-info-note span{color:#6b21a8;font-size:.6875rem;line-height:1.4}@media (max-width:768px){.form-designer-modal{border-radius:0;max-height:100vh;width:100%}.form-designer-body{padding:1.25rem}.geometry-type-selector{grid-template-columns:1fr}.field-row{flex-direction:column}.form-designer-footer{flex-direction:column-reverse;gap:.75rem}.btn-designer-cancel,.btn-designer-create{width:100%}}.date-presets-section{align-items:center;background:#f9fafb;border-radius:8px;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;padding:1rem}.date-presets-section label{color:#374151;font-size:.875rem;font-weight:600}.preset-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.btn-preset{background:#fff;border:1.5px solid #e5e7eb;border-radius:6px;color:#4b5563;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.btn-preset:hover{background:#667eea;border-color:#667eea;color:#fff;transform:translateY(-1px)}.header-actions{display:flex;gap:.75rem}.quick-stats-bar{grid-gap:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1.5rem;padding:1rem 1rem 1rem 7.25rem}.quick-stat{display:flex;flex-direction:column;gap:.25rem}.quick-stat .stat-label{color:#fffc;font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.quick-stat .stat-value{color:#fff;font-size:1.25rem;font-weight:700}.quick-stat.fuel-input-stat{flex-direction:column;gap:.25rem}.fuel-input-wrapper{align-items:center;display:flex;gap:.5rem}.fuel-inline-input{background:#ffffff26;border:1px solid #ffffff4d;border-radius:6px;color:#fff;font-size:1rem;font-weight:600;padding:.35rem .5rem;text-align:center;transition:all .2s ease;width:60px}.fuel-inline-input:focus{background:#ffffff40;border-color:#ffffff80;box-shadow:0 0 0 3px #ffffff1a;outline:none}.fuel-inline-input::-webkit-inner-spin-button,.fuel-inline-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.quick-stat.fuel-input-stat .stat-unit{color:#ffffffe6;font-size:.875rem;font-weight:500;white-space:nowrap}.quick-stat.user-filter-stat{flex-direction:column;gap:.25rem;min-width:140px}.user-filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:#ffffff26;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;border:1px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.4rem 1.75rem .4rem .75rem;transition:all .2s ease}.user-filter-select:focus,.user-filter-select:hover{background-color:#ffffff40;border-color:#ffffff80}.user-filter-select:focus{box-shadow:0 0 0 3px #ffffff1a;outline:none}.user-filter-select option{background:#667eea;color:#fff;padding:.5rem}.analytics-container{padding:.5rem 0}.analytics-summary-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.analytics-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:all .2s ease}.analytics-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.analytics-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:1.75rem;height:60px;justify-content:center;width:60px}.analytics-content{flex:1 1}.analytics-content h3{color:#111827;font-size:1.75rem;font-weight:700;margin:0 0 .25rem}.analytics-content p{color:#6b7280;font-size:.875rem;font-weight:500;margin:0}.fuel-config-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.fuel-config-section h3{color:#111827;font-size:1.125rem;font-weight:700;margin:0 0 1rem}.fuel-config-inputs{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.analytics-date-range{background:#f9fafb;border-radius:8px;padding:1rem 1.5rem;text-align:center}.analytics-date-range p{color:#4b5563;font-size:.9375rem;margin:0}.analytics-date-range strong{color:#111827;font-weight:600}.point-meta{gap:1rem;margin-top:.25rem}.point-battery,.point-speed{background:#f3f4f6;border-radius:4px;color:#6b7280;font-size:.75rem;padding:.125rem .5rem}.filter-input{border:1.5px solid #e5e7eb;border-radius:6px;font-size:.875rem;min-width:150px;padding:.5rem .75rem;transition:all .2s ease}.filter-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.route-date{font-size:.8125rem}@media (max-width:768px){.analytics-summary-grid,.fuel-config-inputs,.quick-stats-bar{grid-template-columns:1fr}.preset-buttons{width:100%}.btn-preset{flex:1 1}.date-presets-section{align-items:stretch;flex-direction:column}}.filters-section-horizontal{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;flex-wrap:wrap;gap:2rem;margin-bottom:1rem;padding:1.5rem}.date-presets-inline{align-items:center;display:flex;flex:1 1;gap:1rem;min-width:0}.date-presets-inline label{color:#374151;font-size:.875rem;font-weight:600;white-space:nowrap}.preset-buttons-inline{display:flex;flex-wrap:wrap;gap:.5rem}.btn-preset-chip{background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;color:#4b5563;cursor:pointer;font-size:.8125rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-preset-chip:hover{background:#f5f7ff;border-color:#667eea;color:#667eea;transform:translateY(-1px)}.btn-preset-chip:active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000;box-shadow:0 4px 8px #667eea4d;color:#fff;font-weight:600}.btn-preset-chip.selected{background:#eff6ff;border:2px solid #3b82f6;color:#3b82f6;font-weight:600}.date-inputs-simple{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.date-inputs-simple label{color:#374151;font-size:.875rem;font-weight:600;white-space:nowrap}.filter-input-simple{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;color:#1f2937;cursor:pointer;font-size:.875rem;min-width:150px;padding:.5rem .75rem;transition:all .2s ease}.filter-input-simple:hover{border-color:#cbd5e0}.filter-input-simple:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filters-section-bottom{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;display:flex;justify-content:space-between;margin-bottom:1rem;padding:1rem 1.5rem}@media (max-width:1024px){.filters-section-horizontal{gap:1rem}.date-presets-inline,.filters-section-horizontal{align-items:stretch;flex-direction:column}.preset-buttons-inline{justify-content:center}.date-inputs-right{justify-content:space-between;width:100%}}@media (max-width:768px){.preset-buttons-inline{flex-direction:column}.btn-preset-chip{text-align:center;width:100%}.date-inputs-simple{align-items:stretch;flex-direction:column;gap:.5rem}.date-inputs-simple label{font-size:.75rem}.filter-input-simple{width:100%}}.routes-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:1rem}.route-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;box-shadow:0 1px 3px #0000000d;cursor:pointer;padding:1rem;transition:all .2s ease}.route-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.route-card-header{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.75rem}.route-user{display:flex;flex-direction:column;gap:.25rem}.route-user strong{color:#1f2937;font-size:.9375rem;font-weight:600}.route-date{color:#6b7280;font-size:.75rem;font-weight:500}.route-card-body{display:flex;flex-direction:column;gap:.75rem}.route-meta-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.route-meta-grid .meta-item{align-items:center;background:#f9fafb;border-radius:6px;display:flex;gap:.5rem;padding:.5rem}.meta-icon{flex-shrink:0;font-size:1.125rem}.route-meta-grid .meta-item>div{display:flex;flex-direction:column;gap:.125rem;min-width:0}.route-meta-grid .meta-label{color:#6b7280;font-size:.6875rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.route-meta-grid .meta-value{color:#1f2937;font-size:.875rem;font-weight:600;margin-left:0;text-align:left}.route-notes{align-items:flex-start;background:#fffbeb;border-left:3px solid #f59e0b;border-radius:4px;color:#92400e;display:flex;font-size:.8125rem;gap:.5rem;margin-top:.25rem;padding:.5rem}.notes-icon{flex-shrink:0;font-size:1rem}.route-card-actions{border-top:1px solid #f3f4f6;display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem}.btn-action{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:.8125rem;font-weight:600;gap:.375rem;justify-content:center;padding:.5rem .75rem;transition:all .2s ease}.btn-action-view{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-action-view:hover{box-shadow:0 4px 8px #667eea4d;transform:translateY(-1px)}.btn-action-export{background:#f3f4f6;border:1px solid #e5e7eb;color:#4b5563}.btn-action-export:hover{background:#e5e7eb;border-color:#d1d5db;transform:translateY(-1px)}.empty-state,.loading-state{color:#6b7280;padding:3rem 1rem;text-align:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 1rem;width:40px}@media (max-width:768px){.route-meta-grid,.routes-grid{grid-template-columns:1fr}.route-card-actions{flex-direction:column}}.modal-overlay{align-items:flex-start;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:.5vh 1rem;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:1000px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.route-detail-modal{max-width:1200px}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:.5rem 1rem}.modal-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:1.5rem;font-weight:700;margin:0}.modal-close-btn{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:1.25rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.modal-close-btn:hover{background:#e5e7eb;color:#1f2937;transform:rotate(90deg)}.modal-body{flex:1 1;overflow-y:auto;padding:.5rem 1rem}.route-detail-header{align-items:flex-start;border-bottom:2px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1.5rem}.route-detail-info h3{color:#1f2937;font-size:1.5rem;font-weight:700;margin:0 0 .5rem}.route-detail-date{color:#6b7280;font-size:.9375rem;margin:0}.route-detail-actions{display:flex;gap:.75rem}.route-stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:2rem}.route-stats-grid .stat-card{align-items:center;background:linear-gradient(135deg,#f9fafb,#fff);border:1.5px solid #e5e7eb;border-radius:10px;display:flex;gap:1rem;padding:1.25rem;transition:all .2s ease}.route-stats-grid .stat-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a;transform:translateY(-2px)}.route-stats-grid .stat-icon{flex-shrink:0;font-size:2rem}.route-stats-grid .stat-content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.route-stats-grid .stat-content h4{color:#1f2937;font-size:1.25rem;font-weight:700;margin:0}.route-stats-grid .stat-content p{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.025em;margin:0;text-transform:uppercase}.route-timeline-section{background:#f9fafb;border-radius:10px;margin-bottom:1.5rem;padding:1.5rem}.route-timeline-section h3{color:#1f2937;font-size:1.125rem;font-weight:700;margin:0 0 1rem}.timeline-info{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.timeline-item{display:flex;flex-direction:column;gap:.25rem}.timeline-label{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.timeline-value{color:#1f2937;font-size:.9375rem;font-weight:600}.route-notes-section{background:#fffbeb;border-left:4px solid #f59e0b;border-radius:8px;margin-bottom:1.5rem;padding:1.25rem}.route-notes-section h3{color:#92400e;font-size:1rem;font-weight:700;margin:0 0 .75rem}.route-notes-section p{color:#78350f;line-height:1.6;margin:0}.route-points-section{background:#fff;border:1.5px solid #e5e7eb;border-radius:10px;padding:1.5rem}.route-points-section h3{color:#1f2937;font-size:1.125rem;font-weight:700;margin:0 0 1rem}.route-points-list{display:flex;flex-direction:column;gap:.75rem;max-height:400px;overflow-y:auto;padding-right:.5rem}.route-points-list::-webkit-scrollbar{width:8px}.route-points-list::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.route-points-list::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.route-points-list::-webkit-scrollbar-thumb:hover{background:#9ca3af}.route-point-item{background:#f9fafb;border-radius:8px;display:flex;gap:1rem;padding:.875rem;transition:all .2s ease}.route-point-item:hover{background:#f3f4f6;transform:translateX(4px)}.point-number{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:32px;justify-content:center;width:32px}.point-content{flex:1 1;min-width:0}.point-coords{align-items:center;display:flex;gap:.75rem;margin-bottom:.375rem}.point-coords span:first-child{color:#1f2937;font-family:Courier New,monospace;font-size:.8125rem;font-weight:600}.point-accuracy{background:#e5e7eb;border-radius:12px;color:#6b7280;font-size:.6875rem;font-weight:600;padding:.125rem .5rem}.point-meta{color:#6b7280;display:flex;flex-wrap:wrap;font-size:.75rem;gap:.75rem}.point-time{font-weight:600}.point-battery,.point-speed{font-weight:500}.route-points-more{color:#6b7280;font-size:.875rem;font-style:italic;padding:1rem;text-align:center}@media (max-width:768px){.modal-overlay{padding:0}.modal-content{border-radius:0;max-height:100vh}.modal-header{padding:1rem 1.5rem}.modal-body{padding:1.5rem}.route-detail-header{flex-direction:column;gap:1rem}.route-stats-grid{grid-template-columns:repeat(2,1fr)}.timeline-info{grid-template-columns:1fr}.route-points-list{max-height:300px}}.user-tracking-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(500px,1fr));margin-top:1.5rem}.user-tracking-card{background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden;transition:all .3s ease}.user-tracking-card:hover{border-color:#667eea;box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.user-tracking-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;justify-content:space-between;padding:1.5rem}.user-header-left,.user-tracking-header{align-items:center;display:flex;gap:1rem}.user-header-left{flex:1 1}.user-header-actions{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.btn-action-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #ffffff4d;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.375rem;padding:.5rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-action-header:hover{background:#ffffff40;border-color:#ffffff80;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-action-header:active{transform:translateY(0)}.user-avatar-large{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:3px solid #ffffff4d;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;font-weight:700;height:60px;justify-content:center;width:60px}.user-info{flex:1 1}.user-name{color:#fff;font-size:1.25rem;font-weight:700;margin:0;text-shadow:0 1px 3px #0003}.user-session-count{color:#ffffffe6;font-size:.875rem;font-weight:500;margin:.25rem 0 0}.user-stats-grid{grid-gap:1rem;background:#f9fafb;border-bottom:1.5px solid #e5e7eb;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);padding:1.5rem}.user-stat-item{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:.75rem;padding:1rem;transition:all .2s ease}.user-stat-item:hover{border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.stat-icon-small{align-items:center;background:linear-gradient(135deg,#f5f7ff,#e8ebff);border-radius:8px;display:flex;flex-shrink:0;font-size:1.5rem;height:40px;justify-content:center;width:40px}.stat-details{flex:1 1;min-width:0}.stat-label-small{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.03em;margin-bottom:.25rem;text-transform:uppercase}.stat-value-large{color:#1f2937;font-size:1.125rem;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fuel-cost-badge{align-items:center;background:linear-gradient(135deg,#fff7ed,#fed7aa);border-bottom:1.5px solid #fdba74;display:flex;justify-content:space-between;padding:1rem 1.5rem}.fuel-cost-label{color:#92400e;font-size:.875rem;font-weight:600}.fuel-cost-value{color:#92400e;font-size:1.25rem;font-weight:700}.recent-sessions-section{padding:1.5rem}.section-title{align-items:center;color:#6b7280;display:flex;font-size:.875rem;font-weight:700;gap:.5rem;letter-spacing:.05em;margin:0 0 1rem;text-transform:uppercase}.section-title:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;content:"";height:16px;width:4px}.recent-sessions-list{display:flex;flex-direction:column;gap:.75rem}.recent-session-item{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;gap:1rem;padding:.875rem;transition:all .2s ease}.recent-session-item:hover{background:#f3f4f6;border-color:#667eea}.session-date-time{display:flex;flex-direction:column;gap:.25rem;min-width:100px}.session-date{color:#1f2937;font-size:.8125rem;font-weight:600}.session-time{color:#6b7280;font-size:.75rem;font-weight:500}.session-quick-stats{align-items:center;color:#4b5563;display:flex;flex:1 1;font-size:.8125rem;font-weight:500;gap:.5rem}.session-separator{color:#d1d5db}.session-distance,.session-duration,.session-points,.session-view-btn{white-space:nowrap}.session-view-btn{background:#fff;border:1.5px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.375rem .875rem;transition:all .2s ease}.session-view-btn:hover{background:#667eea;box-shadow:0 2px 8px #667eea4d;color:#fff;transform:translateY(-1px)}.user-card-actions{background:#f9fafb;border-top:1.5px solid #e5e7eb;display:flex;gap:.75rem;padding:1rem 1.5rem}.btn-action-view-all{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all .2s ease}.btn-action-view-all:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-action-export{align-items:center;background:#fff;border:1.5px solid #667eea;border-radius:8px;color:#667eea;cursor:pointer;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1rem;transition:all .2s ease;white-space:nowrap}.btn-action-export:hover{background:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff;transform:translateY(-2px)}@media (max-width:1024px){.user-tracking-grid{grid-template-columns:1fr}.user-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.user-tracking-header{padding:1.25rem}.user-avatar-large{font-size:1.25rem;height:50px;width:50px}.user-name{font-size:1.125rem}.user-stats-grid{gap:.75rem;grid-template-columns:1fr;padding:1.25rem}.recent-session-item{align-items:stretch;flex-direction:column;gap:.75rem}.session-date-time{flex-direction:row;justify-content:space-between}.session-quick-stats{justify-content:center}.session-view-btn{width:100%}.user-card-actions{flex-direction:column}.btn-action-export{justify-content:center;width:100%}}.user-detail-modal{max-height:90vh;max-width:1000px;overflow-y:auto;width:90vw}.modal-subtitle{color:#6b7280;font-size:.875rem;font-weight:400;margin-top:.25rem}.user-detail-summary{grid-gap:1rem;background:#f9fafb;border-radius:8px;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem;padding:1.5rem}.summary-item{display:flex;flex-direction:column;gap:.5rem}.summary-label{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.summary-value{color:#1f2937;font-size:1.5rem;font-weight:700}.daily-breakdown-section{margin-top:1.5rem}.section-heading{border-bottom:2px solid #e5e7eb;color:#1f2937;font-size:1.125rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem}.daily-breakdown-table-wrapper{border:1.5px solid #e5e7eb;border-radius:8px;overflow-x:auto}.daily-breakdown-table{background:#fff;border-collapse:collapse;width:100%}.daily-breakdown-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.daily-breakdown-table th{font-size:.8125rem;font-weight:600;letter-spacing:.05em;padding:1rem;text-align:left;text-transform:uppercase}.daily-breakdown-table tbody tr{border-bottom:1px solid #e5e7eb;transition:all .2s ease}.daily-breakdown-table tbody tr:hover{background:#f9fafb}.daily-breakdown-table tbody tr:last-child{border-bottom:none}.daily-breakdown-table td{color:#374151;font-size:.875rem;padding:1rem}.date-cell{color:#1f2937;font-weight:600}.date-display{align-items:center;display:flex;gap:.5rem}.sessions-cell{color:#667eea;font-weight:600;text-align:center}.distance-cell{font-weight:500}.duration-cell{color:#6b7280}.fuel-cell{color:#059669;font-weight:500}.status-cell{text-align:center}.activity-badge{align-items:center;background:#d1fae5;border-radius:12px;color:#065f46;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem;padding:.25rem .75rem}.modal-note{background:#fef3c7;border-left:4px solid #f59e0b;border-radius:4px;margin-top:1.5rem;padding:1rem}.modal-note p{color:#78350f;font-size:.875rem;line-height:1.5;margin:0}.modal-note strong{font-weight:700}.btn-action-view-details{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff}.btn-action-view-details:hover{box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}.calendar-section{padding:.5rem}.calendar-month-block{margin-bottom:1.5rem}.calendar-month-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:6px;color:#1f2937;color:#fff;font-size:1rem;font-weight:700;margin-bottom:.75rem;padding:.5rem;text-align:center}.calendar-weekday-headers{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:repeat(7,1fr);margin-bottom:.25rem}.weekday-header{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.375rem;text-align:center;text-transform:uppercase}.calendar-grid-traditional{grid-gap:.25rem;display:grid;gap:.25rem;grid-template-columns:repeat(7,1fr)}.calendar-day-traditional{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:4px;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;min-height:65px;padding:.5rem;position:relative;text-align:center;transition:all .2s ease}.calendar-day-traditional:hover{box-shadow:0 2px 8px #0000001a;transform:scale(1.02);z-index:1}.calendar-day-traditional.active{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-color:#86efac;border-width:2px}.calendar-day-traditional.inactive{background:#fafafa}.calendar-day-traditional.out-of-range{opacity:.3;pointer-events:none}.calendar-day-number-traditional{color:#374151;font-size:.875rem;font-weight:600;line-height:1;margin-bottom:.25rem}.calendar-day-traditional.active .calendar-day-number-traditional{color:#16a34a;font-weight:700}.calendar-day-distance-traditional{border-radius:3px;font-size:.625rem;font-weight:700;line-height:1.2;padding:.15rem .3rem}.calendar-day-distance-traditional.has-data{background:#dcfce7;border:1px solid #86efac;color:#16a34a}.calendar-day-distance-traditional.no-data{color:#0000}.calendar-legend{background:#f9fafb;border:1px solid #e5e7eb;border-radius:4px;display:flex;gap:1rem;justify-content:center;margin-top:1rem;padding:.75rem}.legend-item{align-items:center;color:#4b5563;display:flex;font-size:.75rem;font-weight:500;gap:.375rem}.legend-box{border:1px solid;border-radius:3px;height:16px;width:16px}.legend-box.active-box{background:linear-gradient(135deg,#dcfce7,#bbf7d0);border-color:#86efac}.legend-box.inactive-box{background:#fafafa;border-color:#e5e7eb}@media (max-width:768px){.user-detail-modal{width:95vw}.user-detail-summary{grid-template-columns:1fr 1fr}.summary-value{font-size:1.25rem}.daily-breakdown-table{font-size:.75rem}.daily-breakdown-table td,.daily-breakdown-table th{padding:.75rem .5rem}.calendar-grid-traditional{gap:.15rem}.calendar-day-traditional{min-height:50px;padding:.3rem}.calendar-day-number-traditional{font-size:.75rem}.calendar-day-distance-traditional{font-size:.5625rem;padding:.1rem .25rem}.weekday-header{font-size:.625rem;padding:.25rem}.calendar-month-header{font-size:.875rem;padding:.375rem}.calendar-legend{gap:.75rem;padding:.625rem}.legend-item{font-size:.6875rem}.legend-box{height:14px;width:14px}}.profile-tab-container{background:#f5f7fa;height:100%;overflow-y:auto;padding:1.5rem;width:100%}.profile-tab-container .tab-header{background:#fff;border:1px solid #e2e8f0cc;border-radius:8px;box-shadow:0 2px 8px #00000014;margin-bottom:1.25rem;padding:1.25rem}.profile-tab-container .tab-header h2{color:#1a202c;font-size:1.25rem;font-weight:600;margin:0}.tab-description{color:#64748b;font-size:.875rem;line-height:1.4;margin-top:.25rem}.settings-sections{display:flex;flex-direction:column;gap:1.25rem;margin:0 auto;max-width:1200px}.settings-section{background:#fff!important;background-color:#fff!important;border:none;border-radius:8px;box-shadow:0 2px 8px #00000014;padding:1.25rem;transition:all .3s ease}.settings-section:hover{box-shadow:0 4px 16px #0000001f}.settings-section .section-header{align-items:flex-start;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding:0 0 .75rem;position:relative}.settings-section .section-header:after{background:linear-gradient(135deg,#667eea,#764ba2);bottom:-2px;content:"";height:2px;left:0;position:absolute;width:80px}.settings-section .section-title{flex:1 1}.settings-section .section-title h3{border-bottom:none;color:#1a202c;font-size:1.25rem;font-weight:600;margin:0 0 .5rem;padding-bottom:0}.settings-section .section-title p{color:#64748b;font-size:.8125rem;margin:.5rem 0 0}.settings-section .section-content{background:#0000;display:block;padding:.75rem 0 0}.settings-section .section-content .form-grid{margin-bottom:1rem}.settings-section .section-content .form-grid,.settings-section .section-content .info-grid{grid-gap:1rem;display:grid!important;gap:1rem;grid-template-columns:repeat(2,1fr)}.settings-section .form-group{display:flex!important;flex-direction:column!important;gap:.375rem;opacity:1!important;visibility:visible!important}.settings-section .form-group.full-width{grid-column:1/-1}.settings-section .form-group label{color:#334155;display:block!important;font-size:.8125rem;font-weight:600;visibility:visible!important}.settings-section .form-input{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1e293b;display:block!important;font-size:.875rem;padding:.625rem .875rem;transition:all .2s ease;visibility:visible!important;width:100%}.settings-section .form-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.settings-section .form-input:disabled{background:#f1f5f9;color:#64748b;cursor:not-allowed}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-input{flex:1 1;padding-right:3rem}.password-toggle{background:none;border:none;cursor:pointer;font-size:1.25rem;opacity:.6;padding:.25rem;position:absolute;right:.75rem;transition:opacity .2s ease}.password-toggle:hover{opacity:1}.password-requirements{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin:1rem 0 .75rem;padding:.75rem}.requirements-title{color:#475569;font-size:.8125rem;font-weight:600;margin:0 0 .5rem}.password-requirements ul{display:flex;flex-direction:column;gap:.375rem;list-style:none;margin:0;padding:0}.password-requirements li{color:#64748b;font-size:.8125rem;padding-left:1.25rem;position:relative}.password-requirements li:before{color:#cbd5e1;content:"○";font-weight:700;left:0;position:absolute}.password-requirements li.met{color:#38a169}.password-requirements li.met:before{color:#38a169;content:"✓"}.form-actions{border-top:none;display:flex;gap:.75rem;justify-content:flex-end;margin-top:.75rem;padding-top:.75rem}.btn-cancel,.btn-edit,.btn-save{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:400;gap:6px;padding:8px 16px;transition:all .2s ease}.btn-cancel svg,.btn-edit svg,.btn-save svg{flex-shrink:0;height:16px;width:16px}.btn-edit{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 4px #667eea4d;color:#fff}.btn-edit:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f);box-shadow:0 4px 8px #667eea66;transform:translateY(-2px)}.btn-edit:active{transform:translateY(0)}.btn-save{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 2px 4px #22c55e4d;color:#fff}.btn-save:hover:not(:disabled){background:linear-gradient(135deg,#16a34a,#15803d);box-shadow:0 4px 8px #22c55e66;transform:translateY(-2px)}.btn-save:active:not(:disabled){transform:translateY(0)}.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-cancel{background:#f8fafc;border:1.5px solid #cbd5e0;color:#4a5568}.btn-cancel:hover:not(:disabled){background:#edf2f7;border-color:#a0aec0;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.btn-cancel:active:not(:disabled){transform:translateY(0)}.btn-cancel:disabled{cursor:not-allowed;opacity:.5}.settings-section .info-item{display:flex!important;flex-direction:column!important;gap:.375rem;opacity:1!important;visibility:visible!important}.settings-section .info-item.full-width{grid-column:1/-1}.settings-section .info-item label{color:#64748b;display:block!important;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;visibility:visible!important}.settings-section .info-value{color:#1e293b;display:block!important;font-size:.875rem;font-weight:500;visibility:visible!important}.settings-section .role-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:inline-block}.settings-section .role-badge,.settings-section .status-badge{border-radius:4px;font-size:.8125rem;font-weight:600;padding:.3rem .625rem}.settings-section .status-badge{align-items:center;display:inline-flex;gap:.25rem}.settings-section .status-badge.active{background:#c6f6d5;color:#22543d}.settings-section .status-badge.inactive{background:#fee2e2;color:#991b1b}@media (max-width:768px){.profile-tab-container{padding:1rem}.settings-sections{gap:1rem}.settings-section{padding:1rem}.settings-section .form-grid,.settings-section .info-grid{gap:.875rem;grid-template-columns:1fr}.settings-section .form-group.full-width,.settings-section .info-item.full-width{grid-column:1}.settings-section .section-header{align-items:flex-start;flex-direction:column;gap:.75rem;margin-bottom:.75rem;padding:0 0 .625rem}.settings-section .section-content{padding:.625rem 0 0}.settings-section .form-actions{flex-direction:column-reverse;gap:.625rem}.settings-section .btn-cancel,.settings-section .btn-edit,.settings-section .btn-save{justify-content:center;width:100%}}.activity-section{background:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;margin-top:24px;padding:20px}.activity-section .section-subtitle{border-bottom:1px solid #e5e7eb;color:#1f2937;font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:12px}.activity-list{max-height:400px;overflow-y:auto}.activity-item{align-items:flex-start;border-radius:8px;display:flex;gap:12px;padding:12px 8px;transition:background-color .15s ease}.activity-item:hover{background-color:#f9fafb}.activity-item:not(:last-child){border-bottom:1px solid #f3f4f6}.activity-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.activity-icon svg{height:16px;width:16px}.activity-content{flex:1 1;min-width:0}.activity-title{word-wrap:break-word;color:#374151;font-size:13px;line-height:1.4;margin:0 0 4px}.activity-time{color:#9ca3af;font-size:11px;margin:0}.activity-item[data-type=login] .activity-icon{background:linear-gradient(135deg,#10b981,#059669)}.activity-item[data-type=create] .activity-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.activity-item[data-type=update] .activity-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}.activity-item[data-type=delete] .activity-icon{background:linear-gradient(135deg,#ef4444,#dc2626)}.activity-item[data-type=view] .activity-icon{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.activity-list::-webkit-scrollbar{width:6px}.activity-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.activity-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.activity-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.activity-empty{color:#6b7280;padding:40px 20px;text-align:center}.activity-empty svg{height:48px;margin-bottom:12px;opacity:.5;width:48px}.activity-loading{align-items:center;color:#6b7280;display:flex;justify-content:center;padding:40px 20px}.activity-loading:after{animation:spin .8s linear infinite;border:2px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;content:"";height:20px;margin-left:8px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.profile-main-content.showing-route-details{background:#0000!important;background-color:initial!important}.profile-main-content:has(.showing-route-details),.profile-main-content:has(.transparent-bg){background:#0000!important;background-color:initial!important}.profile-main-content:has(.route-tracking-content.transparent-bg),.profile-main-content:has(.route-tracking-tab.showing-route-details){background:#0000!important;background-color:initial!important}.route-tracking-tab.showing-route-details{background:#0000!important}.manual-metrics-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem;padding:20px}.metrics-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.metrics-header .section-subtitle{color:#374151;font-size:1.1rem;font-weight:600;margin:0}.metrics-actions{display:flex;gap:8px}.cancel-metrics-btn,.edit-metrics-btn,.save-metrics-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.edit-metrics-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.edit-metrics-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.save-metrics-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.save-metrics-btn:hover:not(:disabled){box-shadow:0 4px 12px #10b98166;transform:translateY(-1px)}.save-metrics-btn:disabled{cursor:not-allowed;opacity:.6}.cancel-metrics-btn{background:#f3f4f6;border:1px solid #d1d5db;color:#4b5563}.cancel-metrics-btn:hover{background:#e5e7eb}.metrics-grid-container{overflow-x:auto}.metrics-grid{grid-gap:12px 24px;display:grid;gap:12px 24px;grid-template-columns:repeat(2,1fr)}.metric-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;gap:12px;padding:10px 12px}.metric-item .metric-label{color:#374151;flex-shrink:0;font-size:15px;font-weight:600;min-width:180px}.metric-item .metric-value{color:#1f2937;font-size:15px;font-weight:600}.metric-input{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#1f2937;flex:1 1;font-size:14px;min-width:0;padding:8px 12px;transition:all .2s ease}.metric-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.metric-input::placeholder{color:#9ca3af;font-weight:400}.branch-info-item{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe}.branch-info-item .metric-label{color:#1e40af}.branch-info-item .metric-value{color:#1e3a8a}.last-updated-item{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0}.last-updated-item .metric-label{color:#166534}.last-updated-value{color:#15803d!important;font-weight:600}@media (max-width:768px){.metrics-grid{grid-template-columns:1fr}.metrics-header{align-items:flex-start;flex-direction:column;gap:12px}.metric-item .metric-label{font-size:12px;min-width:120px}}.buffer-draggable-panel{background:#2a2f38;border:1px solid #3c414c;border-radius:8px;box-shadow:0 8px 32px #0006;color:#f7f8fa;display:flex;flex-direction:column;max-height:455px;max-height:90vh;max-width:90vw;min-height:210px;min-width:240px;position:fixed;right:60px;top:60px;width:240px;z-index:9999}.buffer-panel-header{align-items:center;background:#242730;border-bottom:1px solid #3c414c;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:10px 14px;-webkit-user-select:none;user-select:none}.buffer-panel-header span{color:#f7f8fa;font-size:13px;font-weight:600}.buffer-close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#9ca3af;cursor:pointer;display:flex;font-size:18px;height:22px;justify-content:center;transition:all .2s ease;width:22px}.buffer-close-btn:hover{background:#ffffff0d;color:#f7f8fa}.buffer-tabs{background:#242730;border-bottom:1px solid #3c414c;display:flex}.buffer-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:#a0a7b4;cursor:pointer;flex:1 1;font-size:11px;font-weight:500;padding:8px 12px;transition:all .2s ease}.buffer-tab.active{background:#1f7cf41a;border-bottom-color:#1f7cf4;color:#1f7cf4}.buffer-tab:hover{background:#1f7cf40d;color:#f7f8fa}.buffer-panel-body{background:#2a2f38;display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;padding:12px}.buffer-panel-body::-webkit-scrollbar{width:6px}.buffer-panel-body::-webkit-scrollbar-track{background:#0003;border-radius:3px}.buffer-panel-body::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.buffer-panel-body::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.buffer-section{flex-shrink:0;margin-bottom:12px}.buffer-section label{color:#a0a7b4;display:block;font-size:11px;font-weight:600;margin-bottom:5px}.buffer-section input[type=number],.buffer-section input[type=text]{background:#353a44;border:1px solid #3c414c;border-radius:4px;color:#f7f8fa;font-size:11px;padding:6px 8px;transition:border-color .2s ease;width:100%}.buffer-section input[type=number]:focus,.buffer-section input[type=text]:focus{border-color:#1f7cf4;box-shadow:0 0 0 3px #1f7cf433;outline:none}.buffer-section input[type=number]::placeholder,.buffer-section input[type=text]::placeholder{color:#6b7280}.buffer-coord-inputs{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.buffer-btn{background:#242730;border:1px solid #3c414c;border-radius:4px;color:#a0a7b4;cursor:pointer;font-size:10px;font-weight:500;padding:6px 12px;transition:all .2s ease}.buffer-btn:hover:not(:disabled){background:#2a2f38;border-color:#4a5568;color:#f7f8fa}.buffer-btn:disabled{cursor:not-allowed;opacity:.5}.buffer-btn.primary{background:linear-gradient(135deg,#1f7cf4,#0d47a1);border:1px solid #1f7cf44d;box-shadow:0 2px 8px #1f7cf44d;color:#fff}.buffer-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#0d47a1,#083d8a);box-shadow:0 4px 12px #1f7cf466;transform:translateY(-1px)}.buffer-btn.secondary{background:#242730;border:1px solid #3c414c;color:#a0a7b4}.buffer-btn.secondary:hover:not(:disabled){background:#2a2f38;border-color:#4a5568;color:#f7f8fa}.buffer-btn.danger-outline{background:#0000;border:1px solid #ef444480;color:#ef4444;font-size:9px;padding:4px 8px}.buffer-btn.danger-outline:hover{background:#ef44441a;border-color:#ef4444}.buffer-preview-info{background:#1f7cf414;border:1px solid #1f7cf433;border-radius:6px;margin-top:8px;padding:10px}.buffer-preview-info h4{color:#1f7cf4;font-size:11px;font-weight:600;margin:0 0 8px}.buffer-preview-details{display:flex;flex-direction:column;gap:6px}.buffer-preview-item{align-items:center;display:flex;font-size:10px;justify-content:space-between}.buffer-preview-item .label{color:#a0a7b4;font-weight:500}.buffer-preview-item .value{color:#f7f8fa;font-family:monospace;font-weight:600}.buffer-list-header{align-items:center;border-bottom:1px solid #3c414c;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.buffer-list-header h4{color:#f7f8fa;font-size:12px;font-weight:600;margin:0}.buffer-table-container{background:#242730;border:1px solid #3c414c;border-radius:6px;box-shadow:inset 0 2px 4px #0000001a;flex:0 1 auto;max-height:200px;overflow-y:auto}.buffer-table-container::-webkit-scrollbar{width:6px}.buffer-table-container::-webkit-scrollbar-track{background:#0003;border-radius:3px}.buffer-table-container::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.buffer-table{border-collapse:collapse;font-size:10px;width:100%}.buffer-table thead{background:#242730f2;position:-webkit-sticky;position:sticky;top:0;z-index:1}.buffer-table th{border-bottom:2px solid #3c414c;color:#a0a7b4;font-size:10px;font-weight:600;padding:8px;text-align:left}.buffer-table td{border-bottom:1px solid #3c414c4d;color:#f7f8fa;padding:8px}.buffer-table td.coords,.buffer-table td.date{color:#a0a7b4;font-family:monospace;font-size:9px}.buffer-table tbody tr{cursor:pointer;transition:background .2s ease}.buffer-table tbody tr:hover{background:#1f7cf41a}.buffer-table tbody tr.selected{background:#1f7cf440;border-left:3px solid #1f7cf4}.buffer-table tbody tr.selected td:first-child{padding-left:5px}.empty-buffers{color:#6b7280;padding:40px 20px;text-align:center}.empty-buffers p{font-size:12px;font-style:italic;margin-bottom:16px}.delete-buffer-btn{align-items:center;background:#ef44441a;border:1px solid #ef444433;border-radius:3px;color:#ef4444;cursor:pointer;display:flex;font-size:14px;height:24px;justify-content:center;transition:all .2s ease;width:24px}.delete-buffer-btn:hover{background:#ef444433;border-color:#ef4444;transform:scale(1.1)}.buffer-panel-footer{background:#242730;border-radius:0 0 8px 8px;border-top:1px solid #3c414c;display:flex;gap:8px;justify-content:flex-end;padding:10px 12px}.buffer-panel-footer .buffer-btn{padding:6px 16px}@media (max-width:768px){.buffer-draggable-panel{left:5vw!important;max-width:90vw;width:90vw!important}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.legend-panel-fixed{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#242730f2;border:1px solid #3c414c;border-radius:12px;bottom:10px;box-shadow:0 4px 12px #0000004d;color:#f7f8fa;display:flex;flex-direction:column;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;max-height:400px;max-width:300px;min-width:240px;position:fixed;right:10px;transition:all .2s ease;z-index:1000}.legend-panel-header{align-items:center;background:#ffffff0d;border-bottom:1px solid #3c414c;border-radius:12px 12px 0 0;display:flex;flex-shrink:0;font-size:13px;font-weight:700;gap:6px;justify-content:space-between;padding:6px 12px;transition:all .2s ease}.legend-panel-header.minimized{border-bottom:none;border-radius:12px}.legend-minimize-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;height:28px;justify-content:center;min-width:32px;padding:6px 10px;transition:all .2s ease}.legend-minimize-btn:hover{background:#fff3;border-color:#ffffff4d}.legend-minimize-btn svg{transition:transform .2s ease}.legend-panel-body{flex:1 1;max-height:330px;opacity:1;overflow-y:auto;padding:8px;transition:max-height .3s ease,padding .3s ease,opacity .3s ease}.legend-panel-body.minimized{max-height:0;opacity:0;overflow-y:hidden;padding:0}.legend-panel-body::-webkit-scrollbar{width:6px}.legend-panel-body::-webkit-scrollbar-track{background:#0003;border-radius:3px}.legend-panel-body::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.legend-panel-body::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.legend-item-standard{align-items:center;display:flex;gap:8px;margin-bottom:2px;padding:4px 6px}.legend-color-box{border-radius:3px;flex-shrink:0;height:14px;width:14px}.legend-label{flex:1 1;font-size:13px;font-weight:500}.legend-opacity{background:#ffffff1a;border-radius:3px;color:#a0a7b4;font-size:11px;padding:2px 6px}.legend-item-viz{background:#2a2f38;border:1px solid #3c414c;border-radius:6px;margin-bottom:4px;padding:8px}.legend-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.legend-item-title,.legend-item-title-small{font-size:13px;font-weight:600}.legend-item-title-small{margin-bottom:3px}.legend-item-field{color:#a0a7b4;font-size:10px;margin-bottom:5px}.legend-item-badge{background:#ffffff1a;border-radius:3px;color:#a0a7b4;font-size:9px;font-weight:600;letter-spacing:.5px;padding:2px 5px;text-transform:uppercase}.legend-gradient{border:1px solid #ffffff1a;border-radius:2px;box-shadow:inset 0 1px 3px #0000004d;height:12px}.legend-gradient-labels{color:#a0a7b4;display:flex;font-size:9px;justify-content:space-between;margin-top:3px;padding:0 2px}.legend-gradient-row{align-items:center;display:flex;gap:6px}.legend-value{color:#a0a7b4;font-size:9px;min-width:32px;text-align:center}.legend-gradient-bar{border:1px solid #ffffff1a;border-radius:2px;box-shadow:inset 0 1px 3px #0000004d;flex:1 1;height:10px}.legend-solid-color{border:1px solid #fff3;border-radius:4px;box-shadow:0 1px 2px #0003;height:20px;width:100%}.legend-categories{margin-top:4px}.legend-category-item{align-items:center;display:flex;gap:6px;margin-bottom:3px}.legend-category-color{border:1px solid #ffffff1a;border-radius:2px;box-shadow:0 1px 2px #0003;flex-shrink:0;height:12px;width:12px}.legend-category-item span{flex:1 1;font-size:11px}.legend-more-text{color:#a0a7b4;font-size:9px;font-style:italic;padding-left:18px}.legend-categories-compact{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.legend-category-compact{align-items:center;display:flex;gap:4px;margin-right:6px}.legend-category-color-small{border:1px solid #ffffff1a;border-radius:2px;box-shadow:0 1px 2px #0003;height:12px;width:12px}.legend-category-compact span,.legend-ellipsis{color:#a0a7b4;font-size:9px}.legend-ellipsis{font-style:italic}