*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f7fafc;color:#2d3748;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0;overflow-x:hidden}code{font-family:Courier New,Monaco,Consolas,source-code-pro,monospace}.App{background:#f7fafc;overflow:hidden;text-align:center}.App,.App-header{min-height:100vh;position:relative}.App-header{align-items:center;background:#fff;box-shadow:0 1px 3px #0000000d;color:#2d3748;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;padding:40px 20px;z-index:1}.App-header h1{color:#1e3a5f;font-size:3.5rem;font-weight:600;letter-spacing:2px;margin-bottom:10px;text-transform:uppercase}.App-header p{color:#4a5568;font-size:1.2rem;letter-spacing:.5px;margin-top:10px}.loading-container{background:#fff;color:#8b6914;min-height:100vh;overflow:hidden;position:relative}.loading-container:before{animation:stars 15s linear infinite;background:radial-gradient(3px 3px at 20% 30%,#ffd70066,#0000),radial-gradient(2px 2px at 60% 70%,#daa5204d,#0000),radial-gradient(1.5px 1.5px at 50% 50%,#ffdf0066,#0000);background-size:200% 200%;content:"";height:200%;opacity:.6;position:absolute;width:200%}.loading-container p{font-size:1.2rem;letter-spacing:2px;margin-top:20px;position:relative;z-index:1}.spinner{border-right:4px solid #ffd70033;border-top:4px solid #ffd70033;border-color:#d4af37 gold #ffd70033 #ffd70033;border-style:solid;border-width:4px;box-shadow:0 0 25px #ffd70066;height:60px;position:relative;width:60px;z-index:1}.logout-button{background:linear-gradient(135deg,#f44,#c00);border-radius:8px;box-shadow:0 4px 15px #ff44444d;font-size:16px;letter-spacing:1px;margin-top:30px;padding:12px 30px;text-transform:uppercase;transition:all .3s}.logout-button:hover{background:linear-gradient(135deg,#f66,red);box-shadow:0 6px 20px #ff444480}.api-status{margin-top:20px}.success{color:#09c;font-weight:700;text-shadow:0 0 10px #00d4ff33}.error{color:#e53e3e;font-weight:700;text-shadow:0 0 10px #e53e3e33}.coming-soon-page{align-items:center;background:#f7fafc;display:flex;justify-content:center;min-height:calc(100vh - 80px);padding:40px 20px}.coming-soon-content{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;max-width:400px;padding:50px 40px;text-align:center}.coming-soon-icon{align-items:center;animation:comingSoonPulse 2s ease-in-out infinite;background:#f7fafc;border:2px solid #e2e8f0;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 25px;width:80px}.coming-soon-icon img{animation:comingSoonRotate 8s linear infinite;height:40px;width:40px}@keyframes comingSoonPulse{0%,to{box-shadow:0 0 0 0 #71809633;transform:scale(1)}50%{box-shadow:0 0 0 10px #71809600;transform:scale(1.05)}}@keyframes comingSoonRotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.coming-soon-content h2{color:#1e3a5f;font-size:24px;font-weight:700;margin:0 0 10px}.coming-soon-title{color:#718096;font-size:16px;font-weight:600;margin:0 0 15px}.coming-soon-message{color:#4a5568;font-size:14px;line-height:1.6;margin:0 0 25px}.coming-soon-btn{align-items:center;background:#718096;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.coming-soon-btn:hover{background:#4a5568;box-shadow:0 4px 12px #7180964d;transform:translateY(-2px)}.loading-spinner-container{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;color:#2d3748;display:flex;flex-direction:column;gap:10px;justify-content:center;min-height:150px;padding:40px;text-align:center}.loading-spinner-container.compact{gap:5px;min-height:100px;padding:20px}.loading-spinner-spinner{border:4px solid #e2e8f0;border-top-color:#718096;height:48px;width:48px}.loading-spinner-container.compact .loading-spinner-spinner{border-width:3px;height:32px;width:32px}.loading-spinner-text{color:#1e3a5f;font-size:1.1rem;font-weight:600}.loading-spinner-container.compact .loading-spinner-text,.loading-spinner-subtext{font-size:.9rem}.loading-spinner-container.compact .loading-spinner-subtext{font-size:.8rem}.login-container{align-items:center;background:#f7fafc;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-width:420px;padding:40px;position:relative;width:100%;z-index:1}.login-card h2{color:#1e3a5f;font-size:32px;font-weight:600;letter-spacing:3px;margin:0 0 30px;text-align:center;text-transform:uppercase}.login-icon{animation:rocket 2s ease-in-out infinite;height:32px;object-fit:contain;position:absolute;right:-50px;top:0;width:32px}@keyframes rocket{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(15deg)}}.form-group{margin-bottom:24px}.form-group label{font-size:14px;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.form-group input{background:#fffffff2;border-radius:8px;box-sizing:border-box;font-size:16px;padding:14px 16px;transition:all .3s}.form-group input::placeholder{color:#a0aec0}.form-group input:focus{border-color:#2c5282;box-shadow:0 0 15px #0000000d}.error-message{background:#e53e3e1a;border:1px solid #e53e3e4d;box-shadow:0 0 15px #e53e3e26;color:#e53e3e;font-size:14px;margin-bottom:24px;padding:14px}.login-button{background:#718096;border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:#fff;cursor:pointer;font-size:16px;font-weight:700;letter-spacing:2px;padding:16px;text-transform:uppercase;transition:all .3s;width:100%}.login-button:hover:not(:disabled){background:#4a5568;box-shadow:0 4px 6px #00000026;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{background:#a0aec0;cursor:not-allowed;opacity:.5}.connection-alert-container{align-items:center;background:#f7fafc;display:flex;justify-content:center;min-height:100vh;padding:20px}.connection-alert{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000000d;max-width:600px;padding:40px;text-align:center;width:100%}.alert-icon{stroke:#e53e3e;height:64px;margin:0 auto 20px;width:64px}.connection-alert h2{color:#1e3a5f;font-size:24px;font-weight:600;margin:0 0 20px}.alert-message{color:#718096;font-size:16px;line-height:1.6;margin-bottom:30px}.alert-details{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:24px;text-align:left}.alert-details p{color:#2d3748;margin:12px 0}.alert-details ul{color:#4a5568;margin:12px 0 20px 24px}.alert-details li{line-height:1.6;margin:10px 0}.solution{border-top:1px solid #e2e8f0;margin-top:24px;padding-top:24px}.alert-details pre{background:#edf2f7;border:1px solid #e2e8f0;border-radius:8px;color:#2d3748;font-size:13px;margin-top:12px;overflow-x:auto;padding:16px;text-align:left}.alert-details code{background:#edf2f7;border:1px solid #e2e8f0;border-radius:4px;color:#2d3748;font-family:Courier New,monospace;padding:3px 8px}.retry-button{background:#718096;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 32px;transition:all .3s}.retry-button:hover{background:#4a5568;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.dashboard-container .icon-svg,.dashboard-container img[src*=".svg"]{stroke:currentColor;fill:none}.dashboard-container{background:#f5f5f5;color:#111827;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.dashboard-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 70px);padding:2rem;text-align:center}.loading-spinner{border:4px solid #e5e7eb;border-top-color:#ffd414;height:50px;margin-bottom:1rem;width:50px}.loading-text{color:#727272;font-size:14px;margin:0}.dashboard-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffffa;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 2px 0 #0000000d;padding:20px 40px}.header-content h1{color:#414141;font-size:24px;font-weight:600;margin:0}.header-content p{color:#727272;font-size:14px;margin:5px 0 0}.user-info{align-items:center;gap:20px}.user-badge{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;display:flex;gap:12px;padding:12px 20px}.privilege-icon{font-size:1.5rem}.user-details{display:flex;flex-direction:column;gap:4px}.user-email{color:#1a1a1a;font-weight:600}.privilege-text{font-size:11.9px;font-weight:500;letter-spacing:.025em;text-transform:uppercase}.logout-button{background:#dc2626;border:none;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;color:#fff;cursor:pointer;font-weight:600;padding:10px 24px;transition:all .25s ease}.logout-button:hover{background:#b91c1c;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.dashboard-layout{display:flex;min-height:calc(100vh - 80px)}.dashboard-main{background:#f5f5f5;flex:1 1;overflow-y:auto;padding:0}.dashboard-tabs{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:0;overflow-x:auto;padding:0 10%}.dashboard-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:15px 24px;position:relative;transition:all .15s ease;white-space:nowrap}.dashboard-tab.active,.dashboard-tab:hover{background:#f9fafb;color:#414141}.dashboard-tab.active{border-bottom-color:#ffd414;font-weight:600}.dashboard-section{padding:40px 10%;width:100%}.section-title{border-bottom:1px solid #e5e7eb;font-size:24px;margin:0 0 30px;padding-bottom:15px}.monitoring-header{align-items:flex-start;border-bottom:2px solid #ffd41433;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.header-left{flex:1 1}.dashboard-title{color:#414141;font-size:24px;font-weight:600;margin:0 0 10px}.last-update{color:#727272;font-size:14px;margin:0}.header-right{gap:20px}.header-right,.system-status{align-items:center;display:flex}.system-status{background:#fff;border:1px solid #e5e7eb;border-radius:6px;gap:8px;padding:8px 16px}.status-indicator{border-radius:9999px;display:inline-block;height:12px;width:12px}.status-indicator.healthy{background:#15803d;box-shadow:0 0 0 3px #15803d33}.status-text{color:#1a1a1a}.refresh-button,.status-text{font-size:14px;font-weight:500}.refresh-button{align-items:center;background:#414141;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;gap:8px;padding:10px 20px;transition:all .15s ease}.refresh-button:hover:not(:disabled){background:#2a2a2a;transform:translateY(-1px)}.refresh-button:disabled{cursor:not-allowed;opacity:.6}.refresh-icon{stroke:currentColor;color:currentColor;flex-shrink:0}.metrics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:30px}.metric-card{box-shadow:0 1px 2px 0 #0000000d;padding:24px}.metric-card:hover{border-color:#d1d5db}.metric-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.metric-title{color:#727272;font-size:14px;font-weight:600;margin:0}.metric-icon{stroke:#727272;color:#727272;height:24px;width:24px}.metric-value{font-size:36px}.loading-metric{color:#9ca3af;font-size:24px}.section-content{width:100%}.dashboard-welcome{margin-bottom:40px}.welcome-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border:1px solid #d1d5db;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;padding:30px}.welcome-card h2{color:#414141;font-size:24px;font-weight:600;margin:0 0 15px}.welcome-card p{color:#727272;font-size:14px;margin:10px 0}.dashboard-content{display:flex;flex-direction:column;gap:30px}.privilege-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;padding:30px}.privilege-section h3{color:#414141;font-size:20px;font-weight:600;margin:0 0 25px}.admin-section{border:2px solid #dc26264d}.manager-section{border:2px solid #ca8a044d}.user-section{border:2px solid #15803d4d}.unknown-section{border:2px solid #9ca3af4d}.admin-features,.manager-features,.user-features{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.feature-card{background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;padding:20px;transition:all .25s ease}.feature-card:hover{background:#fff;border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-4px)}.feature-card h4{color:#414141;font-size:16px;font-weight:600;margin:0 0 10px}.feature-card p{color:#727272;font-size:14px;margin:0}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;text-align:center}.error-container h2{color:#dc2626;font-weight:600}.error-container p{color:#727272;margin:0 0 30px}.spinner{border:3px solid #e5e7eb;border-top-color:#ffd414;height:50px;margin-bottom:20px;width:50px}.integration-list{display:flex;flex-direction:column;gap:15px;margin-top:20px}.integration-item{background:#fffffff2;border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .25s ease}.integration-item:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.integration-item h4{color:#414141;font-size:16px;font-weight:600;margin:0 0 8px}.integration-item p{color:#727272;font-size:14px;margin:0}.analytics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px}.analytics-card{background:#fffffff2;border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .25s ease}.analytics-card:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.analytics-card h4{color:#414141;font-size:16px;font-weight:600;margin:0 0 8px}.analytics-card p{color:#727272;font-size:14px;margin:0}.map-container{align-items:center;background:#fffffff2;border:1px solid #e5e7eb;border-radius:8px;color:#727272;display:flex;font-size:16px;justify-content:center;margin-top:20px;min-height:400px;padding:40px}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:20px;text-align:center}.user-info{width:100%}.dashboard-layout,.user-info{flex-direction:column}.dashboard-main{padding:20px}.dashboard-tabs{padding:0 20px}.dashboard-tab{font-size:.85rem;padding:12px 16px}.admin-features,.analytics-grid,.manager-features,.rt-metrics-grid,.user-features{grid-template-columns:1fr}}.action-icon,.percentage-icon,.status-icon-inline,.status-icon-small,.table-icon,.warning-icon-small{stroke:currentColor;color:currentColor;display:inline-block;flex-shrink:0;height:16px;margin-right:4px;vertical-align:middle;width:16px}.section-icon{stroke:currentColor;color:currentColor;display:inline-block;flex-shrink:0;margin-right:10px;vertical-align:middle}.cache-badge{background:#f5f5f5;border-radius:9999px;color:#727272;display:inline-block;font-size:10px;font-weight:500;margin-left:12px;padding:4px 10px}.rt-metrics-grid{grid-gap:1.5vw;display:grid;gap:1.5vw;grid-template-columns:repeat(4,1fr);margin-top:2vw}.rt-metric-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;display:flex;flex-direction:column;padding:1.5vw}.rt-metric-label{color:#727272;font-size:14px;font-weight:500;margin-bottom:.8vw}.rt-metric-value{color:#414141;font-size:30px;font-weight:700;margin-bottom:.5vw}.rt-metric-value.rt-value-blue{color:#2563eb}.rt-metric-value.rt-value-green{color:#15803d}.rt-metric-percentage{color:#727272;font-size:11.9px;margin-top:.3vw}.rt-metric-percentage.rt-percentage-green{color:#15803d}.distribucion-cola-section{border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:1.5rem}.distribucion-title{color:#414141;font-size:20px;font-weight:600;margin-bottom:1.5rem}.colas-flow-container{display:flex;flex-direction:column;gap:1.5rem}.cola-flow-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;padding:1.25rem}.cola-flow-header{align-items:center;border-bottom:2px solid #ffd414;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem}.cola-flow-name{color:#414141;font-size:16px;font-weight:600;margin:0}.cola-flow-total{background:#f5f5f5;border-radius:9999px;color:#727272;font-size:14px;font-weight:600;padding:.35rem .75rem}.cola-chart{align-items:flex-end;display:flex;gap:.25rem;min-height:180px;overflow-x:auto;padding:1rem .5rem .5rem;scrollbar-color:#d1d5db #f9fafb;scrollbar-width:thin}.cola-chart::-webkit-scrollbar{height:6px}.cola-chart::-webkit-scrollbar-track{background:#f9fafb;border-radius:3px}.cola-chart::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.chart-bar-wrapper{align-items:center;display:flex;flex:1 1;flex-direction:column;max-width:70px;min-width:50px}.chart-bar-value{color:#414141;font-size:10px;font-weight:600;margin-bottom:4px;text-align:center}.chart-bar-container{align-items:flex-end;display:flex;height:100px;justify-content:center;width:100%}.chart-bar{border-radius:4px 4px 0 0;cursor:pointer;min-height:4px;transition:all .25s ease;width:28px}.chart-bar:hover{opacity:.85;transform:scaleX(1.1)}.chart-bar-label{word-wrap:break-word;color:#727272;font-size:10px;height:28px;line-height:1.1;margin-top:6px;max-width:60px;overflow:hidden;text-align:center}@media (max-width:768px){.cola-flow-header{align-items:flex-start;flex-direction:column;gap:.5rem}.chart-bar-wrapper{min-width:40px}.chart-bar{width:22px}.chart-bar-label{font-size:.5rem}.chart-bar-value{font-size:.6rem}}.no-data{color:#9ca3af;font-size:14px;margin:0;padding:1rem;text-align:center}.correlacion-metrics-grid{grid-gap:1.5vw;display:grid;gap:1.5vw;grid-template-columns:repeat(4,1fr);margin-top:2vw}.correlacion-metric-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;display:flex;flex-direction:column;padding:1.5vw;text-align:center}.correlacion-icon{font-size:2.5rem;margin-bottom:1vw;opacity:.7}.correlacion-value{color:#414141;font-size:36px;font-weight:700;margin-bottom:.5vw}.correlacion-value-blue{color:#2563eb}.correlacion-value-yellow{color:#ca8a04}.correlacion-value-green{color:#15803d}.correlacion-label{color:#727272;font-size:14px;font-weight:500;margin-bottom:.3vw}.correlacion-percentage{color:#9ca3af;font-size:11.9px}@media (max-width:768px){.correlacion-metrics-grid{grid-template-columns:1fr}}.monitoreo-section{border-top:1px solid #e5e7eb;margin-top:3vw;padding-top:2vw}.monitoreo-section:first-of-type{border-top:none;margin-top:0;padding-top:0}.monitoreo-subtitle{color:#414141;font-size:20px;font-weight:600;margin-bottom:1.5vw}.estados-rpu-grid{grid-gap:1.5vw;display:grid;gap:1.5vw;grid-template-columns:repeat(4,1fr);margin-bottom:2vw}.estado-rpu-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;display:flex;flex-direction:column;padding:1.5vw;text-align:center}.estado-dot{border-radius:9999px;height:16px;margin-bottom:1vw;width:16px}.estado-dot-green{background-color:#15803d}.estado-dot-yellow{background-color:#ca8a04}.estado-dot-red{background-color:#dc2626}.estado-dot-gray{background-color:#9ca3af}.estado-value{color:#414141;font-size:36px;margin-bottom:.5vw}.estado-label{color:#727272;font-size:14px}.correlacion-monitoreo-grid{grid-gap:1.5vw;display:grid;gap:1.5vw;grid-template-columns:repeat(3,1fr);margin-bottom:2vw}.correlacion-monitoreo-card{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;display:flex;flex-direction:column;padding:1.5vw;text-align:center}.correlacion-monitoreo-value{font-size:36px;font-weight:700;margin-bottom:.5vw}.correlacion-value-orange{color:#ca8a04}.correlacion-monitoreo-label{color:#727272;font-size:14px;font-weight:500;margin-bottom:.3vw}.correlacion-monitoreo-sublabel{color:#9ca3af;font-size:11.9px;margin-top:.2vw}@media (max-width:768px){.correlacion-monitoreo-grid,.estados-rpu-grid{grid-template-columns:1fr}}.systems-section{border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:1.5rem}.section-subtitle{color:#414141;font-size:20px;font-weight:600;margin:0}.systems-status-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.2rem}.systems-status-header .monitoreo-subtitle{margin-bottom:0}.loading-indicator{color:#727272;font-size:11.9px;font-style:italic}.test-button{align-items:center;background:#414141;display:flex;gap:.5rem}.test-button:hover{background:#2a2a2a}.test-icon{font-size:1.2rem}.metric-icon-text{font-size:1.5rem}.error-icon-text{font-size:4rem;margin-bottom:1rem}.systems-dual-section{grid-gap:2rem;border-top:1px solid #e5e7eb;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-top:2rem;padding-top:1.5rem}.systems-column,.test-column{background:#fffffffa;border:1px solid #e5e7eb;border-radius:12px;padding:1.5rem}.systems-status-list{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.system-status-row{align-items:center;background:#f9fafb;border-left:3px solid #9ca3af;border-radius:8px;display:flex;gap:1rem;padding:.75rem 1rem}.system-status-row.system-status-connected{background:#15803d0d;border-left-color:#15803d}.system-status-row.system-status-error{background:#dc26260d;border-left-color:#dc2626}.system-status-row.system-status-not_configured{background:#ca8a040d;border-left-color:#ca8a04}.system-icon{filter:brightness(0) saturate(100%) invert(23%) sepia(19%) saturate(548%) hue-rotate(175deg) brightness(93%) contrast(92%);height:22px;opacity:.8;width:22px}.system-status-row.system-status-connected .system-icon{filter:brightness(0) saturate(100%) invert(53%) sepia(61%) saturate(444%) hue-rotate(99deg) brightness(91%) contrast(85%)}.system-status-row.system-status-error .system-icon{filter:brightness(0) saturate(100%) invert(52%) sepia(89%) saturate(2147%) hue-rotate(332deg) brightness(94%) contrast(97%)}.system-status-row.system-status-not_configured .system-icon{filter:brightness(0) saturate(100%) invert(76%) sepia(72%) saturate(449%) hue-rotate(2deg) brightness(105%) contrast(88%)}.system-name{color:#414141;flex:1 1;font-weight:500}.system-badge{align-items:center;border-radius:9999px;display:flex;font-size:14px;font-weight:700;height:28px;justify-content:center;width:28px}.system-badge.status-connected{background:#f0fdf4;color:#15803d}.system-badge.status-error{background:#fef2f2;color:#dc2626}.system-badge.status-not_configured{background:#fefce8;color:#ca8a04}.system-badge.status-checking{background:#e5e7eb;color:#727272}.test-container{margin-top:1rem}.test-live-button{border:none;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;font-size:14px;gap:.75rem;padding:1rem 1.5rem;width:100%}.test-live-button,.test-live-button-small{align-items:center;background:#414141;color:#fff;cursor:pointer;display:flex;font-weight:600;justify-content:center;transition:all .25s ease}.test-live-button-small{border:none;border-radius:6px;box-shadow:0 1px 2px 0 #0000000d;font-size:11.9px;gap:.5rem;padding:.6rem 1.2rem}.test-live-button-small:hover:not(:disabled){background:#2a2a2a;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-1px)}.test-live-button-small:disabled{cursor:not-allowed;opacity:.7}.test-live-button-small.testing{background:#2a2a2a}.test-live-button:hover:not(:disabled){background:#2a2a2a;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.test-live-button:disabled{cursor:not-allowed;opacity:.7}.test-live-button.testing{background:#2a2a2a}.test-live-icon{font-size:1.3rem;transition:transform .3s ease}.test-live-icon.spinning{animation:spin 1s linear infinite}.test-results{display:flex;flex-direction:column;gap:.5rem;margin-top:1.25rem}.test-result-item{align-items:center;background:#f9fafb;border-radius:6px;display:flex;font-size:14px;justify-content:space-between;padding:.6rem 1rem;transition:all .25s ease}.test-result-item.success{background:#15803d14;border-left:3px solid #15803d}.test-result-item.error{background:#dc262614;border-left:3px solid #dc2626}.test-result-item.pending{background:#f9fafb;border-left:3px solid #9ca3af}.test-result-name{color:#727272;font-weight:500}.test-result-status{font-weight:600}.test-result-item.success .test-result-status{color:#15803d}.test-result-item.error .test-result-status{color:#dc2626}.test-result-item.pending .test-result-status{color:#727272}@media (max-width:900px){.systems-dual-section{grid-template-columns:1fr}}.refresh-button-small{border-radius:8px;min-width:auto;padding:.5rem}.refresh-button-small .refresh-icon{height:18px;margin:0;width:18px}.systems-status-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.system-status-card{align-items:center;background:#fffffffa;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;display:flex;gap:1rem;padding:1.2rem 1.5rem;transition:all .25s ease}.system-status-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.system-status-icon{align-items:center;background:#f9fafb;border-radius:8px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.system-status-icon img{height:24px;opacity:.8;width:24px}.system-status-icon-wrapper{align-items:center;background:#f9fafb;border-radius:8px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.system-connection-icon{color:#727272;font-size:1.8rem}.system-status-badge{align-items:center;border-radius:9999px;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:32px;justify-content:center;width:32px}.system-status-badge.status-connected{background:#f0fdf4;color:#15803d}.system-status-badge.status-error{background:#fef2f2;color:#dc2626}.system-status-badge.status-not_configured{background:#fefce8;color:#ca8a04}.system-status-badge.status-checking{background:#e5e7eb;color:#727272}.system-status-connected .system-connection-icon{color:#48bb78}.system-status-error .system-connection-icon{color:#f56565}.system-status-not_configured .system-connection-icon{color:#ecc94b}.system-status-checking .system-connection-icon{color:#a0aec0}.system-status-connected .system-status-icon-wrapper{background:#48bb781a}.system-status-error .system-status-icon-wrapper{background:#f565651a}.system-status-not_configured .system-status-icon-wrapper{background:#ecc94b1a}.system-status-checking .system-status-icon-wrapper{background:#f7fafc}.dashboard-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.dashboard-header .header-left{display:flex;flex-direction:column;gap:4px}.dashboard-header .header-right{align-items:center;display:flex;gap:12px}.system-healthy-badge{align-items:center;background:#f0fdf4;border:1px solid #86efac;border-radius:9999px;color:#15803d;display:flex;font-size:11.9px;font-weight:500;gap:8px;padding:8px 16px}.system-healthy-badge .healthy-icon{align-items:center;background:#15803d;border-radius:9999px;color:#fff;display:flex;font-size:10px;font-weight:700;height:18px;justify-content:center;width:18px}.system-healthy-badge .healthy-text{color:#15803d}.btn-actualizar{align-items:center;background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .15s ease}.btn-actualizar:hover:not(:disabled){background:#e6bf12}.btn-actualizar:disabled{cursor:not-allowed;opacity:.6}.btn-actualizar img{filter:brightness(0) saturate(100%) invert(23%) sepia(0) saturate(0) hue-rotate(180deg) brightness(95%) contrast(90%);height:16px;width:16px}.metrics-grid-4{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.metric-card-simple{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px 0 #0000000d;padding:20px;position:relative;transition:all .15s ease}.metric-card-simple:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.metric-card-simple .metric-label{color:#727272;display:block;font-size:11.9px;font-weight:500;margin-bottom:8px}.metric-card-simple .metric-icon-right{height:24px;opacity:.5;position:absolute;right:20px;top:20px;width:24px}.metric-card-simple .metric-value-large{color:#414141;font-size:30px;font-weight:700;line-height:1.2}.dashboard-panels{grid-gap:24px;display:grid;gap:24px;grid-template-columns:1fr 1fr}.panel-sistemas,.panel-tests{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 2px 0 #0000000d;padding:24px}.panel-header{margin-bottom:20px}.panel-title{color:#414141;font-size:16px;font-weight:600;margin:0}.panel-actions{align-items:center;display:flex;gap:12px}.auto-refresh-label{color:#727272;font-size:11.9px;gap:6px}.auto-refresh-label input{accent-color:#ffd414;cursor:pointer}.btn-ejecutar{align-items:center;background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;display:flex;font-size:11.9px;font-weight:500;gap:6px;padding:8px 16px;transition:all .15s ease}.btn-ejecutar:hover{background:#e6bf12}.btn-ejecutar span{font-size:11.9px}.panel-content-empty{align-items:center;background:#f9fafb;border-radius:8px;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.panel-content-empty .empty-icon{height:48px;margin-bottom:16px;opacity:.4;width:48px}.panel-content-empty p{color:#727272;font-size:14px;line-height:1.5;margin:0;max-width:300px}.sistemas-list{display:flex;flex-direction:column;gap:12px}.sistema-item{align-items:center;border-bottom:1px solid #f5f5f5;display:flex;justify-content:space-between;padding:12px 0}.sistema-item:last-child{border-bottom:none}.sistema-name{color:#727272}.sistema-name,.sistema-status{font-size:14px;font-weight:500}.sistema-status{align-items:center;display:flex;gap:8px}.sistema-status.connected{color:#15803d}.sistema-status.connected .status-dot{background:#15803d}.sistema-status.error{color:#dc2626}.sistema-status.error .status-dot{background:#dc2626}.sistema-status.warning{color:#ca8a04}.sistema-status.warning .status-dot{background:#ca8a04}.sistema-status.checking{color:#9ca3af}.sistema-status.checking .status-dot{animation:pulse-dot 1.5s ease-in-out infinite;background:#9ca3af}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.sistema-status .status-dot{border-radius:9999px;height:8px;width:8px}.btn-ejecutar.loading{background:#727272;color:#fff;cursor:not-allowed}.btn-spinner-small{animation:btn-spin .8s linear infinite;border:2px solid #4141414d;border-radius:9999px;border-top-color:#414141;display:inline-block;height:12px;width:12px}.panel-content-loading{align-items:center;background:#f9fafb;border-radius:8px;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.panel-content-loading .test-spinner{animation:btn-spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:9999px;border-top-color:#ffd414;height:32px;margin-bottom:12px;width:32px}.panel-content-loading p{color:#727272;font-size:14px;margin:0}.panel-test-results{display:flex;flex-direction:column;gap:8px}.test-result-row{align-items:center;background:#f9fafb;border-left:3px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;padding:12px 16px}.test-result-row.connected{background:#15803d0d;border-left-color:#15803d}.test-result-row.error{background:#dc26260d;border-left-color:#dc2626}.test-result-row.not_configured{background:#ca8a040d;border-left-color:#ca8a04}.test-name{color:#727272;font-weight:500}.test-status{font-size:11.9px;font-weight:600}.test-status.connected{color:#15803d}.test-status.error{color:#dc2626}.test-status.not_configured{color:#ca8a04}@media (max-width:1024px){.metrics-grid-4{grid-template-columns:repeat(2,1fr)}.dashboard-panels{grid-template-columns:1fr}}@media (max-width:600px){.metrics-grid-4{grid-template-columns:1fr}.dashboard-header{flex-direction:column;gap:16px}.dashboard-header .header-right{justify-content:flex-end;width:100%}}.system-status-info{flex:1 1;min-width:0}.system-status-name{color:#414141;font-size:14px;font-weight:600;margin-bottom:.25rem}.system-status-message{color:#727272;font-size:11.9px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.system-status-indicator{border-radius:9999px;flex-shrink:0;height:14px;position:relative;width:14px}.status-connected{background:#15803d;box-shadow:0 0 8px #15803d80}.status-error{background:#dc2626;box-shadow:0 0 8px #dc262680}.status-not_configured{background:#ca8a04;box-shadow:0 0 8px #ca8a0480}.status-checking{animation:pulse-gray 1.5s ease-in-out infinite;background:#9ca3af}@keyframes pulse-gray{0%,to{opacity:1}50%{opacity:.5}}.system-status-connected{border-left:3px solid #15803d}.system-status-error{border-left:3px solid #dc2626}.system-status-not_configured{border-left:3px solid #ca8a04}.system-status-checking{border-left:3px solid #9ca3af}.system-status-connected .system-status-icon{background:#15803d1a}.system-status-connected .system-status-icon img{filter:invert(33%) sepia(85%) saturate(503%) hue-rotate(101deg) brightness(95%) contrast(91%)}.system-status-error .system-status-icon{background:#dc26261a}.system-status-error .system-status-icon img{filter:invert(24%) sepia(98%) saturate(3063%) hue-rotate(349deg) brightness(92%) contrast(95%)}.system-status-not_configured .system-status-icon{background:#ca8a041a}.system-status-not_configured .system-status-icon img{filter:invert(54%) sepia(92%) saturate(576%) hue-rotate(21deg) brightness(93%) contrast(98%)}@media (max-width:768px){.systems-status-grid{grid-template-columns:1fr}.system-status-card{padding:1rem}.system-status-icon{height:40px;width:40px}.system-status-icon img{height:20px;width:20px}}.animated-number{font-feature-settings:"tnum";align-items:baseline;display:inline-flex;font-variant-numeric:tabular-nums;transition:color .3s ease}.animated-number-large{font-size:48px;font-weight:700;line-height:1.2}.animated-number-medium{font-size:32px;font-weight:600;line-height:1.3}.animated-number-small{font-size:24px;font-weight:600;line-height:1.4}.animated-number-tiny{font-size:18px;font-weight:500;line-height:1.4}.animated-number-prefix,.animated-number-suffix{font-size:.6em;margin:0 2px;opacity:.7}.animated-number-value{color:inherit}.animated-number.is-animating .animated-number-value{color:#60a5fa}.animated-number-placeholder{color:#ffffff4d;letter-spacing:2px}.animated-number-skeleton{animation:number-skeleton-shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#ffffff0d 25%,#ffffff26 50%,#ffffff0d 75%);background-size:200% 100%;border-radius:4px;display:inline-block;height:1em;width:80px}.animated-number-large .animated-number-skeleton{height:48px;width:100px}.animated-number-medium .animated-number-skeleton{height:32px;width:80px}.animated-number-small .animated-number-skeleton{height:24px;width:60px}.animated-number-tiny .animated-number-skeleton{height:18px;width:50px}@keyframes number-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes value-update-flash{0%{background-color:initial}50%{background-color:#60a5fa1a}to{background-color:initial}}.animated-number.value-updated{animation:value-update-flash .5s ease;border-radius:4px}.animated-number.trend-up .animated-number-value{color:#22c55e}.animated-number.trend-down .animated-number-value{color:#ef4444}.animated-number.trend-neutral .animated-number-value{color:#94a3b8}@media (max-width:768px){.animated-number-large{font-size:36px}.animated-number-medium{font-size:28px}.animated-number-small{font-size:20px}}@media (max-width:480px){.animated-number-large{font-size:28px}.animated-number-medium{font-size:24px}.animated-number-small{font-size:18px}}.skeleton{animation:skeleton-shimmer 1.5s ease-in-out infinite;background:linear-gradient(90deg,#ffffff0d 25%,#ffffff26 50%,#ffffff0d 75%);background-size:200% 100%;border-radius:4px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{height:16px;margin-bottom:8px}.skeleton-text:last-child{margin-bottom:0}.skeleton-number{align-items:center;display:flex;justify-content:center}.skeleton-number-large .skeleton{height:48px;width:80px}.skeleton-number-medium .skeleton{height:32px;width:60px}.skeleton-number-small .skeleton{height:24px;width:40px}.skeleton-card{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;min-height:120px;padding:20px}.skeleton-card-header{margin-bottom:16px}.skeleton-card-body{align-items:flex-start;display:flex;flex-direction:column}.skeleton-card-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.skeleton-table{background:#ffffff08;border-radius:8px;overflow:hidden;width:100%}.skeleton-table-header{background:#ffffff0d;border-bottom:1px solid #ffffff1a;display:flex;gap:16px;padding:16px}.skeleton-table-body{padding:8px 0}.skeleton-table-row{border-bottom:1px solid #ffffff0d;display:flex;gap:16px;padding:12px 16px}.skeleton-table-row:last-child{border-bottom:none}.skeleton-chart{align-items:flex-end;background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;display:flex;justify-content:center;padding:20px}.skeleton-chart-bars{align-items:flex-end;display:flex;gap:12px;height:80%;justify-content:space-around;width:100%}.skeleton-bar{border-radius:4px 4px 0 0;flex:1 1;max-width:60px}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}.skeleton{background-color:#ffffff14}@media (max-width:768px){.skeleton-card-grid{grid-template-columns:repeat(2,1fr)}.skeleton-card{min-height:100px;padding:16px}}@media (max-width:480px){.skeleton-card-grid{grid-template-columns:1fr}}.skeleton-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:24px}.skeleton-stat-card{align-items:flex-start;background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;display:flex;flex-direction:column;padding:16px}.skeleton-system-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:24px}.skeleton-system-card{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;padding:20px}.skeleton-system-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.skeleton-system-body{padding:8px 0}.skeleton-circle{border-radius:50%}.skeleton-integracion{padding:24px}.skeleton-tabs{border-bottom:1px solid #ffffff1a;display:flex;gap:8px;margin-bottom:24px;padding-bottom:16px}.skeleton-tab{border-radius:8px}.skeleton-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px}.skeleton-monitoreo{padding:24px}.skeleton-filters{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.skeleton-flow-general{padding:24px}.settings-container{background:#f5f5f5;color:#414141;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.settings-content{margin:0 10%;padding:30px 0}.alert{max-width:800px}.alert-error{background:#7180961a;border:2px solid #7180964d;color:#4a5568}.alert-success{background:#00ff8826;border:2px solid #00ff8880;color:#00a86b;font-weight:600}.settings-content{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin:0 auto;max-width:1200px}.platform-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:30px}.platform-header h2{align-items:center;color:#414141;display:flex;font-size:20px;font-weight:600;gap:10px;margin:0 0 25px}.platform-icon{stroke:currentColor;color:currentColor;height:24px;width:24px}.alert-icon-small{height:20px;width:20px}.alert-icon-small,.status-icon-small{stroke:currentColor;color:currentColor;flex-shrink:0}.delete-icon,.status-icon-small{height:18px;width:18px}.delete-icon{stroke:currentColor;color:currentColor}.credentials-form{margin-bottom:30px}.auth-toggle{background:#2c528205;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:20px;margin:15px 0;padding:12px}.auth-toggle label{align-items:center;color:#2c5282;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:8px}.auth-toggle input[type=radio]{accent-color:#2c5282;cursor:pointer;height:18px;margin:0;width:18px}.form-group{margin-bottom:20px}.form-group label{color:#1a1a2e;display:block;font-weight:500;margin-bottom:8px}.form-group input{background:#fff;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 2px #0000000d;color:#2d3748;font-size:1rem;padding:12px;transition:all .2s ease;width:100%}.form-group input:focus{background:#fff;border-color:#ffd414;box-shadow:0 0 0 3px #ffd41433,0 2px 4px #0000001a;outline:none}.form-group input:disabled{background:#f7fafc;color:#4a5568;cursor:not-allowed}.form-group select{-webkit-appearance:none;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'%3E%3Cpath fill='%23718096' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 2px #0000000d;color:#2d3748;cursor:pointer;font-size:1rem;padding:12px 36px 12px 12px;transition:all .2s ease;width:100%}.form-group select:focus{border-color:#ffd414;box-shadow:0 0 0 3px #ffd41433,0 2px 4px #0000001a;outline:none}.form-actions{gap:10px;margin-top:10px}.test-btn{background:linear-gradient(135deg,#f093fb,#f5576c);border:2px solid #f093fb80;border-radius:8px;box-shadow:0 4px 15px #f093fb66,0 0 0 1px #f093fb33;color:#fff;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px;transition:all .3s ease}.test-btn:hover:not(:disabled){box-shadow:0 6px 20px #f093fb99;transform:translateY(-2px)}.test-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.save-btn{background:#ffd414;border:none;border-radius:6px;box-shadow:0 2px 4px #0000001a;color:#414141;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px;transition:all .15s ease}.save-btn:hover:not(:disabled){background:#e6bf12;box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.save-btn:disabled{cursor:not-allowed;opacity:.5}.connection-status{align-items:center;animation:fadeIn .3s ease;border-radius:6px;box-shadow:0 2px 4px #0000000d;display:flex;font-size:14px;font-weight:500;gap:8px;margin:10px 0;padding:12px}.connection-status.success{background:#f0fdf4;border:2px solid #15803d66;color:#15803d;font-weight:600}.connection-status.error{background:#fef2f2;border:2px solid #dc262666;color:#dc2626;font-weight:600}.saved-credentials{border-top:1px solid #e2e8f0;margin-top:30px;padding-top:30px}.saved-credentials h3{color:#1e3a5f;font-size:1.1rem;margin:0 0 15px}.no-credentials{color:#718096;font-style:italic;padding:20px;text-align:center}.credentials-list{display:flex;flex-direction:column;gap:10px}.credential-item{align-items:flex-start;background:#ffffffe6;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 3px #00000014;display:flex;justify-content:space-between;padding:15px;transition:all .2s ease}.credential-item:hover{background:#fff;border-color:#2c5282;box-shadow:0 2px 4px #0000001a;transform:translateX(2px)}.credential-info{display:flex;flex:1 1;flex-direction:column;gap:8px}.cred-detail{align-items:center;display:flex;gap:10px}.cred-label{color:#718096;font-size:12px;font-weight:500;min-width:80px}.cred-value{color:#1e3a5f;font-size:14px;font-weight:600}.cred-value:last-child{color:#718096;font-family:monospace}.delete-btn{background:#f443;border:1px solid #ff444480;border-radius:6px;color:#faa;cursor:pointer;font-size:1rem;padding:8px 12px;transition:all .3s ease}.delete-btn:hover{background:#ff44444d;transform:scale(1.1)}.settings-tabs{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:0;margin-bottom:0;padding:0 10%}.settings-tab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;bottom:-1px;color:#727272;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:15px 24px;position:relative;transition:all .15s ease}.settings-tab.active,.settings-tab:hover{background:#f9fafb;color:#414141}.settings-tab.active{border-bottom-color:#ffd414;font-weight:600}.tab-icon{stroke:currentColor;color:currentColor;height:20px;width:20px}.users-section{margin:0 auto;max-width:1200px;width:100%}.users-section>.alert{margin-bottom:20px}.users-subtabs{border-bottom:1px solid #e5e7eb;display:flex;gap:0;margin-bottom:30px}.user-subtab{align-items:center;background:#0000;border:none;border-bottom:3px solid #0000;bottom:-1px;color:#727272;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:15px 24px;position:relative;transition:all .15s ease}.user-subtab:hover{background:#f9fafb;color:#414141}.user-subtab.active{border-bottom-color:#ffd414;color:#414141;font-weight:600}.add-user-container{align-items:flex-start;display:flex;gap:20px}.user-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:30px}.user-form-card.compact{flex:0 0 400px;padding:20px}.user-form-card.compact h3{color:#1e3a5f;font-size:1.2rem;margin:0 0 20px}.user-form-card.compact .form-group{margin-bottom:15px}.users-list-box{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000001a;flex:1 1;max-height:600px;overflow-y:auto;padding:20px}.users-list-header{margin-bottom:20px}.users-list-header h3{color:#1e3a5f;font-size:1.2rem;margin:0 0 15px}.users-list-header .search-input-group{align-items:center;display:flex;gap:10px}.users-list-header .search-input-group input{border:1px solid #e2e8f0;border-radius:6px;flex:1 1;font-size:.95rem;padding:10px}.users-list-header .search-input-group input:focus{border-color:#718096;box-shadow:0 0 0 3px #7180961a;outline:none}.user-form-card h2{color:#1e3a5f;font-size:1.5rem;margin:0 0 25px}.user-form-card h3{color:#2d3748;font-size:1.2rem;margin:20px 0 15px}.users-list,.users-list-section{margin-top:20px}.users-list{display:flex;flex-direction:column;gap:10px}.user-item{align-items:center;background:#ffffffe6;border:1px solid #e2e8f0;border-radius:6px;box-shadow:0 1px 3px #00000014;display:flex;justify-content:space-between;padding:15px;transition:all .2s ease}.user-item:hover{background:#fff;border-color:#718096;box-shadow:0 2px 4px #0000001a;transform:translateX(2px)}.user-info{display:flex;flex:1 1;flex-direction:column;gap:8px}.users-section .user-email{color:#1a1a1a;font-size:14px;font-weight:600}.user-privilege{align-items:center;display:flex}.privilege-badge{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px;text-transform:capitalize}.privilege-badge.admin{background:#fef2f2;border:1px solid #dc26264d;color:#dc2626}.privilege-badge.client{background:#f3f4f6;border:1px solid #7272724d;color:#727272}.privilege-badge.manager{background:#dbeafe;border:1px solid #2563eb4d;color:#2563eb}.user-date{color:#718096;font-size:.85rem}.user-actions{display:flex;gap:8px}.edit-btn{align-items:center;background:#71809633;border:1px solid #71809680;border-radius:6px;color:#718096;cursor:pointer;display:flex;font-size:1rem;justify-content:center;padding:8px 12px;transition:all .3s ease}.edit-btn:hover{background:#7180964d;transform:scale(1.05)}.search-section{margin-top:20px}.search-input-group{align-items:flex-end;display:flex;gap:10px}.search-input-group input{flex:1 1}.search-btn{font-size:14px;font-weight:600;min-width:42px;padding:10px 12px}.search-btn:hover:not(:disabled){box-shadow:0 4px 6px #00000026;transform:translateY(-2px)}.search-btn:disabled{opacity:.5}.search-results{margin-top:30px}.user-config-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.user-config-modal{animation:slideIn .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.user-config-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px 24px}.user-config-modal-header h3{color:#1e3a5f;font-size:1.25rem;font-weight:600;margin:0}.modal-close-btn{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.modal-close-btn:hover{background:#f3f4f6}.modal-close-btn img{height:20px;width:20px}.user-config-modal-body{padding:24px}.user-email-display{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:20px;padding:16px}.user-email-display label{color:#718096;display:block;font-size:.85rem;font-weight:500;margin-bottom:6px}.user-email-display .email-value{align-items:center;color:#1e3a5f;display:flex;font-size:1rem;font-weight:600;gap:8px}.email-locked-icon{height:16px;opacity:.6;width:16px}.projects-section{border-top:1px solid #e2e8f0;margin-top:20px;padding-top:20px}.projects-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.projects-section h4{align-items:center;color:#1e3a5f;display:flex;font-size:1rem;font-weight:600;gap:8px;margin:0}.projects-actions{display:flex;gap:8px}.project-action-btn{background:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#718096;cursor:pointer;font-size:.8rem;font-weight:500;padding:6px 12px;transition:all .15s ease}.project-action-btn:hover{background:#f7fafc;border-color:#cbd5e0}.project-action-btn.active{background:#ffd414;border-color:#ffd414;color:#414141}.projects-info{margin-bottom:10px}.projects-count{color:#718096;font-size:.85rem;font-weight:500}.projects-count.warning{color:#dc2626}.projects-count.success{color:#15803d}.projects-list{display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.project-item,label.project-item{align-items:center;background:#f9fafb;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;font-weight:400;gap:10px;margin:0;padding:10px 12px;transition:all .2s ease}.project-item:hover{background:#f3f4f6;border-color:#d1d5db}.project-item.selected{background:#ffd4141a;border-color:#ffd414}.project-checkbox{accent-color:#ffd414;cursor:pointer;height:18px;width:18px}.project-name{color:#414141;flex:1 1;font-size:.95rem}.no-projects{background:#f9fafb;border-radius:6px;color:#718096;font-style:italic;padding:20px;text-align:center}.user-config-modal-footer{background:#f9fafb;border-radius:0 0 12px 12px;border-top:1px solid #e2e8f0;display:flex;gap:12px;padding:20px 24px}.user-config-modal-footer .cancel-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#414141;cursor:pointer;flex:1 1;font-size:14px;font-weight:500;padding:12px;transition:all .15s ease}.user-config-modal-footer .cancel-btn:hover{background:#f3f4f6;border-color:#d1d5db}@media (max-width:768px){.settings-container{padding:20px}.settings-content{grid-template-columns:1fr}.settings-tabs{padding:0 5%}.users-subtabs{flex-wrap:wrap}.search-input-group{align-items:stretch;flex-direction:column}.search-btn{height:auto;min-width:auto;padding:12px;width:100%}.add-user-container{flex-direction:column}.user-form-card.compact{flex:1 1;width:100%}.users-list-box{max-height:none;width:100%}.user-config-modal{max-height:95vh;width:95%}}.toast-container{bottom:24px;display:flex;flex-direction:column-reverse;gap:12px;max-height:calc(100vh - 100px);max-width:400px;overflow-x:hidden;overflow-y:auto;pointer-events:none;position:fixed;right:24px;z-index:9999}.toast-container::-webkit-scrollbar{width:4px}.toast-container::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.toast-item{align-items:flex-start;animation:toastSlideIn .3s ease-out forwards;background:#fff;border-left:4px solid #718096;border-radius:12px;box-shadow:0 4px 20px #0000001f,0 2px 8px #00000014;display:flex;gap:12px;max-width:400px;min-width:320px;overflow:hidden;padding:16px;pointer-events:auto;position:relative;transform-origin:bottom right}@keyframes toastSlideIn{0%{opacity:0;transform:translateX(100%) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}.toast-item.toast-exit{animation:toastSlideOut .3s ease-in forwards}@keyframes toastSlideOut{0%{opacity:1;transform:translateX(0) scale(1)}to{opacity:0;transform:translateX(100%) scale(.95)}}.toast-success{border-left-color:#38a169}.toast-success .toast-icon-container{background:#38a1691a}.toast-success .toast-icon{filter:brightness(0) saturate(100%) invert(52%) sepia(52%) saturate(566%) hue-rotate(103deg) brightness(93%) contrast(92%)}.toast-error{border-left-color:#e53e3e}.toast-error .toast-icon-container{background:#e53e3e1a}.toast-error .toast-icon{filter:brightness(0) saturate(100%) invert(37%) sepia(74%) saturate(1836%) hue-rotate(336deg) brightness(92%) contrast(93%)}.toast-warning{border-left-color:#d69e2e}.toast-warning .toast-icon-container{background:#d69e2e1a}.toast-warning .toast-icon{filter:brightness(0) saturate(100%) invert(63%) sepia(65%) saturate(547%) hue-rotate(11deg) brightness(96%) contrast(89%)}.toast-info{border-left-color:#3182ce}.toast-info .toast-icon-container{background:#3182ce1a}.toast-info .toast-icon{filter:brightness(0) saturate(100%) invert(40%) sepia(84%) saturate(409%) hue-rotate(176deg) brightness(92%) contrast(87%)}.toast-loading{border-left-color:#718096}.toast-loading .toast-icon-container{background:#7180961a}.toast-loading .toast-icon{filter:brightness(0) saturate(100%) invert(55%) sepia(8%) saturate(722%) hue-rotate(173deg) brightness(91%) contrast(85%)}.toast-icon-container{align-items:center;border-radius:8px;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.toast-icon{height:20px;width:20px}.toast-icon-spinning{animation:toastSpin 1s linear infinite}@keyframes toastSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.toast-content{flex:1 1;min-width:0}.toast-title{color:#1e3a5f;font-size:14px;font-weight:600;line-height:1.3;margin-bottom:4px}.toast-message{word-wrap:break-word;color:#4a5568;font-size:13px;line-height:1.4}.toast-details{border-top:1px solid #e2e8f0;color:#718096;font-size:12px;line-height:1.4;margin-top:6px;padding-top:6px}.toast-action-btn{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;color:#2d3748;cursor:pointer;font-size:12px;font-weight:500;margin-top:10px;padding:6px 14px;transition:all .2s ease}.toast-action-btn:hover{background:#edf2f7;border-color:#cbd5e0}.toast-close-btn{align-items:center;background:#0000;border:none;border-radius:4px;cursor:pointer;display:flex;height:24px;justify-content:center;opacity:.5;padding:0;position:absolute;right:10px;top:10px;transition:all .2s ease;width:24px}.toast-close-btn:hover{background:#f7fafc;opacity:1}.toast-close-icon{height:14px;width:14px}.toast-progress{animation:toastProgress linear forwards;background:currentColor;border-radius:0 0 0 12px;bottom:0;height:3px;left:0;opacity:.3;position:absolute}.toast-success .toast-progress{background:#38a169}.toast-error .toast-progress{background:#e53e3e}.toast-warning .toast-progress{background:#d69e2e}.toast-info .toast-progress{background:#3182ce}@keyframes toastProgress{0%{width:100%}to{width:0}}@media (max-width:480px){.toast-container{bottom:16px;left:16px;max-width:none;right:16px}.toast-item{max-width:none;min-width:auto}}.toast-item:hover{box-shadow:0 6px 24px #00000026,0 3px 10px #0000001a}.toast-item{transition:box-shadow .2s ease}.flow-container{background:#f5f5f5;color:#111827;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.flow-header{display:none}.flow-header p{color:#4a5568;font-size:1.1rem}.alert{align-items:center;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;font-size:.95rem;font-weight:500;gap:10px;margin:0 auto 30px;max-width:1400px;padding:15px 20px}.alert-error{background:#ff444426;border:2px solid #ff444480;color:#e53e3e;font-weight:600}.flow-content{margin:0 10%;padding:30px 0}.flow-diagram{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;flex-direction:column;gap:0;margin-bottom:50px;min-height:400px;padding:40px}.flow-diagram,.flow-empty{align-items:center;display:flex}.flow-empty{color:#718096;font-size:1.1rem;justify-content:center;min-height:300px}.flow-step-wrapper{align-items:center;display:flex;flex-direction:column;gap:15px;max-width:300px;width:100%}.flow-circle{align-items:center;border:4px solid;border-radius:50%;display:flex;height:120px;justify-content:center;position:relative;transition:all .4s ease;width:120px}.flow-circle.idle{background:#4040401a;border-color:#4040404d;opacity:.5}.flow-circle.pending{background:#80808033;border-color:#80808080}.flow-circle.running{animation:pulse 1.5s infinite;background:#ffd41426;border-color:#ffd414;box-shadow:0 0 12px #ffd41466}.flow-circle.success{background:#15803d26;border-color:#15803d;box-shadow:0 0 20px #15803d66}.flow-circle.error{background:#dc262626;border-color:#dc2626;box-shadow:0 0 20px #dc262666}.circle-content{align-items:center;display:flex;flex-direction:column;gap:8px}.circle-icon{font-size:2.5rem}.circle-icon,.flow-circle.running .circle-icon{animation:rotate 2s linear infinite}.flow-circle.error .circle-icon,.flow-circle.pending .circle-icon,.flow-circle.success .circle-icon{animation:none}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.circle-number{color:#718096;font-size:1.2rem;font-weight:700}.step-info{text-align:center;width:100%}.step-name{color:#414141;font-size:16px;font-weight:600;margin-bottom:5px}.step-message{border:1px solid #0000;border-radius:6px;font-size:.9rem;font-weight:500;margin-top:5px;padding:8px 12px}.step-message.idle{background:#7180961a;border-color:#71809633;color:#718096}.step-message.pending{background:#80808026;border-color:#8080804d;color:#4a5568}.step-message.running{background:#ffd41426;border-color:#ffd414;color:#414141;font-weight:600}.step-message.success{background:#f0fdf4;border-color:#15803d4d;color:#15803d;font-weight:600}.step-message.error{background:#fef2f2;border-color:#dc262666;color:#dc2626;font-weight:600}.flow-connector{align-items:center;display:flex;flex-direction:column;margin:10px 0;transition:all .3s ease}.connector-line{background:#8080804d;height:40px;transition:all .3s ease;width:3px}.flow-connector.active .connector-line{background:#718096;box-shadow:0 2px 4px #0000001a}.connector-arrow{color:#8080804d;font-size:1.5rem;margin-top:-5px;transition:all .3s ease}.flow-connector.active .connector-arrow{animation:bounce 1s infinite;color:#15803d}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(5px)}}.flow-controls{margin-bottom:40px;text-align:center}.control-buttons{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:15px}.execute-btn{background:#ffd414;border:none;border-radius:6px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;color:#414141;cursor:pointer!important;font-size:14px;font-weight:600;padding:15px 30px;pointer-events:auto!important;position:relative;transition:all .15s ease;z-index:100}.execute-btn:hover:not(:disabled){background:#e6bf12;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.execute-btn:disabled{cursor:not-allowed!important;opacity:.6}.execute-btn:active{background:#ccaa10;transform:scale(.98)}.execute-btn-single{align-items:center;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer!important;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 25px;pointer-events:auto!important;position:relative;transition:all .15s ease;z-index:10}.execute-btn-single.icinga{background:#fff;box-shadow:0 1px 3px 0 #0000001a;color:#414141}.execute-btn-single.icinga:hover:not(:disabled){background:#f9fafb;border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.execute-btn-single.rt{background:#fff;box-shadow:0 1px 3px 0 #0000001a;color:#414141}.execute-btn-single.rt:hover:not(:disabled){background:#f9fafb;border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.execute-btn-single:disabled{cursor:not-allowed;opacity:.6}.repeat-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#727272;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 25px;transition:all .15s ease}.repeat-btn:hover{background:#f9fafb;border-color:#ffd414;transform:translateY(-2px)}.repeat-btn.active{background:#15803d;border-color:#15803d;box-shadow:0 2px 8px #15803d4d;color:#fff}.repeat-btn.active:hover{background:#166534;border-color:#166534}.execute-btn .btn-icon,.execute-btn-single .btn-icon,.repeat-btn .btn-icon{flex-shrink:0;height:16px;width:16px}.repeat-pending-indicator{align-items:center;background:#f0fdf4;border:1px solid #15803d4d;border-radius:6px;color:#15803d;display:inline-flex;font-size:14px;font-weight:500;gap:10px;margin-top:10px;padding:10px 20px}.repeat-pending-indicator .repeat-icon{height:18px;width:18px}.repeat-pending-indicator .repeat-icon.spinning{animation:spin 1.5s linear infinite}.flow-result{align-items:center;border-radius:8px;display:inline-flex;font-size:1rem;font-weight:600;gap:10px;margin-top:20px;padding:15px}.flow-result.success{background:#f0fdf4;border:1px solid #15803d80;color:#15803d}.flow-result.error{background:#fef2f2;border:1px solid #dc262680;color:#dc2626}.flow-info{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;padding:30px}.flow-info h3{color:#414141;font-size:16px;font-weight:600;margin:0 0 20px}.flow-info ul{list-style:none;margin:0;padding:0}.flow-info li{border-bottom:1px solid #e5e7eb;color:#727272;font-size:14px;padding:10px 0}.flow-info li:last-child{border-bottom:none}.flow-info li strong{color:#414141}.error-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;text-align:center}.error-icon{font-size:4rem;margin-bottom:20px}.error-container h2{color:#f44;margin:0 0 15px}.error-container p{color:#4a5568;margin:10px 0}.flow-history{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;margin-top:50px;padding:30px}.history-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.history-header h3{color:#414141;font-size:16px;font-weight:600;margin:0}.refresh-btn:hover:not(:disabled){transform:translateY(-1px)}.refresh-btn:disabled{opacity:.5}.loading-history,.no-history{color:#718096;font-style:italic;padding:30px;text-align:center}.history-table-container{overflow-x:auto}.history-table{border-collapse:collapse;margin-top:10px;width:100%}.history-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.history-table th{color:#414141;font-size:11.9px;font-weight:600;padding:12px;text-align:left;text-transform:uppercase}.history-table tbody tr{border-bottom:1px solid #e5e7eb;transition:all .15s ease}.history-table tbody tr:hover{background:#f9fafb}.history-table tbody tr.successful{border-left:3px solid #15803d}.history-table tbody tr.error{border-left:3px solid #dc2626}.history-table td{color:#727272;font-size:14px;padding:12px}.process-name{color:#414141;font-weight:600}.status-badge{border-radius:12px;display:inline-block;font-size:.85rem;padding:4px 12px}.status-badge.successful{background:#f0fdf4;border:1px solid #15803d4d;color:#15803d}.status-badge.error{background:#fef2f2;border:1px solid #dc26264d;color:#dc2626}.status-badge.ok,.status-badge.up{background:#f0fdf4;border:1px solid #15803d4d;color:#15803d}.status-badge.warning{background:#fefce8;border:1px solid #ca8a044d;color:#ca8a04}.status-badge.critical,.status-badge.down{background:#fef2f2;border:1px solid #dc26264d;color:#dc2626}.status-badge.unknown{background:#f3f4f6;border:1px solid #7272724d;color:#727272}.process-date{color:#718096;font-family:monospace;font-size:.85rem}.process-error{color:#f88;font-size:.85rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.flow-tabs{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:0;margin-bottom:0;padding:0 10%}.flow-tab{background:#0000;border:none;border-bottom:3px solid #0000;bottom:-1px;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:15px 24px;position:relative;transition:all .15s ease}.flow-tab.active,.flow-tab:hover{background:#f9fafb;color:#414141}.flow-tab.active{border-bottom-color:#ffd414;font-weight:600}.rpu-historial-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;padding:30px}.historial-header-section{margin-bottom:30px}.historial-header-section h2{color:#414141;font-size:24px;font-weight:600;margin:0 0 10px}.historial-subtitle{color:#727272;font-size:14px;margin:0}.historial-filters{grid-gap:16px;align-items:end;background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:grid;gap:16px;grid-template-columns:200px 1fr 220px;margin-bottom:24px;padding:20px}.filter-group{gap:6px}.filter-label{color:#727272;font-size:10px;letter-spacing:.5px}.filter-select{background:#fff;border:1px solid #e5e7eb;color:#414141;height:42px;padding:10px 14px;transition:all .15s ease}.filter-select:hover{border-color:#ffd414}.filter-select:focus{border-color:#ffd414;box-shadow:0 0 0 2px #ffd41433;outline:none}.search-group{display:flex;flex-direction:column;gap:6px}.search-input-wrapper{gap:8px}.search-input{background:#fff;border:1px solid #e5e7eb;box-sizing:border-box;color:#414141;height:42px;padding:10px 14px;transition:all .15s ease}.search-input:focus{box-shadow:0 0 0 2px #ffd41433}.search-input::placeholder{color:#9ca3af}.search-btn{align-items:center;background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;display:flex;flex-shrink:0;height:42px;justify-content:center;padding:0 14px;transition:all .15s ease;width:42px}.search-btn .search-icon{stroke:currentColor;color:currentColor;height:20px;width:20px}.search-btn:hover:not(:disabled){background:#e6bf12;transform:scale(1.05)}.search-btn:disabled{cursor:not-allowed;opacity:.6}.loading-historial,.no-historial{color:#718096;font-size:1.1rem;padding:60px 20px;text-align:center}.historial-table-container{border-radius:8px;overflow-x:auto}.historial-table{background:#fff;border-collapse:collapse;width:100%}.historial-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.historial-table th{color:#414141;font-size:11.9px;font-weight:600;letter-spacing:.5px;padding:15px 12px;text-align:left;text-transform:uppercase;white-space:nowrap}.historial-table tbody tr{border-bottom:1px solid #e5e7eb;transition:all .15s ease}.historial-table tbody tr:hover{background:#f9fafb}.historial-table td{color:#727272;font-size:14px;padding:12px;white-space:nowrap}.rpu-cell{color:#414141;font-weight:600}.sitio-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis}.fecha-cell{color:#718096;font-family:monospace;font-size:.85rem}.trafico-cell{font-weight:600;text-align:center}.tcp-cell,.udp-cell{color:#15803d;font-size:18px;text-align:center}.estado-cell,.ip-cell{font-family:monospace;font-size:.85rem}.estado-cell{color:#718096}.fuentes-cell{font-family:monospace;font-size:.85rem;max-width:200px;overflow:hidden;text-overflow:ellipsis}@media (max-width:768px){.flow-container,.flow-diagram{padding:20px}.history-table{font-size:.8rem}.history-table td,.history-table th{padding:8px}.flow-tabs{flex-direction:column}.flow-tab{text-align:left;width:100%}.historial-filters{align-items:stretch;flex-direction:column;gap:10px}.filter-group,.filter-select,.search-group{width:100%}.search-input{flex:1 1}.historial-table-container{overflow-x:scroll}.historial-table{min-width:1000px}}.cache-status-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a}.cache-status-header{border-bottom:1px solid #e5e7eb}.cache-status-header h2{color:#414141;font-size:16px}.cache-loading{animation:cachePulse 1.5s infinite;color:#718096}@keyframes cachePulse{0%,to{opacity:1}50%{opacity:.5}}.cache-stat{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;transition:all .15s ease}.cache-stat:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a}.cache-stat-value{color:#15803d;font-size:24px}.cache-stat-label{color:#727272;font-size:11.9px}.cache-endpoints{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px}.cache-endpoints h3{color:#414141;font-size:14px}.cache-missing-badge{background:#fef2f2;border-radius:9999px;color:#dc2626;font-size:10px}.cache-endpoint-item{border-radius:6px;color:#414141;font-size:11.9px;transition:all .15s ease}.cache-endpoint-item.cached{background:#f0fdf4;border:1px solid #15803d4d}.cache-endpoint-item.missing{background:#fef2f2;border:1px solid #dc26264d}.cache-endpoint-ttl{background:#edf2f7;color:#718096}.cache-warmup-status{background:#ffd4141a;border:1px solid #ffd4144d;border-radius:6px;margin-top:15px;padding:12px 15px}.cache-warmup-status h3{color:#414141;font-size:14px;font-weight:500;margin:0 0 10px}.cache-warmup-details{display:flex;flex-wrap:wrap;font-size:11.9px;gap:10px}.cache-warmup-details span{background:#f3f4f6;border-radius:9999px;color:#727272;padding:4px 10px}.warmup-step{background:#fefce8!important;color:#ca8a04!important}.warmup-failed{background:#fef2f2!important;color:#dc2626!important}.warmup-fechas{background:#f0fdf4!important;color:#15803d!important}.cache-fechas{border-top:1px solid #e2e8f0;color:#718096;margin-top:10px}.cache-status-empty{color:#718096}.snapshots-container{background:#f7fafc;min-height:100vh;padding:0}.snapshots-content{margin:0 10%;padding:30px 0}.snapshots-loading{color:#718096;font-size:1.1rem;padding:60px 20px;text-align:center}.snapshots-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:0 auto 40px;max-width:1200px}.snapshot-card{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:15px;transition:all .3s ease}.snapshot-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-4px)}.snapshot-card.error{background:linear-gradient(135deg,#fff,#fff5f5);border-color:#f44}.snapshot-card.success{background:linear-gradient(135deg,#fff,#f0fff4);border-color:#38a169}.snapshot-card.no_data{background:linear-gradient(135deg,#fff,#fffaf0);border-color:orange}.snapshot-card-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.header-stats{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.percentage-stats{display:flex;font-size:.85rem;font-weight:600;gap:12px}.percentage-success{color:#38a169}.percentage-error{color:#e53e3e}.snapshot-card-header h3{color:#1e3a5f;font-size:1.2rem;font-weight:600;margin:0}.status-badge{border-radius:20px;font-size:.9rem;font-weight:600;letter-spacing:.5px;padding:6px 16px;text-transform:uppercase}.status-badge.error{background:#f443;border:1px solid #f446;color:#e53e3e}.status-badge.success{background:#38a16933;border:1px solid #38a16966;color:#38a169}.status-badge.no_data{background:#ffa50033;border:1px solid #ffa50066;color:#ff8c00}.snapshot-card-body{min-height:80px}.consolidated-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin:0 10%;padding:30px}.consolidated-header{display:none;margin-bottom:20px}.consolidated-status{color:#718096;font-size:.95rem;margin:0}.consolidated-actions{align-items:center;display:flex;gap:12px;justify-content:flex-end;margin-bottom:20px}.search-bar{flex:1 1;max-width:300px}.search-bar input{border-radius:8px;padding:10px 15px}.btn-apply,.btn-clear,.btn-filters,.btn-refresh{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;padding:10px 20px;transition:all .2s ease}.btn-filters{color:#4a5568}.btn-filters,.btn-refresh{background:#fff;border:1px solid #e2e8f0}.btn-refresh{align-items:center;border-radius:50%;display:flex;font-size:1.2rem;height:40px;justify-content:center;width:40px}.btn-clear{background:#fff;border:1px solid #e2e8f0;color:#4a5568}.btn-apply{background:#718096;color:#fff}.btn-clear:hover,.btn-filters:hover,.btn-refresh:hover{background:#f7fafc}.btn-apply:hover{background:#718096}.filters-section{animation:slideDown .3s ease-out;background:#f7fafc;border-radius:8px;margin-bottom:20px;padding:15px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.filters-row{flex-wrap:nowrap;gap:10px}.filter-item{flex:0 1 auto;min-width:0}.filter-item:first-child{min-width:140px}.filter-item:nth-child(2){min-width:130px}.filter-item:nth-child(3){min-width:150px}.filter-item:nth-child(4){min-width:140px}.filter-item label{color:#4a5568;display:block;font-size:.8rem;font-weight:500;margin-bottom:4px;white-space:nowrap}.filter-item input[type=date],.filter-item select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;padding:6px 10px;width:100%}.filter-actions{flex-shrink:0;gap:8px}.filter-actions .btn-apply,.filter-actions .btn-clear{font-size:.9rem;padding:8px 16px;white-space:nowrap}.consolidated-empty,.consolidated-loading{color:#718096;font-size:1rem;padding:40px 20px;text-align:center}.consolidated-table-container{margin-top:20px;overflow-x:auto}.consolidated-table{background:#fff;border-collapse:collapse;width:100%}.consolidated-table thead{background:#f7fafc}.consolidated-table th{border-bottom:2px solid #e2e8f0;color:#1e3a5f;font-size:.9rem;font-weight:600;padding:12px 15px;text-align:left}.consolidated-table td{border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:.9rem;padding:12px 15px}.consolidated-table tbody tr:hover{background:#f7fafc}.error-message{background:#ff44441a;border-left:4px solid #f44;border-radius:8px;padding:15px}.error-message strong{color:#e53e3e;display:block;font-size:1rem;margin-bottom:10px}.error-message p{font-size:.95rem;margin:0 0 10px;word-break:break-word}.error-date{color:#718096;font-family:monospace;font-size:.85rem}.error-count,.error-date{display:block;margin-top:10px}.error-count{border-top:1px solid #f443;color:#e53e3e;font-size:.9rem;font-weight:600;padding-top:10px}.success-message{background:#38a1691a;border-left:4px solid #38a169;border-radius:8px;padding:15px}.success-message p{color:#2d5016;font-size:.95rem;font-weight:600;margin:0 0 10px}.success-date{color:#718096;display:block;font-family:monospace;font-size:.85rem}.no-data-message{background:#ffa5001a;border-left:4px solid orange;border-radius:8px;padding:15px}.no-data-message p{color:#b7791f;font-size:.95rem;font-weight:600;margin:0 0 10px}.no-data-time{color:#718096;display:block;font-family:monospace;font-size:.85rem}.last-update-info{background:#2c52820d;border-radius:12px;grid-column:1/-1;margin-top:20px;padding:20px;text-align:center}.last-update-info p{color:#2c5282;font-size:.95rem;font-weight:500;margin:0}.ticket-link{color:#3182ce;cursor:pointer;font-weight:500;text-decoration:underline;transition:color .2s ease}.ticket-link:hover{color:#2c5282}.ticket-popup-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.ticket-popup-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ticket-popup-header{align-items:center;background:#f7fafc;border-bottom:2px solid #e2e8f0;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:20px 30px}.ticket-popup-header h2{color:#1e3a5f;font-size:1.5rem;font-weight:600;margin:0}.ticket-popup-close{align-items:center;background:none;border:none;border-radius:50%;color:#718096;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.ticket-popup-close:hover{background:#e2e8f0;color:#4a5568}.ticket-popup-body{flex:1 1;overflow-y:auto;padding:20px 30px}.ticket-popup-empty,.ticket-popup-loading{color:#718096;font-size:1rem;padding:40px 20px;text-align:center}.ticket-popup-table-container{overflow-x:auto}.ticket-popup-table{border-collapse:collapse;font-size:.9rem;width:100%}.ticket-popup-table thead{background:#f7fafc;position:-webkit-sticky;position:sticky;top:0;z-index:10}.ticket-popup-table th{border-bottom:2px solid #e2e8f0;color:#1e3a5f;font-weight:600;padding:12px 10px;text-align:left;white-space:nowrap}.ticket-popup-table td{border-bottom:1px solid #e2e8f0;color:#4a5568;padding:12px 10px}.ticket-popup-table tbody tr:hover{background:#f7fafc}.ticket-subject{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-status{border-radius:12px;display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.ticket-status-new{background:#38a16933;color:#2d5016}.ticket-status-open{background:#ed893633;color:#c05621}.ticket-status-resolved{background:#4299e133;color:#2c5282}.ticket-status-rejected{background:#e53e3e33;color:#c53030}.ticket-status-unknown{background:#a0aec033;color:#4a5568}.ticket-popup-footer{background:#f7fafc;border-radius:0 0 12px 12px;border-top:2px solid #e2e8f0;padding:15px 30px}.ticket-popup-footer p{color:#4a5568;font-size:.95rem;font-weight:500;margin:0}@media (max-width:768px){.snapshots-container{padding:20px}.snapshots-content{grid-template-columns:1fr}.snapshot-card-header{align-items:flex-start;flex-direction:column;gap:10px}.ticket-popup-content{max-height:95vh;max-width:95vw}.ticket-popup-header{padding:15px 20px}.ticket-popup-header h2{font-size:1.2rem}.ticket-popup-body{padding:15px 20px}.ticket-popup-table{font-size:.8rem}.ticket-popup-table td,.ticket-popup-table th{padding:8px 6px}.ticket-subject{max-width:150px}}.search-section{margin-bottom:30px}.search-title{color:#1e3a5f;font-size:1.3rem;font-weight:600;margin:0 0 15px}.search-bar-main{align-items:stretch;display:flex;gap:12px}.search-input-large{border:2px solid #e2e8f0;border-radius:10px;flex:1 1;font-size:1.1rem;max-width:400px;padding:14px 20px;transition:all .2s ease}.search-input-large:focus{border-color:#1e3a5f;box-shadow:0 0 0 3px #1e3a5f1a;outline:none}.search-input-large::placeholder{color:#a0aec0}.btn-search-main{background:#1e3a5f;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:14px 28px;transition:all .2s ease}.btn-search-main:hover:not(:disabled){background:#2c5282;transform:translateY(-1px)}.btn-search-main:disabled{background:#a0aec0;cursor:not-allowed}.search-error{background:#e53e3e1a;border-left:4px solid #e53e3e;border-radius:6px;color:#c53030;font-size:.95rem;margin-top:15px;padding:12px 16px}.search-result-card{background:linear-gradient(135deg,#fff,#f7fafc);border:2px solid #1e3a5f;border-radius:12px;box-shadow:0 4px 12px #1e3a5f26;margin-top:20px;padding:20px 25px}.search-result-card h4{border-bottom:2px solid #e2e8f0;color:#1e3a5f;font-size:1.2rem;font-weight:600;margin:0 0 20px;padding-bottom:12px}.result-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.result-item{display:flex;flex-direction:column;gap:4px}.result-label{color:#718096;font-size:.85rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.result-value{color:#1e3a5f;font-size:1rem;font-weight:600}.list-toggle-section{border-top:1px solid #e2e8f0;margin:30px 0 20px;padding-top:20px}.btn-hide-list,.btn-show-list{align-items:center;border:2px solid #1e3a5f;border-radius:10px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:10px;padding:12px 24px;transition:all .2s ease}.btn-show-list{background:#fff;color:#1e3a5f}.btn-show-list:hover{background:#1e3a5f;color:#fff}.btn-hide-list{background:#f7fafc;border-color:#e2e8f0;color:#718096}.btn-hide-list:hover{background:#e2e8f0;color:#4a5568}.btn-icon{height:18px;width:18px}.btn-show-list:hover .btn-icon{filter:brightness(0) invert(1)}.full-list-section{animation:fadeIn .3s ease-out;margin-top:20px}.pagination-controls{align-items:center;background:#fff;border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:center;margin-top:0;padding:20px}.pagination-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1e3a5f;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#1e3a5f;border-color:#1e3a5f;color:#fff}.pagination-btn:disabled{background:#f7fafc;cursor:not-allowed;opacity:.5}.pagination-info{color:#4a5568;font-size:14px;padding:0 16px}@media (max-width:768px){.pagination-controls{flex-wrap:wrap;gap:8px}.pagination-btn{font-size:12px;padding:6px 12px}.pagination-info{order:-1;padding:0 0 8px;text-align:center;width:100%}.consolidated-section{margin:0 5%;padding:20px}.search-bar-main{flex-direction:column}.search-input-large{max-width:100%}.btn-search-main{width:100%}.result-grid{grid-template-columns:1fr}.btn-hide-list,.btn-show-list{justify-content:center;width:100%}}.vista-general-container{background:#f7fafc;min-height:100vh;padding:30px}.vista-general-loading{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;min-height:400px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#718096;height:40px;margin-bottom:20px;width:40px}.vista-general-resumen{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.resumen-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 4px #0000001a;gap:15px;padding:20px}.resumen-card,.resumen-icon{align-items:center;display:flex}.resumen-icon{background:#f7fafc;border-radius:12px;flex-shrink:0;height:60px;justify-content:center;width:60px}.resumen-icon img{filter:brightness(0) saturate(100%) invert(27%) sepia(8%) saturate(1200%) hue-rotate(182deg) brightness(95%) contrast(88%);height:32px;width:32px}.resumen-content{flex:1 1}.resumen-label{color:#718096;font-size:.9rem;margin-bottom:5px}.resumen-value{color:#1e3a5f;font-size:2rem;font-weight:700;margin-bottom:5px}.resumen-subtitle{color:#a0aec0;font-size:.85rem}.flujos-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:30px}.flujo-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;padding:20px}.flujo-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:25px;padding-bottom:15px}.flujo-header h2{color:#1e3a5f;font-size:1.2rem;font-weight:600;margin:0}.refresh-btn-small{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;gap:5px;padding:8px 12px;transition:all .2s}.refresh-btn-small:hover:not(:disabled){background:#edf2f7}.refresh-btn-small img{height:16px;width:16px}.refresh-btn-small img.spinning{animation:spin 1s linear infinite}.flujo-header-buttons{align-items:center;display:flex;gap:8px}.upload-btn-small{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;display:flex;gap:5px;padding:8px 12px;transition:all .2s}.upload-btn-small:hover:not(:disabled){background:#edf2f7}.upload-btn-small img{height:16px;width:16px}.upload-btn-small img.spinning{animation:spin 1s linear infinite}.upload-notification{animation:slideIn .3s ease-out;border-radius:8px;font-size:.875rem;margin-top:10px;padding:12px 16px}.upload-notification.success{background:#c6f6d5;border:1px solid #9ae6b4;color:#22543d}.upload-notification.warning{background:#fef5e7;border:1px solid #fbd38d;color:#7c2d12}.upload-notification.error{background:#fed7d7;border:1px solid #fc8181;color:#742a2a}.upload-progress-container{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:15px;padding:15px}.upload-progress-bar{background:#e2e8f0;height:24px;margin-bottom:8px;width:100%}.upload-progress-bar,.upload-progress-fill{border-radius:12px;overflow:hidden;position:relative}.upload-progress-fill{background:linear-gradient(90deg,#4299e1,#3182ce);height:100%;transition:width .3s ease}.upload-progress-fill:after{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.upload-progress-text{color:#4a5568;font-size:.875rem;font-weight:500;margin-bottom:8px;text-align:center}.upload-progress-stats{display:flex;flex-wrap:wrap;font-size:.8125rem;gap:15px;justify-content:center;margin-top:8px}.upload-progress-stats .stat-item{border-radius:4px;font-weight:500;padding:4px 10px}.upload-progress-stats .stat-item.success{background:#c6f6d5;color:#22543d}.upload-progress-stats .stat-item.info{background:#bee3f8;color:#2c5282}.upload-progress-stats .stat-item.warning{background:#fbd38d;color:#7c2d12}.upload-progress-stats .stat-item.error{background:#fed7d7;color:#742a2a}.flujo-subsection{margin-top:20px}.subsection-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.subsection-header h3{color:#2d3748;font-size:1.2rem;margin:0}.timestamp{color:#718096;font-size:.9rem}.subsection-stats{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px}.stat-item{align-items:center;display:flex;gap:10px}.stat-label{color:#4a5568;font-weight:500}.stat-value{color:#1e3a5f;font-size:1.1rem}.stat-subvalue{color:#718096;font-size:.9rem}.status-boxes{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-bottom:20px}.status-box{align-items:center;border:2px solid;border-radius:8px;display:flex;justify-content:center;padding:20px}.status-box.red{background:#e53e3e1a;border-color:#e53e3e}.status-box.green{background:#38a1691a;border-color:#38a169}.status-box-content{text-align:center;width:100%}.status-box-value{font-size:2rem;font-weight:700;margin-bottom:5px}.status-box.red .status-box-value{color:#e53e3e}.status-box.green .status-box-value{color:#38a169}.status-box-label{color:#4a5568;font-size:.9rem;font-weight:500;margin-bottom:5px}.status-box-percent{color:#718096;font-size:.85rem;font-weight:600}.subsection-footer{color:#718096;font-size:.9rem;margin-bottom:20px;text-align:center}.status-cards{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.status-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:15px;text-align:center}.status-dot{border-radius:50%;height:12px;margin:0 auto 10px;width:12px}.status-dot.green{background:#38a169}.status-dot.red{background:#e53e3e}.status-dot.yellow{background:#d69e2e}.status-value{color:#1e3a5f;font-size:1.8rem;font-weight:700;margin-bottom:5px}.status-label{color:#718096;font-size:.85rem}.rt-section{border-top:2px solid #e2e8f0;margin-top:30px;padding-top:30px}.rt-section h4{color:#2d3748;font-size:1.1rem;margin:0 0 15px}.rt-summary{color:#4a5568;font-size:1rem;margin-bottom:20px}.rt-status-cards{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.rt-status-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:15px;text-align:center}.rt-status-card.blue{background:#4299e11a;border-color:#4299e1}.rt-status-card.orange{background:#dd6b201a;border-color:#dd6b20}.rt-status-card.green{background:#38a1691a;border-color:#38a169}.rt-status-value{color:#1e3a5f;font-size:1.5rem;font-weight:700;margin-bottom:5px}.rt-status-label{color:#718096;font-size:.85rem;font-weight:600;text-transform:uppercase}.fecha-status{margin:25px 0}.fecha-status h4{color:#2d3748;font-size:1.1rem;margin:0 0 15px}.fecha-boxes{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.fecha-box{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;padding:20px;text-align:center}.fecha-box.green{background:#38a1691a;border-color:#38a169}.fecha-box.orange{background:#dd6b201a;border-color:#dd6b20}.fecha-value{color:#1e3a5f;font-size:2rem;font-weight:700;margin-bottom:5px}.fecha-label{color:#718096;font-size:.9rem;font-weight:600}.info-completa{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:25px;padding:15px;text-align:center}.info-label{color:#4a5568;font-weight:500;margin-right:10px}.info-value{color:#1e3a5f;font-size:1.2rem;font-weight:700}.cobertura-trafico{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin:25px 0;padding:20px;text-align:center}.cobertura-label{color:#4a5568;font-weight:500;margin-bottom:10px}.cobertura-value{color:#1e3a5f;font-size:2.5rem;font-weight:700;margin-bottom:10px}.cobertura-detail{color:#718096;font-size:.9rem}.tcp-ratio{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin:25px 0;padding:20px;text-align:center}.tcp-label{color:#4a5568;font-weight:500;margin-bottom:10px}.tcp-value{color:#1e3a5f;font-size:2.5rem;font-weight:700}.estados-sitios{border-top:2px solid #e2e8f0;margin-top:25px;padding-top:25px}.estados-sitios h4{color:#2d3748;font-size:1.1rem;margin:0 0 15px}.estados-summary{display:flex;flex-wrap:wrap;gap:20px}.hosts-lista-container{grid-gap:30px;border-top:2px solid #e2e8f0;display:grid;gap:30px;grid-template-columns:1fr 1fr;margin-top:25px;padding-top:25px}.hosts-section{display:flex;flex-direction:column}.hosts-section-title{align-items:center;color:#2d3748;display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin:0 0 10px}.copy-button{align-items:center;align-self:flex-start;background:#718096;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:6px;margin-bottom:15px;padding:8px 14px;transition:all .2s ease}.copy-button:hover{background:#4a5568;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.copy-button img{filter:brightness(0) invert(1);height:14px;width:14px}.hosts-count{background:#e2e8f0;border-radius:12px;color:#4a5568;font-size:.85rem;font-weight:500;padding:2px 8px}.hosts-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto;padding-right:5px}.hosts-list::-webkit-scrollbar{width:6px}.hosts-list::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.hosts-list::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.hosts-list::-webkit-scrollbar-thumb:hover{background:#a0aec0}.host-button{background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.host-button:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.host-button.monitored{background:#f0fdf4;border-color:#10b981}.host-button.monitored:hover{background:#dcfce7;border-color:#059669;box-shadow:0 4px 12px #10b98133}.host-button.not-monitored{background:#fef2f2;border-color:#ef4444}.host-button.not-monitored:hover{background:#fee2e2;border-color:#dc2626;box-shadow:0 4px 12px #ef444433}.host-ip{color:#1e3a5f;font-family:Courier New,monospace;font-size:1rem;font-weight:700;margin-bottom:4px}.host-button.monitored .host-ip{color:#065f46}.host-button.not-monitored .host-ip{color:#991b1b}.host-rpu{color:#4a5568;font-family:Courier New,monospace;font-size:.85rem;font-weight:500;margin-bottom:2px}.host-button.monitored .host-rpu{color:#047857}.host-button.not-monitored .host-rpu{color:#b91c1c}.host-desc{color:#718096;font-size:.85rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hosts-empty,.hosts-loading{background:#f7fafc;border:1px dashed #cbd5e0;border-radius:8px;color:#718096;font-size:.9rem;padding:20px;text-align:center}.copy-notification{animation:slideIn .3s ease;border-radius:8px;box-shadow:0 4px 12px #00000026;font-size:.9rem;font-weight:500;padding:12px 20px;position:fixed;right:20px;top:20px;z-index:1000}.copy-notification.success{background:#10b981;color:#fff}.copy-notification.error{background:#ef4444;color:#fff}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.hosts-lista-container{gap:20px;grid-template-columns:1fr}}.estado-item{align-items:center;display:flex;gap:10px}.estado-label{color:#4a5568;font-weight:500}.estado-value{color:#1e3a5f;font-size:1.1rem;font-weight:700}@media (max-width:1200px){.flujos-grid{grid-template-columns:1fr}}@media (max-width:768px){.vista-general-container{padding:15px}.flujos-grid,.vista-general-resumen{grid-template-columns:1fr}.flujo-section{padding:20px}.fecha-boxes,.rt-status-cards,.status-cards{grid-template-columns:1fr}}.cache-status-section{background:linear-gradient(135deg,#1a365d,#2d3748);border-radius:12px;color:#fff;margin-top:25px;padding:25px}.cache-status-header{align-items:center;border-bottom:1px solid #fff3;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.cache-status-header h2{align-items:center;display:flex;font-size:1.3rem;font-weight:600;gap:10px;margin:0}.cache-status-header h2:before{content:"💾"}.cache-loading{animation:pulse 1.5s infinite;color:#ffffffb3;font-size:.85rem}.cache-status-content{display:flex;flex-direction:column;gap:20px}.cache-summary{display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between}.cache-stat{background:#ffffff1a;border-radius:10px;flex:1 1;min-width:100px;padding:15px 20px;text-align:center}.cache-stat-value{color:#68d391;display:block;font-size:1.8rem;font-weight:700;margin-bottom:5px}.cache-stat-label{color:#fffc;font-size:.85rem}.cache-endpoints{background:#0003;border-radius:10px;padding:20px}.cache-endpoints h3{align-items:center;display:flex;font-size:1rem;font-weight:600;gap:10px;margin:0 0 15px}.cache-missing-badge{background:#fc8181;border-radius:12px;color:#742a2a;font-size:.75rem;font-weight:600;padding:3px 10px}.cache-endpoints-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.cache-endpoint-item{align-items:center;border-radius:8px;display:flex;font-size:.85rem;gap:8px;padding:10px 12px;transition:all .2s ease}.cache-endpoint-item.cached{background:#48bb7833;border:1px solid #48bb7866}.cache-endpoint-item.missing{background:#fc818133;border:1px solid #fc818166}.cache-endpoint-icon{font-size:1rem}.cache-endpoint-name{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cache-endpoint-ttl{background:#0003;border-radius:10px;color:#fff9;font-size:.75rem;padding:2px 8px}.cache-fechas{border-top:1px solid #ffffff1a;color:#ffffffb3;font-size:.85rem;padding-top:10px;text-align:center}.cache-status-empty{color:#fff9;padding:30px;text-align:center}@media (max-width:768px){.cache-summary{flex-direction:column}.cache-stat{min-width:auto}.cache-endpoints-grid{grid-template-columns:1fr}}.gestion-sitios-container .icon-svg,.gestion-sitios-container img[src*=".svg"]{stroke:currentColor;fill:none}.gestion-sitios-container{background:#f5f5f5;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.gestion-sitios-header{display:none;margin:0;padding:0}.gestion-sitios-title-section{margin-bottom:1vw}.gestion-sitios-title{color:#414141;font-size:24px;font-weight:600;margin:0 0 .5vw}.gestion-sitios-subtitle{color:#727272;font-size:14px;margin:0}.gestion-sitios-tabs{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:0;margin:0;padding:0 10%}.gestion-sitios-tab{background:#0000;border:none;border-bottom:3px solid #0000;bottom:-1px;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:15px 24px;position:relative;transition:all .15s ease;white-space:nowrap}.gestion-sitios-tab.active,.gestion-sitios-tab:hover{background:#f9fafb;color:#414141}.gestion-sitios-tab.active{border-bottom-color:#ffd414;font-weight:600}.gestion-sitios-content{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a;margin:24px 10%;padding:2vw}.gestion-sitios-metrics{grid-gap:1.5vw;display:grid;gap:1.5vw;grid-template-columns:repeat(4,1fr);margin-bottom:2vw}.gestion-sitios-metric-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;padding:1.5vw;position:relative;text-align:center}.metric-icon{stroke:#4a5568;color:#4a5568;height:32px;margin-bottom:.8vw;opacity:.7;width:32px}.metric-value{margin-bottom:.5vw}.metric-label{font-size:14px}.metric-percentage{color:#a0aec0;font-size:.85rem;margin-top:.3vw}.gestion-sitios-actions-top{display:flex;gap:1vw;justify-content:flex-end;margin-bottom:2vw}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5vw;padding:.6vw 1.2vw;transition:all .2s ease}.action-btn-postgres{background:#15803d;color:#fff}.action-btn-postgres:hover{background:#166534}.action-btn-refresh{background:#ffd414;color:#414141}.action-btn-refresh:hover{background:#e6bf12}.action-btn-upload{background:#15803d;color:#fff}.action-btn-upload:hover{background:#166534}.btn-icon{stroke:currentColor;color:currentColor;flex-shrink:0;height:16px;width:16px}.btn-icon.spinning{animation:spin 1s linear infinite}.gestion-sitios-search-section{margin-bottom:1.5vw}.search-container{align-items:center;display:flex;gap:.5vw;margin-bottom:.8vw;position:relative}.search-container .search-icon{color:#718096;left:1vw;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);z-index:1}.search-input{border:1px solid #e2e8f0;color:#2d3748;flex:1 1;font-size:.9rem;padding:.8vw 1vw .8vw 2.5vw}.search-input:focus{border-color:#ffd414;box-shadow:0 0 0 3px #ffd41433;outline:none}.filter-btn{background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;padding:.8vw 1vw;transition:all .2s ease}.filter-btn:hover{background:#edf2f7;border-color:#cbd5e0}.filter-icon{color:#718096;font-size:1rem}.records-info{color:#718096;font-size:.85rem;margin-top:.5vw}.gestion-sitios-actions-table{display:flex;gap:1vw;justify-content:flex-end;margin-bottom:1.5vw}.action-btn-save{background:#15803d;border:1px solid #15803d;color:#fff}.action-btn-save:hover:not(:disabled){background:#166534;border-color:#166534}.action-btn-save:disabled{background:#15803d;cursor:not-allowed;opacity:.7}.action-btn-export{background:#ffd414;color:#414141}.action-btn-export:hover{background:#e6bf12}.gestion-sitios-table-container{border:1px solid #e2e8f0;border-radius:6px;overflow-x:auto}.gestion-sitios-table{background:#fff;border-collapse:collapse;width:100%}.gestion-sitios-table thead{background:#f7fafc}.gestion-sitios-table th{border-bottom:2px solid #e2e8f0;color:#4a5568;font-size:.85rem;font-weight:600;padding:1vw;text-align:left;white-space:nowrap}.table-header-content{align-items:center;display:flex;gap:.5vw;margin-bottom:.5vw}.sort-icon{color:#a0aec0;cursor:pointer;font-size:.7rem}.table-filter-input{border:1px solid #e2e8f0;border-radius:4px;color:#2d3748;font-size:.8rem;padding:.4vw .6vw;width:100%}.table-filter-input:focus{border-color:#2c5282;outline:none}.gestion-sitios-table tbody tr{border-bottom:1px solid #edf2f7}.gestion-sitios-table tbody tr:hover{background:#f7fafc}.gestion-sitios-table td{color:#2d3748;font-size:.9rem;padding:.5vw}.table-cell-input{background:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#2d3748;font-size:.85rem;min-width:100px;padding:.5vw;width:100%}.table-cell-input:focus{border-color:#2c5282;box-shadow:0 0 0 2px #2c52821a;outline:none}.table-cell-input:hover{border-color:#cbd5e0}.table-cell-checkbox{cursor:pointer;display:block;height:18px;margin:0 auto;width:18px}.table-cell-select{background:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#2d3748;cursor:pointer;font-size:.85rem;min-width:120px;padding:.5vw;width:100%}.table-cell-select:focus{border-color:#2c5282;box-shadow:0 0 0 2px #2c52821a;outline:none}.table-cell-select:hover{border-color:#cbd5e0}.no-rows-message{color:#a0aec0;font-style:italic;padding:3vw!important;text-align:center}.proyectos-section{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:2vw;margin-top:2vw;padding:1.5vw}.proyectos-title{border-bottom:2px solid #ffd414;color:#414141;font-size:18px;font-weight:600;margin:0 0 1.5vw;padding-bottom:.5vw}.loading-message,.no-proyectos-message{color:#718096;font-style:italic;padding:2vw;text-align:center}.proyectos-table{border-collapse:collapse;margin-top:1vw;width:100%}.proyectos-table th{background:#edf2f7;border-bottom:2px solid #cbd5e0;color:#2d3748;font-size:.9rem;font-weight:600;padding:1vw;text-align:left}.proyectos-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:.9rem;padding:.8vw}.proyectos-table tbody tr:hover{background:#f7fafc}.btn-delete{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:.5vw 1vw;transition:all .15s ease}.btn-delete:hover{background:#b91c1c}.action-btn-add{background:#15803d;color:#fff}.action-btn-add:hover{background:#166534}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 10px 25px #0003;max-height:90vh;max-width:600px;overflow-y:auto;padding:2vw;width:90%}.modal-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:1.5vw;padding-bottom:1vw}.modal-header h2{color:#1e3a5f;font-size:1.5rem;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:2rem;height:30px;justify-content:center;padding:0;transition:background .2s;width:30px}.modal-close:hover{background:#edf2f7}.proyecto-form{gap:1.2vw}.form-group,.proyecto-form{display:flex;flex-direction:column}.form-group{gap:.5vw}.form-group label{color:#2d3748;font-size:.9rem;font-weight:600}.form-group input[type=number],.form-group input[type=text]{border:1px solid #e2e8f0;border-radius:4px;color:#2d3748;font-size:.9rem;padding:.8vw}.form-group input[type=number]:focus,.form-group input[type=text]:focus{border-color:#2c5282;box-shadow:0 0 0 3px #2c52821a;outline:none}.form-group input[type=checkbox]{cursor:pointer;height:18px;margin-right:.5vw;width:18px}.form-group label:has(input[type=checkbox]){align-items:center;display:flex;flex-direction:row}.form-actions{border-top:1px solid #e2e8f0;display:flex;gap:1vw;justify-content:flex-end;margin-top:1vw;padding-top:1vw}.btn-cancel{background:#e2e8f0;border:none;border-radius:4px;color:#2d3748;cursor:pointer;font-size:.9rem;font-weight:600;padding:.8vw 1.5vw;transition:background .2s}.btn-cancel:hover{background:#cbd5e0}.btn-submit{background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;font-size:14px;font-weight:600;padding:.8vw 1.5vw;transition:all .15s ease}.btn-submit:hover{background:#e6bf12}@media (max-width:768px){.gestion-sitios-metrics{grid-template-columns:1fr}.gestion-sitios-actions-top{flex-direction:column}.gestion-sitios-table-container{overflow-x:scroll}.modal-content{padding:4vw;width:95%}.proyectos-table{font-size:.8rem}.proyectos-table td,.proyectos-table th{padding:.5vw}}.notification-bottom{animation:slideInUp .3s ease-out;border-radius:8px;bottom:20px;box-shadow:0 4px 6px #0000001a;font-size:14px;font-weight:500;max-width:400px;padding:15px 20px;position:fixed;right:20px;z-index:10000}.notification-success{background-color:#15803d;color:#fff}.notification-error{background-color:#dc2626;color:#fff}@keyframes slideInUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.action-icon,.percentage-icon,.section-icon,.status-icon-inline,.status-icon-small,.table-icon,.warning-icon-small{stroke:currentColor;color:currentColor;display:inline-block;flex-shrink:0;height:16px;margin-right:4px;vertical-align:middle;width:16px}.section-icon{height:20px;margin-right:8px;width:20px}.modal-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:0;margin-bottom:20px}.modal-tabs button{background:#f7fafc;border:none;border-bottom:3px solid #0000;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:12px 20px;transition:all .15s ease}.modal-tabs button:hover{background:#edf2f7;color:#414141}.modal-tabs button.active{background:#fff;border-bottom-color:#ffd414;color:#414141;font-weight:600}.rpus-modal-list{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;max-height:200px;overflow-y:auto}.rpus-modal-list-item{border-bottom:1px solid #e2e8f0;cursor:pointer;padding:10px 15px;transition:background-color .15s}.rpus-modal-list-item:hover{background-color:#edf2f7}.rpus-modal-list-item.selected{background-color:#d1f2eb}.rpus-modal-list-item .rpu-number{color:#1e3a5f;font-weight:600}.rpus-modal-list-item .rpu-nombre{color:#718096;font-size:13px;margin-left:10px}.filtro-proyecto{align-items:center;background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:12px;margin-bottom:15px;padding:12px}.filtro-proyecto label{color:#2d3748;font-weight:600;white-space:nowrap}.filtro-proyecto select{background-color:#fff;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;flex:1 1;font-size:14px;max-width:300px;padding:8px 12px}.filtro-proyecto select:focus{border-color:#ffd414;box-shadow:0 0 0 3px #ffd41433;outline:none}.filtro-proyecto .btn-limpiar{background-color:#e2e8f0;border:none;border-radius:4px;color:#4a5568;cursor:pointer;font-size:13px;padding:6px 12px;transition:all .15s ease}.filtro-proyecto .btn-limpiar:hover{background-color:#cbd5e0}.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}.mapa-comunicacion-container{background-color:#f7fafc;display:flex;flex-direction:column;height:calc(100vh - 100px);position:relative;width:100%}.mapa-container{flex:1 1}.mapa-container,.mapa-map{height:100%;position:relative;width:100%}.mapa-map{z-index:1}.toggle-panel-btn{align-items:center;background-color:#fff;border:2px solid #e2e8f0;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#2d3748;cursor:pointer;display:flex;font-size:20px;height:50px;justify-content:center;position:absolute;transition:all .3s ease;width:50px;z-index:1003}.toggle-panel-btn:hover{background-color:#f7fafc;border-color:#2d3748;box-shadow:0 4px 12px #0003;transform:scale(1.1)}.filtros-toggle{left:20px;top:20px}.rpu-list-toggle{right:20px;top:20px}.search-toggle{right:20px;top:80px}.badge-count{align-items:center;background-color:#e53e3e;border-radius:50%;color:#fff;display:flex;font-size:11px;font-weight:600;height:20px;justify-content:center;position:absolute;right:-5px;top:-5px;width:20px}.filtros-panel{background-color:#fff;box-shadow:2px 0 8px #00000026;display:none;flex-direction:column;height:100%;left:0;position:absolute;top:0;transform:translateX(-100%);transition:transform .3s ease;width:320px;z-index:998}.filtros-panel.open{display:flex;transform:translateX(0)}.panel-header{align-items:center;background-color:#f7fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.panel-header h3{color:#2d3748;font-size:18px;font-weight:600;letter-spacing:.3px;margin:0}.close-panel-btn{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:20px;height:30px;justify-content:center;padding:0;transition:all .2s;width:30px}.close-panel-btn:hover{background-color:#e2e8f0;color:#2d3748}.panel-content{flex:1 1;overflow-y:auto;padding:20px}.rpu-search-container{margin-bottom:15px;position:relative}.rpu-search-input{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;box-sizing:border-box;color:#2d3748;font-size:14px;padding:10px 35px 10px 12px;transition:border-color .2s;width:100%}.rpu-search-input:focus{border-color:#2d3748;box-shadow:0 0 0 3px #1e3a5f1a;outline:none}.rpu-search-input::placeholder{color:#a0aec0}.rpu-search-clear{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:16px;height:24px;justify-content:center;padding:4px;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all .2s;width:24px}.rpu-search-clear:hover{background-color:#e2e8f0;color:#2d3748}.filtros-panel h3{border-bottom:2px solid #1e3a5f;color:#1e3a5f;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:10px}.filtro-group{margin-bottom:20px}.filtro-group label{color:#4a5568;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.filtro-group select{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#2d3748;cursor:pointer;font-size:14px;padding:10px;transition:border-color .2s;width:100%}.filtro-group select:hover{border-color:#1e3a5f}.filtro-group select:focus{border-color:#1e3a5f;box-shadow:0 0 0 3px #1e3a5f1a;outline:none}.limpiar-filtros{background-color:#e2e8f0;border:none;border-radius:6px;color:#2d3748;cursor:pointer;font-size:14px;font-weight:500;margin-top:10px;padding:10px;transition:background-color .2s;width:100%}.limpiar-filtros:hover{background-color:#cbd5e0}.rpu-list-panel{background-color:#fff;box-shadow:-2px 0 8px #00000026;display:none;flex-direction:column;height:100%;position:absolute;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:350px;z-index:997}.rpu-list-panel.open{display:flex;transform:translateX(0)}.close-panel-btn-fixed{align-items:center;background-color:#fff;border:2px solid #e2e8f0;border-radius:50%;box-shadow:0 2px 8px #00000026;color:#2d3748;cursor:pointer;display:flex;font-size:18px;height:40px;justify-content:center;position:absolute;transition:all .3s ease;width:40px;z-index:1001}.close-panel-btn-fixed:hover{background-color:#f7fafc;border-color:#2d3748;box-shadow:0 4px 12px #0003;transform:scale(1.1)}.filtros-close-fixed{left:330px;top:20px;z-index:1002}.rpu-close-fixed{right:360px;top:20px;z-index:1002}.search-close-fixed{right:360px;top:80px;z-index:1002}.search-panel{background-color:#fff;box-shadow:-2px 0 8px #00000026;display:none;flex-direction:column;height:100%;position:absolute;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:350px;z-index:996}.search-panel.open{display:flex;transform:translateX(0)}.navegacion-controls-compass{grid-gap:8px;align-items:center;bottom:30px;display:grid;gap:8px;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);height:200px;justify-items:center;position:absolute;right:30px;width:200px;z-index:1000}.nav-btn-compass{align-items:center;background-color:#fff;border:2px solid #e2e8f0;border-radius:50%;box-shadow:0 2px 8px #00000026;cursor:pointer;display:flex;flex-direction:column;height:60px;justify-content:center;position:relative;transition:all .3s ease;width:60px}.nav-btn-compass:hover{background-color:#f7fafc;border-color:#2d3748;box-shadow:0 4px 12px #00000040;transform:scale(1.15)}.nav-btn-compass:active{transform:scale(.95)}.nav-norte{grid-column:2;grid-row:1}.nav-este{grid-column:3;grid-row:2}.nav-centro{background:linear-gradient(135deg,#4a5568,#718096);border-color:#4a5568;color:#fff;grid-column:2;grid-row:2;height:70px;width:70px}.nav-centro:hover{background:linear-gradient(135deg,#718096,#4a5568)}.nav-sur{grid-column:2;grid-row:3}.nav-oeste{grid-column:1;grid-row:2}.nav-letter{color:#2d3748;font-size:20px;font-weight:700}.nav-letter,.nav-letter-center{line-height:1;margin-bottom:2px}.nav-letter-center{font-size:24px}.nav-coords-compass{color:#718096;font-size:8px;font-weight:500;letter-spacing:.3px}.nav-coords-compass-center{color:#ffffffe6;font-size:9px;font-weight:500;letter-spacing:.3px}.nav-btn-compass:hover .nav-letter{color:#1e3a5f}.nav-btn-compass:hover .nav-coords-compass{color:#4a5568}.rpu-list{flex:1 1;overflow-y:auto;padding:8px}.rpu-list-empty{color:#718096;font-size:14px;padding:20px;text-align:center}.rpu-list-item{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;margin-bottom:6px;padding:10px 12px;transition:all .2s}.rpu-list-item:hover{background-color:#f7fafc;border-color:#cbd5e0;transform:translateX(2px)}.rpu-list-item.selected{background-color:#edf2f7;border-color:#2d3748;border-left:3px solid #2d3748}.rpu-item-main{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.rpu-item-rpu{color:#2d3748;font-size:14px;font-weight:600}.rpu-item-proyecto{color:#718096;font-size:12px;font-weight:400}.rpu-item-detail{color:#a0aec0;font-size:11px;margin-top:2px}.multiple-rpus-panel{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;bottom:30px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;left:50%;max-height:400px;overflow:hidden;position:absolute;transform:translateX(-50%);width:400px;z-index:1002}.multiple-rpus-header{align-items:center;background-color:#f7fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:15px 20px}.multiple-rpus-header h4{color:#2d3748;font-size:15px;font-weight:600;letter-spacing:.3px;margin:0}.multiple-rpus-list{max-height:320px;overflow-y:auto;padding:10px}.multiple-rpu-item{background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;margin-bottom:6px;padding:10px 12px;transition:all .2s}.multiple-rpu-item:hover{background-color:#f7fafc;border-color:#cbd5e0;transform:translateX(2px)}.multiple-rpu-main{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.multiple-rpu-rpu{color:#2d3748;font-size:14px;font-weight:600}.multiple-rpu-proyecto{color:#718096;font-size:12px;font-weight:400}.multiple-rpu-detail{color:#a0aec0;font-size:11px;margin-top:2px}.selected-feature-panel{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;bottom:30px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;left:50%;max-height:300px;overflow:hidden;position:absolute;transform:translateX(-50%);width:400px;z-index:1001}.selected-feature-header{align-items:center;background-color:#f7fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:15px 20px}.selected-feature-header h4{color:#2d3748;font-size:15px;font-weight:600;letter-spacing:.3px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;padding:0;transition:all .2s;width:24px}.close-btn:hover{background-color:#e2e8f0;color:#2d3748}.feature-details{display:flex;flex-direction:column;gap:10px;max-height:200px;overflow-y:auto;padding:15px 20px}.feature-detail-row{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:8px 0}.feature-detail-row:last-child{border-bottom:none}.feature-label{color:#718096;font-size:12px;font-weight:500;letter-spacing:.5px;min-width:100px;text-transform:uppercase}.feature-value{color:#2d3748;flex:1 1;font-size:13px;font-weight:400;text-align:right}.loading-spinner{align-items:center;animation:none!important;background:#fff;color:#2d3748;display:flex;flex-direction:column;height:100%;justify-content:center;overflow:hidden;position:relative;transform:none!important}.loading-spinner:before{animation:shimmer 2s ease-in-out infinite;background:linear-gradient(90deg,#0000,#00000005 50%,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0;transform:none!important}.loading-spinner-content{animation:none!important;position:relative;text-align:center;transform:none!important;z-index:1}.loading-spinner-spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#4a5568;height:50px;margin:0 auto 24px;position:relative;transform-origin:center center;width:50px}.loading-spinner-text{color:#2d3748;font-size:16px;font-weight:500;letter-spacing:.3px;margin-bottom:8px}.loading-spinner-subtext{color:#718096;font-size:13px;font-weight:400;letter-spacing:.2px}.error-message{align-items:center;background:#fff;border:1px solid #e2e8f0;display:flex;flex-direction:column;height:100%;justify-content:center;padding:40px;text-align:center}.error-message h3{color:#2d3748;font-size:20px;font-weight:600;letter-spacing:.3px;margin:0 0 12px}.error-message p{color:#4a5568;font-size:14px;font-weight:400;line-height:1.6;margin:0}.filtros-panel::-webkit-scrollbar,.info-panel::-webkit-scrollbar{width:8px}.filtros-panel::-webkit-scrollbar-track,.info-panel::-webkit-scrollbar-track{background:#f1f1f1}.filtros-panel::-webkit-scrollbar-thumb,.info-panel::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}.filtros-panel::-webkit-scrollbar-thumb:hover,.info-panel::-webkit-scrollbar-thumb:hover{background:#a0aec0}.integracion-container{background:#f5f5f5;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.integracion-loading{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 70px);padding:2rem;text-align:center}.integracion-loading .loading-spinner{animation:integracion-spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#ffd414;height:50px;margin-bottom:1rem;width:50px}@keyframes integracion-spin{to{transform:rotate(1turn)}}.integracion-loading .loading-text{color:#727272;font-size:14px;margin:0}.integracion-content{padding:0}.integracion-tabs{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:0;margin:0;padding:0 10%}.integracion-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:15px 24px;transition:all .15s ease}.integracion-tab.active,.integracion-tab:hover{background:#f9fafb;color:#414141}.integracion-tab.active{border-bottom-color:#ffd414;font-weight:600}.integracion-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px;padding:24px 10% 0}.header-title h1{color:#414141;font-size:24px;font-weight:600;margin:0}.header-title p{color:#727272;font-size:14px;margin:4px 0 0}.header-actions{gap:12px}.db-status,.header-actions{align-items:center;display:flex}.db-status{border-radius:6px;font-size:11.9px;font-weight:500;gap:6px;padding:8px 12px}.db-status.active{background:#f0fdf4;color:#15803d}.db-status.inactive{background:#fef2f2;color:#dc2626}.db-icon{font-size:10px}.refresh-btn img{filter:brightness(0) saturate(100%) invert(23%) sepia(0) saturate(0) hue-rotate(180deg) brightness(95%) contrast(90%);transition:transform .3s ease}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(5,1fr);margin-bottom:24px;padding:0 10%}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;position:relative;transition:all .15s ease}.stat-card:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.stat-label{color:#727272;font-size:11.9px;margin-bottom:8px}.stat-value{color:#414141;font-size:30px;font-weight:700}.stat-value.online{color:#15803d}.stat-value.offline{color:#dc2626}.stat-icon{height:24px;opacity:.3;position:absolute;right:16px;top:16px;width:24px}.systems-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:24px;padding:0 10%}.system-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .15s ease}.system-card:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.system-card-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.system-card-title{align-items:center;color:#414141;display:flex;font-size:16px;font-weight:600;gap:10px}.system-card-icon{height:22px;opacity:.7;width:22px}.system-card-status{align-items:center;border-radius:9999px;display:flex;font-size:11.9px;font-weight:500;gap:6px;padding:4px 10px}.system-card-status.connected{background:#f0fdf4;color:#15803d}.system-card-status.error{background:#fef2f2;color:#dc2626}.system-card-status.warning{background:#fefce8;color:#ca8a04}.system-card-status.checking{background:#e5e7eb;color:#727272}.system-card-body{margin-bottom:12px}.system-card-row{align-items:center;color:#4a5568;display:flex;font-size:.9rem;justify-content:space-between;padding:8px 0}.system-card-row strong{color:#1e3a5f}.system-card-link{align-items:center;color:#3182ce;display:inline-flex;font-size:.85rem;gap:4px;text-decoration:none}.system-card-link:hover{text-decoration:underline}.info-note{background:#dbeafe;border:1px solid #93c5fd;border-radius:8px;color:#2563eb;font-size:14px;margin:0 10%;padding:16px 20px}.info-note strong{color:#2c5282}.loading-container{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:400px}.spinner{animation:spin 1s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top-color:#1e3a5f;height:40px;width:40px}.stat-card-online{background:#f0fdf4;border-color:#86efac}.stat-card-offline{background:#fef2f2;border-color:#fca5a5}.stat-card-unreachable{background:#fffbeb;border-color:#fcd34d}.stat-card-unknown{background:#f9fafb;border-color:#d1d5db}.stat-value.unreachable{color:#d97706}.stat-value.unknown{color:#6b7280}.rt-tickets-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin:24px 10% 0;overflow:hidden}.rt-tickets-table{border-collapse:collapse;width:100%}.rt-tickets-table thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}.rt-tickets-table th{color:#4a5568;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:16px 20px;text-align:left;text-transform:uppercase}.rt-tickets-table tbody tr{border-bottom:1px solid #e2e8f0;transition:background-color .2s ease}.rt-tickets-table tbody tr:hover{background-color:#f7fafc}.rt-tickets-table tbody tr:last-child{border-bottom:none}.rt-tickets-table td{color:#2d3748;font-size:.9rem;padding:16px 20px}.rt-tickets-empty{color:#718096;font-style:italic;padding:40px 20px!important;text-align:center}.rt-status-badge{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:500;padding:4px 12px;text-transform:capitalize}.rt-status-nuevo{background:#dbeafe;color:#1e40af}.rt-status-abierto{background:#fef3c7;color:#92400e}.rt-status-cerrado,.rt-status-resuelto{background:#d1fae5;color:#065f46}.rt-status-rechazado{background:#fee2e2;color:#991b1b}.rt-status-badge:not([class*=rt-status-]){background:#e2e8f0;color:#4a5568}@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(3,1fr)}.systems-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.integracion-content{padding:16px 20px}.integracion-tabs{overflow-x:auto}.integracion-header{flex-direction:column;gap:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.systems-grid{grid-template-columns:1fr}.rt-tickets-table-container{overflow-x:auto}.rt-tickets-table{min-width:600px}.rt-tickets-table td,.rt-tickets-table th{font-size:.85rem;padding:12px 16px}}.odoo-search-input-wrapper{flex:1 1;position:relative}.odoo-search-input-wrapper .search-icon{height:20px;left:12px;opacity:.5;position:absolute;top:50%;transform:translateY(-50%);width:20px}.odoo-search-input{padding:12px 12px 12px 44px}.odoo-export-btn{margin-left:auto}.odoo-export-btn:hover{background:#38a169}.odoo-download-btn{border:none;border-radius:4px;cursor:pointer;padding:6px 10px;transition:background .2s}.odoo-download-btn:disabled{background:#cbd5e0;cursor:not-allowed}.odoo-download-btn img{filter:brightness(0) invert(1);height:16px;width:16px}@media (max-width:768px){.odoo-stats-grid{grid-template-columns:repeat(2,1fr);margin:0 5% 20px}.odoo-search-section{margin:0 5% 20px}.odoo-empty-state,.odoo-end-list,.odoo-loading,.odoo-loading-more,.odoo-results-header,.odoo-table-container{margin:0 5%}.odoo-stat-value{font-size:22px}.odoo-stat-card.stat-debt .odoo-stat-value{font-size:18px}}.odoo-check-container{margin:40px auto;max-width:600px}.odoo-check-loading{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.odoo-check-loading img{height:50px;margin-bottom:16px;width:50px}.odoo-check-result{align-items:flex-start;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;gap:20px;padding:30px}.odoo-check-result.success{border-left:4px solid #48bb78}.odoo-check-result.error{border-left:4px solid #e53e3e}.odoo-check-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:32px;height:60px;justify-content:center;width:60px}.odoo-check-result.success .odoo-check-icon{background:#c6f6d5;color:#276749}.odoo-check-result.error .odoo-check-icon{background:#fed7d7;color:#c53030}.odoo-check-info h3{color:#2d3748;font-size:20px;margin:0 0 8px}.odoo-check-info p{color:#718096;font-size:14px;margin:0 0 12px}.odoo-check-details{background:#f7fafc;border-radius:6px;margin-bottom:12px;padding:12px}.odoo-check-details p{font-size:13px;margin:4px 0}.odoo-check-timestamp{color:#a0aec0!important;font-size:12px!important;font-style:italic}@media (max-width:768px){.odoo-filters-row,.odoo-search-row{flex-direction:column}.odoo-filters-row{align-items:stretch}.odoo-export-btn{justify-content:center;margin-left:0}.odoo-table-container{max-height:50vh}.odoo-check-result{align-items:center;flex-direction:column;text-align:center}}.analisis-avanzado-container{background:#f5f5f5;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.date-filter-section{border-bottom:1px solid #e2e8f0;margin-bottom:30px;padding-bottom:20px}.date-range-selector{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:8px 16px;width:-webkit-fit-content;width:fit-content}.date-range-selector img{height:16px;opacity:.6;width:16px}.date-range-selector select{background:#0000;border:none;color:#2d3748;cursor:pointer;font-size:.9rem;outline:none}.refresh-btn{font-weight:500;padding:10px 16px}.refresh-btn:hover:not(:disabled){background:#e6bf12}.refresh-btn:disabled{cursor:not-allowed;opacity:.6}.refresh-btn img{height:16px;width:16px}.refresh-btn img.spinning{animation:spin 1s linear infinite}.refresh-btn-tabs{align-items:center;background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;margin-left:20px;padding:10px 16px;transition:all .15s ease}.refresh-btn-tabs:hover:not(:disabled){background:#e6bf12}.refresh-btn-tabs:disabled{cursor:not-allowed;opacity:.6}.refresh-btn-tabs img{height:16px;width:16px}.refresh-btn-tabs img.spinning{animation:spin 1s linear infinite}.analisis-tabs-container{align-items:center;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:0;padding:0 10%}.analisis-tabs{display:flex;flex:1 1;gap:0}.analisis-tab{background:#0000;border:none;border-bottom:3px solid #0000;bottom:-1px;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:15px 24px;position:relative;transition:all .15s ease}.analisis-tab.active,.analisis-tab:hover{background:#f9fafb;color:#414141}.analisis-tab.active{border-bottom-color:#ffd414;font-weight:600}.analisis-content{min-height:400px;padding:40px 10%}.tab-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.summary-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:30px}.summary-card{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:12px;display:flex;gap:15px;padding:20px;transition:box-shadow .2s}.summary-card:hover{box-shadow:0 4px 12px #0000001a}.card-icon{align-items:center;background:#f7fafc;border-radius:8px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.card-icon img{height:24px;opacity:.6;width:24px}.card-content{flex:1 1}.card-label{color:#718096;font-size:.85rem;font-weight:500;margin-bottom:8px}.card-value{color:#414141;font-size:24px;font-weight:700;margin-bottom:4px}.card-trend{align-items:center;display:flex;font-size:.85rem;font-weight:500;gap:4px}.charts-section{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-top:30px}.chart-container{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;display:flex;flex-direction:column;min-height:300px;padding:20px}.chart-wrapper{flex:1 1;min-height:250px;position:relative}.chart-container h3{color:#414141;font-size:16px;font-weight:600;margin:0 0 20px}.no-data{align-items:center;color:#a0aec0;display:flex;flex-direction:column;justify-content:center;min-height:250px}.no-data img{height:48px;margin-bottom:12px;opacity:.4;width:48px}.no-data p{font-size:.9rem;margin:0}.chart-placeholder{color:#718096;padding:20px;text-align:center}.chart-note{color:#a0aec0;font-size:.85rem;margin-top:10px}.predictive-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr)}.predictive-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.predictive-card h3{color:#414141;font-size:16px;font-weight:600;margin:0 0 20px}.projection-value{color:#414141;font-size:36px;font-weight:700;margin-bottom:8px}.projection-label{color:#718096;font-size:.9rem;margin-bottom:12px}.confidence{color:#15803d;font-size:11.9px;font-weight:500}.risk-badge{border-radius:8px;display:inline-block;font-size:1.2rem;font-weight:600;margin-bottom:12px;padding:8px 16px}.risk-badge.critical,.risk-badge.high{background:#fef2f2;color:#dc2626}.risk-badge.medium{background:#fefce8;color:#ca8a04}.risk-badge.low{background:#f0fdf4;color:#15803d}.risk-timeframe{color:#718096;font-size:.9rem;margin-bottom:16px}.risk-details{color:#4a5568;display:flex;flex-direction:column;font-size:.9rem;gap:8px}.efficiency-value{color:#15803d;font-size:30px;font-weight:700;margin-bottom:16px}.recommendations{list-style:none;margin:0;padding:0}.recommendations li{border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:.9rem;padding:8px 0}.recommendations li:last-child{border-bottom:none}.recommendations li:before{color:#ffd414;content:"•";font-weight:700;margin-right:8px}@media (max-width:1200px){.summary-cards{grid-template-columns:repeat(2,1fr)}.charts-section,.predictive-content{grid-template-columns:1fr}}@media (max-width:768px){.analisis-header{align-items:flex-start;flex-direction:column;gap:15px}.header-controls{justify-content:space-between;width:100%}.analisis-tabs{flex-wrap:wrap;justify-content:center;padding:0 5%}.analisis-tab{font-size:.9rem;min-width:100px;padding:10px 16px}.analisis-content{margin:20px 5%;padding:20px}.summary-cards{grid-template-columns:1fr}}.monitoreo-container{background:#f5f5f5;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:calc(100vh - 100px);padding:0}.monitoreo-submenu{background-color:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:0;margin-bottom:0;padding:0 10%}.submenu-item{background:#0000;border:none;border-bottom:3px solid #0000;bottom:-1px;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:15px 24px;position:relative;transition:all .15s ease}.submenu-item.active,.submenu-item:hover{background:#f9fafb;color:#414141}.submenu-item.active{border-bottom-color:#ffd414;font-weight:600}.monitoreo-content{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin:24px 10%;padding:30px}.monitoreo-title{color:#414141;font-size:24px;font-weight:600;margin:0 0 8px}.monitoreo-subtitle{color:#727272;font-size:14px;margin:0 0 30px}.monitoreo-filters{align-items:flex-end;background-color:#f7fafc;border-radius:8px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:30px;padding:20px}.filter-group{gap:8px}.filter-label{color:#4a5568;font-size:12px;font-weight:600;text-transform:uppercase}.date-range{align-items:center;display:flex;gap:12px}.date-input-wrapper{align-items:center;display:flex;position:relative}.calendar-icon{stroke:#718096;color:#718096;height:16px;left:10px;pointer-events:none;position:absolute;width:16px;z-index:1}.date-input{border:1px solid #cbd5e0;border-radius:6px;color:#2d3748;font-size:14px;padding:8px 12px 8px 36px}.date-arrow-icon{stroke:#718096;color:#718096;flex-shrink:0;height:20px;width:20px}.quick-dates{display:flex;flex-wrap:wrap;gap:8px}.quick-date-btn{background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#727272;cursor:pointer;font-size:11.9px;padding:8px 16px;transition:all .15s ease}.quick-date-btn:hover{background-color:#f9fafb;border-color:#ffd414;color:#414141}.quick-date-btn.active{background:#ffd414;border-color:#ffd414;color:#414141;font-weight:600}.select-wrapper{min-width:200px;position:relative}.filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-color:#fff;border:1px solid #cbd5e0;border-radius:6px;color:#2d3748;cursor:pointer;font-size:14px;padding:8px 36px 8px 12px;width:100%}.select-chevron{stroke:#718096;color:#718096;height:16px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:16px}.filter-actions{align-items:center;gap:15px;margin-left:auto}.auto-refresh-label{color:#4a5568}.auto-refresh-label,.refresh-btn{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:8px}.refresh-btn{background:#ffd414;border:none;border-radius:6px;color:#414141;font-weight:600;padding:10px 20px;transition:all .15s ease}.refresh-btn:hover{background:#e6bf12}.refresh-icon{stroke:#414141;color:#414141;height:16px;transition:transform .3s ease;width:16px}.refresh-icon.spinning{animation:spin 1s linear infinite}.updating-indicator{animation:shimmer 1.5s linear infinite;background:linear-gradient(90deg,#ffd414,#fde267,#ffd414);background-size:200% 100%;border-radius:6px;color:#414141;font-size:11.9px;font-weight:500;margin-bottom:15px;padding:8px 16px;text-align:center}.metric-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.metric-card{background-color:#fff;border:1px solid #e5e7eb;padding:20px;text-align:center;transition:all .15s ease}.metric-card:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.metric-icon{margin-bottom:10px}.icon-svg{stroke:#4a5568;color:#4a5568;flex-shrink:0;height:32px;width:32px}.icon-svg-small{stroke:#718096;color:#718096;flex-shrink:0;height:16px;width:16px}.calendar-icon svg,.date-arrow-icon svg,.empty-icon svg,.icon-svg svg,.icon-svg-small svg,.placeholder-icon svg,.refresh-icon svg,.search-icon svg,.select-chevron svg,.select-chevron-small svg,.trend-icon svg{stroke:currentColor;fill:none}.metric-value{font-size:30px;margin-bottom:8px}.metric-label{color:#727272;font-size:11.9px;margin-bottom:4px}.metric-trend{align-items:center;display:flex;font-size:12px;font-weight:600;gap:4px;margin-top:4px}.trend-icon{height:14px;width:14px}.metric-trend.up{color:#15803d}.metric-trend.up .trend-icon{stroke:#15803d;color:#15803d}.metric-trend.down{color:#dc2626}.metric-trend.down .trend-icon{stroke:#dc2626;color:#dc2626}.monitoreo-sections{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.monitoreo-section{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .15s ease}.monitoreo-section:hover{border-color:#ffd414;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.section-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.section-title{color:#414141;font-size:16px;font-weight:600;margin:0}.record-count{font-size:14px;gap:8px}.filter-icon{font-size:16px}.section-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.search-input-wrapper{align-items:center;display:flex;flex:1 1;min-width:200px;position:relative}.search-icon{color:#718096;height:16px;left:12px;width:16px;z-index:1}.search-input{border:1px solid #cbd5e0;border-radius:6px;font-size:14px;padding:8px 12px 8px 36px;width:100%}.select-wrapper-small{min-width:150px;position:relative}.filter-select-small{appearance:none;-webkit-appearance:none;-moz-appearance:none;border:1px solid #cbd5e0;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 36px 8px 12px;width:100%}.select-chevron-small{stroke:#718096;color:#718096;height:14px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:14px}.filter-input-small{border:1px solid #cbd5e0;border-radius:6px;font-size:14px;min-width:150px;padding:8px 12px}.filter-division-btn{background-color:#fff;border:1px solid #e5e7eb;border-radius:6px;color:#727272;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .15s ease}.filter-division-btn:hover{background-color:#f9fafb;border-color:#ffd414;color:#414141}.filter-division-btn.active{background:#ffd414;border-color:#ffd414;color:#414141}.donut-chart-container{align-items:center;background-color:#fff;border-radius:8px;display:flex;justify-content:center;margin:30px 0;min-height:300px;padding:20px;position:relative}.donut-chart-container canvas{max-height:300px;max-width:100%}.category-legend{background-color:#f7fafc;border-radius:8px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:15px}.legend-item{align-items:center;color:#4a5568;display:flex;flex:1 1;font-size:14px;gap:8px;min-width:150px}.legend-value{color:#2d3748;font-weight:600;margin-left:auto}.legend-dot{border-radius:50%;display:inline-block;height:12px;width:12px}.legend-dot.alta{background-color:#15803d}.legend-dot.media{background-color:#ca8a04}.legend-dot.baja{background-color:#dc2626}.category-bars{display:flex;flex-direction:column;gap:12px}.category-bar{align-items:center;background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;display:flex;height:40px;overflow:hidden;padding:0 12px;position:relative}.category-bar.alta{border-left:4px solid #15803d}.category-bar.media{border-left:4px solid #ca8a04}.category-bar.baja{border-left:4px solid #dc2626}.bar-fill{height:100%;left:0;position:absolute;top:0;transition:width .3s ease}.category-bar.alta .bar-fill{background-color:#15803d;opacity:.2}.category-bar.media .bar-fill{background-color:#ca8a04;opacity:.2}.category-bar.baja .bar-fill{background-color:#dc2626;opacity:.2}.bar-label{color:#2d3748;flex:1 1;font-weight:500}.bar-label,.bar-percentage{font-size:14px;position:relative;z-index:1}.bar-percentage{color:#4a5568;font-weight:600}.section-content{min-height:200px}.section-content.empty{align-items:center;color:#a0aec0;display:flex;font-size:14px;justify-content:center}.empty-state{padding:40px;text-align:center}.empty-icon{stroke:#a0aec0;color:#a0aec0;height:64px;margin-bottom:16px;opacity:.4;width:64px}.empty-count{color:#cbd5e0;display:block;font-size:12px;margin-top:8px}.rpu-table{border-collapse:collapse;margin-top:20px;width:100%}.rpu-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.rpu-table th{color:#414141;font-size:11.9px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.rpu-table td{border-bottom:1px solid #e5e7eb;color:#727272;font-size:14px;padding:12px 16px}.rpu-table tbody tr:hover{background-color:#f9fafb}.rpu-table tbody tr:last-child td{border-bottom:none}.category-badge,.status-badge{border-radius:9999px;display:inline-block;font-size:10px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.category-badge.alta{background-color:#f0fdf4;color:#15803d}.category-badge.media{background-color:#fefce8;color:#ca8a04}.category-badge.baja{background-color:#fef2f2;color:#dc2626}.status-badge.verde{background-color:#f0fdf4;color:#15803d}.status-badge.amarillo{background-color:#fefce8;color:#ca8a04}.status-badge.rojo{background-color:#fef2f2;color:#dc2626}.record-count{align-items:center;color:#718096;display:flex;font-size:13px;font-weight:500;gap:6px}.filter-icon{display:none}.placeholder-content{align-items:center;color:#a0aec0;display:flex;flex-direction:column;font-size:16px;gap:16px;padding:60px 20px;text-align:center}.placeholder-icon{stroke:#a0aec0;color:#a0aec0;height:48px;opacity:.5;width:48px}.tendencia-charts{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:30px}.chart-panel{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:20px}.chart-container{height:300px;margin-top:20px;position:relative}.chart-empty,.chart-loading{align-items:center;color:#718096;display:flex;font-size:14px;justify-content:center;min-height:300px}.chart-empty p{color:#a0aec0;margin:0}.chart-placeholder{align-items:center;display:flex;justify-content:center}.chart-placeholder,.chart-svg{height:100%;width:100%}.patron-horario-panel{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:20px;padding:20px}.patron-chart-container{margin-bottom:20px;margin-top:20px;min-height:400px;position:relative}.patron-chart-area{background-color:#fafafa;border-radius:6px;height:400px;overflow:hidden;position:relative}.patron-chart-svg{height:100%;width:100%}.patron-legend{border-top:1px solid #e2e8f0;display:flex;gap:20px;padding-top:20px}.patron-legend-item{border-radius:6px;display:flex;flex:1 1;flex-direction:column;gap:8px;padding:15px}.patron-legend-item.horario-optimo{background-color:#f0fdf4}.patron-legend-item.horario-optimo .patron-legend-label{color:#15803d;font-size:14px;font-weight:600}.patron-legend-item.horario-optimo .patron-legend-value{color:#15803d;font-size:11.9px}.patron-legend-item.horas-pico{background-color:#fefce8}.patron-legend-item.horas-pico .patron-legend-label{color:#ca8a04;font-size:14px;font-weight:600}.patron-legend-item.horas-pico .patron-legend-value{color:#ca8a04;font-size:11.9px}.patron-legend-item.horario-critico{background-color:#fef2f2}.patron-legend-item.horario-critico .patron-legend-label{color:#dc2626;font-size:14px;font-weight:600}.patron-legend-item.horario-critico .patron-legend-value{color:#dc2626;font-size:11.9px}@media (max-width:1024px){.monitoreo-sections,.tendencia-charts{grid-template-columns:1fr}.patron-legend{flex-direction:column}}@media (max-width:768px){.monitoreo-filters{flex-direction:column}.filter-actions{justify-content:space-between;margin-left:0;width:100%}.metric-cards,.tendencia-charts{grid-template-columns:1fr}.patron-legend{flex-direction:column}}.estados-tcp-panel{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-top:20px;padding:20px}.estados-tcp-content{margin-top:20px}.estados-tcp-summary{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:30px}.estados-tcp-total{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;display:flex;flex-direction:column;justify-content:center;min-width:180px;padding:20px 30px}.total-label{color:#ffffffd9;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.total-value{color:#fff;font-size:32px;font-weight:700;margin-top:4px}.estados-tcp-categorias{display:flex;flex:1 1;flex-wrap:wrap;gap:15px}.categoria-item{background-color:#f7fafc;border-left:4px solid;border-radius:8px;flex:1 1;min-width:140px;padding:15px}.categoria-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.categoria-name{color:#2d3748;font-size:14px;font-weight:600}.categoria-badge{border-radius:10px;color:#fff;font-size:11px;font-weight:600;padding:2px 8px}.categoria-value{color:#1e3a5f;font-size:24px;font-weight:700}.estados-tcp-chart{align-items:center;display:flex;justify-content:center;margin:30px auto;max-width:350px}.estados-tcp-chart canvas{max-height:300px;max-width:100%}.estados-tcp-table-container{margin-top:30px}.subsection-title{color:#2d3748;font-size:16px;font-weight:600;margin:0 0 15px}.estados-tcp-table{border:1px solid #e2e8f0;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.estados-tcp-table thead{background-color:#f7fafc}.estados-tcp-table th{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.estados-tcp-table td{border-bottom:1px solid #e2e8f0;color:#4a5568;font-size:13px;padding:10px 16px}.estados-tcp-table tbody tr:hover{background-color:#f7fafc}.estados-tcp-table tbody tr:last-child td{border-bottom:none}.estado-name{background-color:#edf2f7;border-radius:4px;color:#2d3748;font-family:Consolas,Monaco,monospace;font-size:12px;padding:2px 6px}.estados-tcp-table .status-badge{border-radius:10px;color:#fff;font-size:11px;font-weight:600;padding:3px 10px;text-transform:uppercase}.estados-tcp-table .status-badge.ok{background-color:#15803d}.estados-tcp-table .status-badge.warning{background-color:#ca8a04}.estados-tcp-table .status-badge.down{background-color:#dc2626}.table-footer{background-color:#f7fafc;border-top:1px solid #e2e8f0;color:#718096;font-size:13px;padding:12px;text-align:center}@media (max-width:1024px){.estados-tcp-summary{flex-direction:column}.estados-tcp-categorias{flex-direction:row;justify-content:space-between}}@media (max-width:768px){.estados-tcp-categorias{flex-direction:column}.categoria-item{min-width:100%}.estados-tcp-table{font-size:12px}.estados-tcp-table td,.estados-tcp-table th{padding:8px 10px}}.navbar{background:#414141;border-bottom:none;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-sizing:border-box;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;height:60px;justify-content:space-between;max-width:100%;padding:0 2vw;position:-webkit-sticky;position:sticky;top:0;width:100vw;z-index:1000}.navbar,.navbar-brand{align-items:center;display:flex}.navbar-brand{gap:10px}.navbar-logo{height:40px;object-fit:contain;width:40px}.navbar-brand h2{color:#ffd414;font-size:20px;font-weight:700;letter-spacing:-.025em;margin:0}.navbar-menu-container{align-items:center;display:flex;flex:1 1;gap:.5vw;margin:0 1vw;max-width:90vw;min-width:0;position:relative;width:90%}.navbar-scroll-btn{align-items:center;background:#2a2a2a;border:1px solid #414141;border-radius:6px;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;padding:0;transition:all .15s ease;width:32px;z-index:10}.navbar-scroll-btn:hover{background:#1a1a1a;border-color:#ffd414;transform:scale(1.05)}.navbar-scroll-btn:active{transform:scale(.95)}.navbar-scroll-btn-left{margin-right:.5vw}.navbar-scroll-btn-right{margin-left:.5vw}.scroll-icon{filter:brightness(0) invert(1);height:16px;opacity:.8;width:16px}.navbar-menu{-webkit-overflow-scrolling:touch;-ms-overflow-style:none;align-items:center;cursor:grab;display:flex;flex:1 1;gap:8px;max-width:100%;min-width:0;overflow-x:auto;overflow-y:hidden;padding:0 8px;scroll-behavior:smooth;scrollbar-width:none;-webkit-user-select:none;user-select:none}.navbar-menu:active{cursor:grabbing}.navbar-menu::-webkit-scrollbar{display:none}.nav-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:6px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:500;gap:8px;padding:8px 16px;transition:all .15s ease;white-space:nowrap}.nav-item-icon{filter:brightness(0) invert(1);flex-shrink:0;height:16px;opacity:.8;width:16px}.nav-item:hover{background:#ffd4141a;border-color:#0000;color:#fde267}.nav-item:hover .nav-item-icon{filter:brightness(0) saturate(100%) invert(89%) sepia(43%) saturate(720%) hue-rotate(358deg) brightness(103%) contrast(98%);opacity:1}.nav-item.active{background:#ffd414;border-color:#ffd414;color:#414141;font-weight:600}.nav-item.active .nav-item-icon{filter:brightness(0) saturate(100%) invert(23%) sepia(0) saturate(0) hue-rotate(180deg) brightness(95%) contrast(90%);opacity:1}.navbar-user-container{flex-shrink:0;margin-left:8px;position:relative}.navbar-user-btn{align-items:center;background:#2a2a2a;border:1px solid #414141;border-radius:6px;box-sizing:border-box;cursor:pointer;display:flex;gap:8px;max-width:200px;padding:8px 16px;transition:all .15s ease;white-space:nowrap}.navbar-user-btn:hover{background:#1a1a1a;border-color:#ffd414}.user-email{color:#fff;font-size:14px;font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis}.user-arrow-icon{filter:brightness(0) invert(1);flex-shrink:0;height:14px;opacity:.8;transition:transform .15s ease;width:14px}.user-menu-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;margin-top:8px;min-width:180px;overflow:hidden;position:absolute;right:0;top:100%;z-index:1050}.user-menu-item{background:#0000;border:none;color:#414141;cursor:pointer;display:block;font-size:14px;font-weight:500;padding:12px 20px;text-align:left;transition:all .15s ease;width:100%}.user-menu-item:hover{background:#f9fafb;color:#111827}.user-menu-item.logout-item{color:#dc2626}.user-menu-item.logout-item:hover{background:#fef2f2;color:#dc2626}.nav-item.loading{background:#ffffff1a;border-color:#0000;color:#ffffff80;cursor:not-allowed;overflow:hidden;position:relative}.nav-item.loading:after{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#0000,#ffd41433,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.nav-item-loader{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:9999px;border-top-color:#ffd414;flex-shrink:0;height:16px;width:16px}.nav-item.just-loaded{animation:unlockPulse .6s ease-out}@keyframes unlockPulse{0%{box-shadow:0 0 0 0 #ffd41466;transform:scale(1)}50%{background:#ffd41433;box-shadow:0 0 0 8px #ffd41400;transform:scale(1.05)}to{box-shadow:0 0 0 0 #ffd41400;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.85;transform:scale(1.02)}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.flow-running-indicator{align-items:center;animation:pulse 2s infinite;background:#fefce8;border:1px solid #fde047;border-radius:6px;cursor:pointer;display:flex;gap:6px;margin-right:10px;padding:6px 12px;transition:all .15s ease}.flow-running-indicator:hover{box-shadow:0 4px 6px -1px #ca8a0433;transform:scale(1.05)}.flow-running-indicator .flow-dot{animation:blink 1s infinite;background:#ca8a04;border-radius:9999px;height:8px;width:8px}.flow-running-indicator .flow-text{color:#ca8a04;font-size:11.9px;font-weight:500}.nav-item{transition:all .15s ease,transform .15s ease,box-shadow .25s ease}@media (max-width:768px){.navbar{flex-direction:column;gap:12px;height:56px;height:auto;padding:12px 16px}.navbar-menu-container{margin:0;width:100%}.navbar-menu{gap:6px;width:100%}.nav-item{font-size:11.9px;padding:8px 12px}.navbar-user-container{margin-left:0;width:100%}.navbar-user-btn{justify-content:space-between;max-width:100%;width:100%}.user-menu-dropdown{right:0;width:100%}.user-email{max-width:none}}.apollo-loader-overlay{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2c5282 50%,#1e3a5f);bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:9999}.apollo-loader-container{align-items:center;display:flex;flex-direction:column;gap:1.5rem}.apollo-logo-wrapper{align-items:center;display:flex;height:120px;justify-content:center;position:relative;width:120px}.apollo-orbit{border:2px solid #fff3;border-radius:50%;border-top-color:#fffc;position:absolute}.apollo-orbit-1{animation:orbit-spin 2s linear infinite;height:100%;width:100%}.apollo-orbit-2{animation:orbit-spin 1.5s linear infinite reverse;border-top-color:#63b3ed;height:80%;width:80%}.apollo-orbit-3{animation:orbit-spin 1s linear infinite;border-top-color:#48bb78;height:60%;width:60%}@keyframes orbit-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.apollo-core{align-items:center;animation:core-pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#fff,#e2e8f0);border-radius:50%;box-shadow:0 0 30px #ffffff4d;display:flex;height:50px;justify-content:center;width:50px}.apollo-letter{color:#1e3a5f;font-family:Arial Black,sans-serif;font-size:1.75rem;font-weight:800}@keyframes core-pulse{0%,to{box-shadow:0 0 30px #ffffff4d;transform:scale(1)}50%{box-shadow:0 0 50px #ffffff80;transform:scale(1.05)}}.apollo-loader-title{color:#fff;font-size:2rem;font-weight:700;letter-spacing:4px;margin:0;text-transform:uppercase}.apollo-loader-message{color:#fffc;font-size:1rem;margin:0}.apollo-progress-bar{background:#fff3;border-radius:2px;height:4px;overflow:hidden;width:200px}.apollo-progress-fill{background:linear-gradient(90deg,#48bb78,#38a169);border-radius:2px;height:100%;transition:width .3s ease}.apollo-loading-dots{display:flex;gap:8px}.apollo-loading-dots span{animation:dot-bounce 1.4s ease-in-out infinite;background:#fff9;border-radius:50%;height:8px;width:8px}.apollo-loading-dots span:first-child{animation-delay:0s}.apollo-loading-dots span:nth-child(2){animation-delay:.2s}.apollo-loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-bounce{0%,80%,to{opacity:.5;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.welcome-screen{align-items:center;background:linear-gradient(135deg,#f7fafc,#edf2f7);display:flex;justify-content:center;min-height:calc(100vh - 70px)}.welcome-content{align-items:center;display:flex;flex-direction:column;padding:2rem;text-align:center}.welcome-logo{margin-bottom:2rem}.welcome-logo-img{height:120px;object-fit:contain;width:120px}.welcome-title{color:#1e3a5f;font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.welcome-user{color:#4a5568;font-size:1.1rem;margin:0 0 .25rem}.welcome-subtitle{color:#718096;font-size:1rem;margin:0 0 2rem}.welcome-continue-btn{background:linear-gradient(135deg,#1e3a5f,#2c5282);border:none;border-radius:8px;box-shadow:0 4px 16px #1e3a5f40;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 32px;transition:all .3s ease}.welcome-continue-btn:hover{box-shadow:0 6px 20px #1e3a5f59;transform:translateY(-2px)}.welcome-continue-btn:active{transform:translateY(0)}.welcome-continue-btn.loading{align-items:center;background:linear-gradient(135deg,#718096,#a0aec0);cursor:not-allowed;display:flex;gap:10px;justify-content:center}.welcome-continue-btn.loading:hover{box-shadow:0 4px 16px #1e3a5f40;transform:none}.welcome-continue-btn:disabled{cursor:not-allowed}.btn-spinner{animation:btn-spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes btn-spin{to{transform:rotate(1turn)}}.facturas-container .icon-svg,.facturas-container img[src*=".svg"]{stroke:currentColor;fill:none}.facturas-container{background:#f5f5f5;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.facturas-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 5px #00000008;padding:2vw 10%}.facturas-title-section{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5vw}.facturas-title{color:#414141;font-size:24px;font-weight:600;margin:0}.facturas-sync-status{align-items:center;display:flex;gap:1vw}.sync-indicator{align-items:center;color:#15803d;display:flex;font-size:14px;font-weight:500;gap:.5vw}.sync-check-icon{stroke:#15803d;fill:#15803d;height:18px;width:18px}.btn-sync{align-items:center;background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:.5vw;padding:10px 16px;transition:all .15s ease}.btn-sync:hover:not(:disabled){background:#e6bf12}.btn-sync:disabled{cursor:not-allowed;opacity:.6}.btn-sync img{stroke:#fff;fill:none;height:16px;width:16px}.spinning-icon{animation:spin 1s linear infinite}.facturas-info-section{margin-bottom:1.5vw}.metrics-cards{grid-gap:1.5vw;display:grid;gap:1.5vw;grid-template-columns:repeat(5,1fr);margin-bottom:2vw;padding:0 10%}.metric-card{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;display:flex;gap:1vw;padding:1.5vw;transition:transform .2s,box-shadow .2s}.metric-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.metric-icon{align-items:center;background:#f7fafc;border-radius:8px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.metric-icon img{stroke:#718096;fill:none;height:24px;width:24px}.metric-content{flex:1 1;min-width:0}.metric-label{color:#718096;font-size:.85rem;font-weight:500;margin-bottom:.3vw}.metric-value{color:#414141;font-size:20px;font-weight:700;line-height:1.2}.metrics-cards .metric-card:nth-child(2) .metric-value,.metrics-cards .metric-card:nth-child(5) .metric-value{font-size:1.1rem}.metric-percentage{color:#718096;font-size:.75rem;margin-top:.2vw}.info-box{background:#edf2f7;border-left:4px solid #718096;border-radius:6px;display:flex;gap:1vw;margin:0 10%;padding:1.2vw}.info-icon{stroke:#718096;fill:none;flex-shrink:0;height:20px;margin-top:2px;width:20px}.info-content{color:#4a5568;flex:1 1;font-size:.9rem;line-height:1.6}.info-content p{margin:.5vw 0}.info-content .highlight{color:#1e3a5f;font-weight:600}.facturas-filters-section{display:flex;flex-direction:column;gap:1vw;padding:0 10%}.search-bar{align-items:center;display:flex;position:relative}.search-icon{stroke:#718096;fill:none;height:18px;left:1vw;pointer-events:none;position:absolute;width:18px}.search-bar input{border:1px solid #e2e8f0;border-radius:6px;font-size:.95rem;padding:.8vw 1vw .8vw 3vw;transition:border-color .2s;width:100%}.search-bar input:focus{border-color:#718096;outline:none}.filters-row{align-items:flex-end;display:flex;gap:1vw}.filter-group{display:flex;flex:1 1;flex-direction:column;gap:.5vw}.filter-group label{color:#4a5568;font-size:.85rem;font-weight:500}.filter-group select{background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:.9rem;padding:.7vw;transition:border-color .2s}.filter-group select:focus{border-color:#718096;outline:none}.filter-actions{display:flex;gap:.8vw}.btn-export,.btn-filter{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5vw;padding:.7vw 1.2vw;transition:all .2s}.btn-filter{background:#ffd414;color:#414141}.btn-filter:hover{background:#e6bf12}.btn-export{background:#15803d;color:#fff}.btn-export:hover{background:#166534}.btn-export img,.btn-filter img{stroke:#fff;fill:none;height:16px;width:16px}.facturas-content{margin:0 10%;min-height:400px;padding:2vw}.loading-invoices,.no-invoices{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;padding:4vw}.empty-icon,.loading-invoices img{stroke:#cbd5e0;fill:none;height:48px;margin-bottom:1vw;width:48px}.loading-invoices p,.no-invoices p{color:#718096;font-size:1rem}.no-invoices-subtitle{color:#a0aec0;font-size:.9rem;font-style:italic;margin-top:.5vw}.invoices-table-container{-webkit-overflow-scrolling:touch;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;max-height:60vh;overflow-x:auto;overflow-y:auto}.invoices-table-container::-webkit-scrollbar{height:8px;width:8px}.invoices-table-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.invoices-table-container::-webkit-scrollbar-thumb{background:#718096;border-radius:4px}.invoices-table-container::-webkit-scrollbar-thumb:hover{background:#4a5568}.invoices-table{border-collapse:collapse;min-width:1400px;width:100%}.invoices-table thead{background:#f7fafc;border-bottom:2px solid #e2e8f0}.invoices-table th{background:#f7fafc;color:#4a5568;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:1vw;position:-webkit-sticky;position:sticky;text-align:left;text-transform:uppercase;top:0;white-space:nowrap;z-index:10}.invoices-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:.9rem;padding:1vw;white-space:nowrap}.invoices-table td:first-child,.invoices-table th:first-child{min-width:60px;text-align:center;width:60px}.invoices-table td:nth-child(2),.invoices-table th:nth-child(2){min-width:120px;width:120px}.invoices-table td:nth-child(3),.invoices-table th:nth-child(3){min-width:180px;width:180px}.invoices-table td:nth-child(4),.invoices-table th:nth-child(4){min-width:120px;width:120px}.invoices-table td:nth-child(5),.invoices-table th:nth-child(5){min-width:150px;width:150px}.invoices-table td:nth-child(6),.invoices-table td:nth-child(7),.invoices-table th:nth-child(6),.invoices-table th:nth-child(7){min-width:120px;width:120px}.invoices-table td:nth-child(8),.invoices-table td:nth-child(9),.invoices-table th:nth-child(8),.invoices-table th:nth-child(9){min-width:110px;width:110px}.invoices-table td:nth-child(10),.invoices-table th:nth-child(10){min-width:80px;text-align:center;width:80px}.invoices-table td:nth-child(11),.invoices-table th:nth-child(11){min-width:130px;width:130px}.invoices-table td:nth-child(12),.invoices-table th:nth-child(12){min-width:150px;width:150px}.invoices-table td:nth-child(13),.invoices-table th:nth-child(13){min-width:120px;width:120px}.invoices-table td:nth-child(14),.invoices-table th:nth-child(14){min-width:150px;width:150px}.invoices-table tbody tr:hover{background:#f7fafc}.amount-cell{color:#1e3a5f;font-weight:600}.semaphore{align-items:center;display:flex;height:24px;justify-content:center;margin:0 auto;width:24px}.semaphore-light{border:2px solid;border-radius:50%;display:block;height:16px;width:16px}.semaphore-green .semaphore-light{background:#15803d;border-color:#15803d;box-shadow:0 0 8px #15803d80}.semaphore-yellow .semaphore-light{background:#ca8a04;border-color:#ca8a04;box-shadow:0 0 8px #ca8a0480}.semaphore-red .semaphore-light{background:#dc2626;border-color:#dc2626;box-shadow:0 0 8px #dc262680}.badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.3vw .8vw;text-transform:uppercase}.badge-posted{background:#dbeafe;color:#1e40af}.badge-draft{background:#f3f4f6;color:#4b5563}.badge-cancel{background:#fee2e2;color:#991b1b}.badge-paid{background:#f0fdf4;color:#15803d}.badge-in-payment{background:#dbeafe;color:#2563eb}.badge-pending{background:#fefce8;color:#ca8a04}.badge-overdue{background:#fef2f2;color:#dc2626}.badge-days{font-size:.7rem;font-weight:400;text-transform:none}.days-overdue{color:#dc2626}.days-warning{color:#ca8a04}.invoice-number{color:#414141;font-weight:600}.analytic-cell{color:#718096;font-size:.85rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-success{background:#d4edda;color:#155724}.badge-warning{background:#fff3cd;color:#856404}.badge-error{background:#f8d7da;color:#721c24}.badge-default{background:#e2e8f0;color:#4a5568}.action-buttons{display:flex;gap:.5vw}.btn-action{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:4px;cursor:pointer;display:flex;font-size:.85rem;gap:.4vw;padding:.5vw .8vw;transition:all .2s}.btn-action:hover{background:#f7fafc;border-color:#cbd5e0}.btn-view{color:#718096}.btn-view:hover{color:#4a5568}.btn-download{color:#28a745}.btn-download:hover{border-color:#28a745;color:#218838}.btn-action img{stroke:currentColor;fill:none;height:14px;width:14px}.load-more-container{display:flex;justify-content:center;margin-top:2vw}.btn-load-more{background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .15s ease}.btn-load-more:hover{background:#e6bf12}.loading-more-container{align-items:center;color:#718096;display:flex;font-size:.9rem;gap:.8vw;justify-content:center;padding:1.5vw}.loading-more-container img{stroke:#718096;fill:none;height:20px;width:20px}.table-status-bar{align-items:center;background:#f7fafc;border-radius:0 0 8px 8px;border-top:1px solid #e2e8f0;color:#718096;display:flex;font-size:.85rem;justify-content:space-between;padding:.8rem 1.2rem}.invoices-count{font-weight:500}.loading-more-indicator{align-items:center;color:#fdd835;display:flex;font-weight:500;gap:.5rem}.loading-more-indicator img{height:18px;width:18px}.end-of-list-text{color:#48bb78;font-weight:500}.end-of-list{align-items:center;border-top:1px solid #e2e8f0;color:#a0aec0;display:flex;font-size:.85rem;font-style:italic;justify-content:center;margin-top:1vw;padding:1.5vw}.facturas-integration-section{background:#fff;border-radius:8px;border-top:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000d;margin:2vw 10% 0;padding:2vw}.integration-box{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5vw}.integration-box h3{color:#414141;font-size:16px;font-weight:600;margin:0 0 1vw}.integration-info{display:flex;flex-direction:column;gap:.8vw}.integration-info p{align-items:center;color:#4a5568;display:flex;font-size:.9rem;gap:.6vw;margin:0}.info-icon-small{stroke:#718096;fill:none;flex-shrink:0;height:16px;width:16px}.integration-info strong{color:#1e3a5f;font-weight:600}.integration-note{border-top:1px solid #e2e8f0;color:#718096!important;font-size:.85rem!important;font-style:italic;margin-top:.5vw!important;padding-top:.8vw}.facturas-no-credentials{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:60vh;padding:4vw;text-align:center}.facturas-no-credentials .alert-icon{stroke:#f56565;fill:none;height:64px;margin-bottom:1.5vw;width:64px}.facturas-no-credentials h3{color:#1e3a5f;font-size:1.5rem;margin:0 0 1vw}.facturas-no-credentials p{color:#718096;font-size:1rem;margin:0}@media (max-width:768px){.facturas-header{padding:4vw 5%}.facturas-title-section{align-items:flex-start;flex-direction:column;gap:1vw}.metrics-cards{grid-template-columns:repeat(2,1fr);padding:0 5%}@media (min-width:769px) and (max-width:1200px){.metrics-cards{grid-template-columns:repeat(3,1fr)}}.filters-row{flex-direction:column}.filter-actions{width:100%}.btn-export,.btn-filter{flex:1 1}.facturas-content{margin:0 5%;padding:4vw}.facturas-integration-section{margin:2vw 5% 0}.invoices-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.invoices-table{min-width:1400px}.invoices-table td,.invoices-table th{font-size:.85rem;padding:.8vw}.action-buttons{flex-direction:column}}.integraciones-externas-container{background:#f5f5f5;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;min-height:100vh;padding:0}.integraciones-externas-content{padding:0}.integraciones-externas-tabs{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:0;margin:0;padding:0 10%}.integraciones-externas-tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#727272;cursor:pointer;font-size:14px;font-weight:500;padding:15px 24px;transition:all .15s ease}.integraciones-externas-tab:hover{background:#f9fafb;color:#414141}.integraciones-externas-tab.active{background:#f9fafb;border-bottom-color:#ffd414;color:#414141;font-weight:600}.integraciones-externas-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:24px;padding:24px 10% 0}.integraciones-externas-header .header-title h1{color:#414141;font-size:24px;font-weight:600;margin:0}.integraciones-externas-header .header-title p{color:#727272;font-size:14px;margin:4px 0 0}.integraciones-externas-header .header-actions{align-items:center;display:flex;gap:12px}.integraciones-externas-header .refresh-btn{align-items:center;background:#ffd414;border:none;border-radius:6px;color:#414141;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 16px;transition:all .15s ease}.integraciones-externas-header .refresh-btn:hover:not(:disabled){background:#e6bf12}.integraciones-externas-header .refresh-btn:disabled{cursor:not-allowed;opacity:.6}.integraciones-externas-header .refresh-btn img{filter:brightness(0) saturate(100%) invert(23%) sepia(0) saturate(0) hue-rotate(180deg) brightness(95%) contrast(90%);height:16px;width:16px}.odoo-search-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;margin:0 10% 20px;padding:20px}.odoo-search-row{display:flex;gap:12px;margin-bottom:16px}.odoo-search-input{border:1px solid #e2e8f0;border-radius:6px;font-size:14px;padding:12px;transition:border-color .2s,box-shadow .2s;width:100%}.odoo-search-input:focus{border-color:#ffd414;box-shadow:0 0 0 3px #ffd41433;outline:none}.odoo-search-btn{background:#ffd414;border:none;border-radius:6px;color:#1a1a1a;cursor:pointer;font-weight:600;padding:12px 24px;transition:background .2s}.odoo-search-btn:hover{background:#e6bf12}.odoo-search-btn:disabled{cursor:not-allowed;opacity:.6}.odoo-filters-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.odoo-filter-group{display:flex;flex-direction:column;gap:4px}.odoo-filter-group label{color:#718096;font-size:12px;font-weight:500}.odoo-filter-group select{border:1px solid #e2e8f0;border-radius:6px;font-size:14px;min-width:150px;padding:8px 12px}.odoo-export-buttons{display:flex;gap:8px;margin-left:auto}.odoo-export-btn{align-items:center;background:#48bb78;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 16px;transition:all .2s}.odoo-export-btn:hover:not(:disabled){background:#38a169}.odoo-export-btn:disabled{cursor:not-allowed;opacity:.6}.odoo-export-btn img{filter:brightness(0) invert(1);height:16px;width:16px}.odoo-export-all-btn{background:#805ad5}.odoo-export-all-btn:hover:not(:disabled){background:#6b46c1}.odoo-apply-filter-btn{align-items:center;background:#3182ce;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s}.odoo-apply-filter-btn:hover:not(:disabled){background:#2c5282}.odoo-apply-filter-btn:disabled{cursor:not-allowed;opacity:.6}.odoo-apply-filter-btn img{filter:brightness(0) invert(1);height:14px;width:14px}.odoo-invoices-table input[type=checkbox]{accent-color:#805ad5;cursor:pointer;height:16px;width:16px}.odoo-invoices-table .selected-row{background:#f0e7ff!important}.odoo-invoices-table .selected-row:hover{background:#e9d8fd!important}.odoo-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(5,1fr);margin:0 10% 20px}.odoo-stat-card{background:#fff;border-left:4px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 8px #0000000d;padding:20px;text-align:center;transition:transform .2s,box-shadow .2s}.odoo-stat-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.odoo-stat-card.stat-green{background:linear-gradient(135deg,#f0fff4,#fff);border-left-color:#48bb78}.odoo-stat-card.stat-yellow{background:linear-gradient(135deg,ivory,#fff);border-left-color:#ecc94b}.odoo-stat-card.stat-red{background:linear-gradient(135deg,#fff5f5,#fff);border-left-color:#e53e3e}.odoo-stat-card.stat-debt{background:linear-gradient(135deg,#faf5ff,#fff);border-left-color:#9f7aea}.odoo-stat-value{color:#2d3748;font-size:28px;font-weight:700;margin-bottom:4px}.odoo-stat-card.stat-green .odoo-stat-value{color:#276749}.odoo-stat-card.stat-yellow .odoo-stat-value{color:#975a16}.odoo-stat-card.stat-red .odoo-stat-value{color:#c53030}.odoo-stat-card.stat-debt .odoo-stat-value{color:#6b46c1;font-size:22px}.odoo-stat-label{color:#718096;font-size:12px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.odoo-empty-state{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;margin:0 10%;padding:60px 20px}.odoo-empty-state img{height:64px;margin-bottom:16px;opacity:.5;width:64px}.odoo-empty-state p{font-size:16px;margin:0}.odoo-loading{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;margin:0 10%;padding:60px 20px}.odoo-loading img{height:40px;margin-bottom:16px;width:40px}.odoo-loading p{font-size:14px;margin:0}.odoo-results-header{align-items:center;background:#f7fafc;border-radius:8px 8px 0 0;color:#718096;display:flex;font-size:14px;justify-content:space-between;margin:0 10%;padding:12px 16px}.odoo-table-container{background:#fff;border-radius:0 0 8px 8px;box-shadow:0 2px 8px #0000000d;margin:0 10%;max-height:60vh;overflow-x:auto;overflow-y:auto}.odoo-invoices-table{border-collapse:collapse;min-width:1200px;width:100%}.odoo-invoices-table thead{background:#f7fafc;position:-webkit-sticky;position:sticky;top:0;z-index:10}.odoo-invoices-table th{border-bottom:2px solid #e2e8f0;color:#4a5568;font-size:12px;font-weight:600;padding:12px 16px;text-align:left;text-transform:uppercase}.odoo-invoices-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;font-size:14px;padding:12px 16px}.odoo-invoices-table tr:hover{background:#f7fafc}.odoo-invoices-table .invoice-number{color:#2b6cb0;font-weight:600}.odoo-invoices-table .amount-cell{font-family:Monaco,Consolas,monospace;text-align:right}.odoo-semaphore{border-radius:50%;box-shadow:0 0 4px #0003;display:inline-block;height:14px;width:14px}.odoo-semaphore.semaphore-green{background:linear-gradient(135deg,#68d391,#48bb78);box-shadow:0 0 8px #48bb7880}.odoo-semaphore.semaphore-yellow{background:linear-gradient(135deg,#f6e05e,#ecc94b);box-shadow:0 0 8px #ecc94b80}.odoo-semaphore.semaphore-red{animation:pulse-red 2s ease-in-out infinite;background:linear-gradient(135deg,#fc8181,#e53e3e);box-shadow:0 0 8px #e53e3e80}.odoo-semaphore.semaphore-gray{background:linear-gradient(135deg,#cbd5e0,#a0aec0)}@keyframes pulse-red{0%,to{box-shadow:0 0 8px #e53e3e80}50%{box-shadow:0 0 16px #e53e3ecc}}.days-cell{font-weight:600;text-align:center}.days-cell.overdue{color:#c53030;font-weight:700}.odoo-badge{border-radius:4px;display:inline-block;font-size:12px;font-weight:500;padding:4px 8px}.odoo-badge.badge-posted{background:#c6f6d5;color:#276749}.odoo-badge.badge-draft{background:#fef3c7;color:#92400e}.odoo-badge.badge-cancel{background:#fed7d7;color:#c53030}.odoo-badge.badge-paid{background:#c6f6d5;color:#276749}.odoo-badge.badge-in-payment{background:#bee3f8;color:#2b6cb0}.odoo-badge.badge-not-paid{background:#fed7d7;color:#c53030}.odoo-badge.badge-partial{background:#fef3c7;color:#92400e}.odoo-badge.badge-default{background:#e2e8f0;color:#4a5568}.actions-cell{text-align:center}.no-docs-indicator{color:#a0aec0;font-size:14px}.odoo-action-btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;justify-content:center;padding:6px 10px;transition:all .2s}.odoo-action-btn:disabled{background:#cbd5e0;cursor:not-allowed;opacity:.5}.odoo-action-btn img{filter:brightness(0) invert(1);height:16px;width:16px}.odoo-preview-btn{background:#805ad5}.odoo-preview-btn:hover:not(:disabled){background:#6b46c1}.odoo-download-btn{background:#2b6cb0}.odoo-download-btn:hover:not(:disabled){background:#2c5282}.odoo-loading-more{align-items:center;color:#718096;display:flex;font-size:14px;gap:8px;justify-content:center;margin:0 10%;padding:16px}.odoo-loading-more img{height:20px;width:20px}.odoo-end-list{color:#48bb78;font-size:14px;font-weight:500;margin:0 10%;padding:16px;text-align:center}.check-placeholder{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;margin:0 10%;padding:80px 20px}.check-placeholder img{height:80px;margin-bottom:20px;opacity:.4;width:80px}.check-placeholder h2{color:#4a5568;font-size:20px;margin:0 0 8px}.check-placeholder p{font-size:14px;margin:0}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:1200px){.odoo-stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.integraciones-externas-tabs{overflow-x:auto;padding:0 5%}.integraciones-externas-header{flex-direction:column;gap:16px;padding:24px 5% 0}.odoo-stats-grid{grid-template-columns:repeat(2,1fr);margin:0 5% 20px}.odoo-search-section{margin:0 5% 20px}.odoo-filters-row,.odoo-search-row{flex-direction:column}.odoo-filters-row{align-items:stretch}.odoo-export-btn{justify-content:center;margin-left:0}.odoo-empty-state,.odoo-end-list,.odoo-loading,.odoo-loading-more,.odoo-results-header,.odoo-table-container{margin:0 5%}.odoo-table-container{max-height:50vh}.odoo-stat-value{font-size:22px}.odoo-stat-card.stat-debt .odoo-stat-value{font-size:18px}.check-placeholder{margin:0 5%}}.error-page{align-items:center;background:#f7fafc;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:40px 20px;position:relative}.error-page-content{animation:errorPageFadeIn .5s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;max-width:500px;padding:50px 40px;position:relative;text-align:center;width:100%;z-index:10}@keyframes errorPageFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.error-page-icon-container{align-items:center;display:inline-flex;justify-content:center;margin-bottom:30px;position:relative}.error-page-icon{animation:errorIconPulse 2s ease-in-out infinite;background:#f7fafc;border:2px solid #e2e8f0;border-radius:50%;height:80px;padding:20px;width:80px}@keyframes errorIconPulse{0%,to{box-shadow:0 0 0 0 #71809633;transform:scale(1)}50%{box-shadow:0 0 0 15px #71809600;transform:scale(1.05)}}.error-page-code{background:#718096;border-radius:20px;bottom:-5px;box-shadow:0 2px 8px #7180964d;color:#fff;font-size:18px;font-weight:700;padding:6px 14px;position:absolute;right:-10px}.error-page-title{color:#1e3a5f;font-size:28px;font-weight:700;line-height:1.3;margin:0 0 15px}.error-page-message{color:#4a5568;font-size:16px;line-height:1.6;margin:0 0 10px}.error-page-suggestion{color:#718096;font-size:14px;line-height:1.5;margin:0 0 30px}.error-page-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:30px}.error-page-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.error-page-btn-primary{background:#718096;box-shadow:0 2px 8px #7180964d;color:#fff}.error-page-btn-primary:hover{background:#4a5568;box-shadow:0 4px 12px #71809666;transform:translateY(-2px)}.error-page-btn-secondary{background:#fff;border:1px solid #e2e8f0;color:#4a5568}.error-page-btn-secondary:hover{background:#f7fafc;border-color:#cbd5e0;transform:translateY(-2px)}.error-page-btn-icon{height:16px;width:16px}.error-page-help{align-items:center;border-top:1px solid #e2e8f0;color:#718096;display:flex;font-size:13px;gap:8px;justify-content:center;padding-top:20px}.error-page-help-icon{height:16px;opacity:.7;width:16px}.error-page-decoration{bottom:0;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0}.error-page-circle{background:linear-gradient(135deg,#7180960d,#71809605);border-radius:50%;position:absolute}.error-page-circle-1{animation:floatCircle 20s ease-in-out infinite;height:400px;right:-100px;top:-150px;width:400px}.error-page-circle-2{animation:floatCircle 15s ease-in-out infinite reverse;bottom:-100px;height:300px;left:-80px;width:300px}.error-page-circle-3{animation:floatCircle 18s ease-in-out infinite;height:200px;left:10%;top:50%;width:200px}@keyframes floatCircle{0%,to{transform:translate(0)}25%{transform:translate(20px,-20px)}50%{transform:translateY(-40px)}75%{transform:translate(-20px,-20px)}}@media (max-width:600px){.error-page-content{padding:40px 25px}.error-page-icon{height:60px;padding:15px;width:60px}.error-page-code{font-size:14px;padding:4px 10px}.error-page-title{font-size:22px}.error-page-message{font-size:14px}.error-page-actions{flex-direction:column}.error-page-btn{justify-content:center;width:100%}}
/*# sourceMappingURL=main.8a917a47.css.map*/