@import"https://fonts.googleapis.com/css2?family=Roboto:wght@300;400;500;600;700&display=swap";@import"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.min.css";:root{font-family:Roboto,sans-serif;font-optical-sizing:auto;font-style:normal;font-variation-settings:"wdth" 100;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%}body{margin:0;padding:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:320px;min-height:100vh;background-color:var(--bg-off-white);color:var(--text-dark);width:100vw;max-width:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}button{font-family:Roboto,sans-serif}a{text-decoration:none;color:inherit}:root{--primary-color: #2563eb;--secondary-color: #f43f5e;--accent-color: rgb(155, 77, 224);--bg-light: #ffffff;--bg-off-white: #f8f9fa;--bg-light-gray: #edf2f7;--bg-dark: #111827;--text-dark: #111827;--text-gray: #374151;--text-light-gray: #6b7280;--text-lighter-gray: #c1c6ce;--text-white: #ffffff;--card-bg: #ffffff;--card-border: #e2e8f0;--card-shadow: rgba(0, 0, 0, .1);--btn-primary: var(--primary-color);--btn-hover: #1d4ed8;--btn-secondary: var(--secondary-color);--success-color: #22c55e;--warning-color: #f59e0b;--danger-color: #ef4444;--info-color: #3b82f6;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-md: 1.125rem;--font-lg: 1.25rem;--font-xl: 1.5rem;--font-2xl: 1.75rem;--font-3xl: 2rem;--font-4xl: 2.375rem;--transition-slow: .5s ease;--transition-medium: .3s ease;--transition-fast: .2s ease;--gradient-blue: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);--gradient-purple: linear-gradient(135deg, #7e22ce 0%, #6b21a8 100%)}.dashboard{display:flex;flex-direction:column;min-height:99vh;background-color:var(--bg-off-white);font-family:Roboto,sans-serif;color:var(--text-dark);width:100%;padding-top:1vh;margin:0 auto}.dashboard-content{flex:1;padding:80px 20px;max-width:100%;margin:0 auto}.no-results-message{text-align:center;padding:40px 20px;color:var(--text-light-gray);font-size:var(--font-lg);background-color:#ffffff80;border-radius:12px;box-shadow:0 4px 20px var(--card-shadow);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:80%;max-width:500px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px}.no-results-message i{font-size:2rem;color:var(--text-light-gray);margin-bottom:10px}.search-loading{display:inline-block;width:20px;height:20px;border:2px solid rgba(0,0,0,.1);border-radius:50%;border-top-color:var(--primary-color);animation:spin 1s ease-in-out infinite;margin-right:10px}.location-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:20px;margin-top:20px;width:100%;margin-bottom:60px}.dashboard.refreshing .location-card{position:relative;overflow:hidden}.dashboard.refreshing .location-card:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,#fff0,#ffffffb3,#fff0);animation:shimmer 1.5s infinite;transform:translate(-100%);pointer-events:none}@media (min-width: 640px){.location-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1000px){.location-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1280px){.location-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1600px){.location-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width: 768px){.dashboard-content{padding:130px 15px 50px;max-width:100%}.location-grid{margin-bottom:80px;gap:15px}.no-results-message{width:80%;padding:30px 15px;font-size:var(--font-base)}}@media (max-width: 480px){.dashboard-content{padding:60px 40px 50px;max-width:100%}.location-grid{gap:12px;margin-bottom:0}.no-results-message{width:85%;padding:20px 15px}}@keyframes spin{to{transform:rotate(360deg)}}.navbar{background-color:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:fixed;top:0;left:0;right:0;z-index:300;padding:1.25rem 1rem;width:90vw;border-radius:0 0 40px 40px;margin:0 5vw;box-shadow:0 2px 35px var(--card-shadow)}.navbar-container{display:flex;justify-content:space-between;align-items:center;max-width:95%;margin:0 auto}.navbar-left{display:flex;align-items:center;gap:1rem;min-width:250px}.navbar-logo{font-size:var(--font-xl);font-weight:600;color:var(--primary-color);text-decoration:none;display:flex;align-items:center;gap:.5rem}.navbar-logo-img{width:32px;height:32px;margin-right:15px;object-fit:contain}.navbar-center{flex:1;display:flex;justify-content:center;padding:0 1rem;position:relative;max-width:40vw}.search-container{position:relative;width:100%;max-width:400px}.search-input{padding:.5rem 2.5rem;border-radius:50px;border:1px solid var(--card-border);font-size:var(--font-sm);width:100%;color:var(--text-gray);transition:all var(--transition-fast);background-color:var(--bg-light)}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb33}.search-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-gray);pointer-events:none}.clear-icon{position:absolute;right:3rem;top:50%;transform:translateY(-50%);color:var(--text-light-gray);cursor:pointer;font-size:var(--font-base);width:20px;height:20px;display:flex;align-items:center;justify-content:center;z-index:10;opacity:0;transition:all var(--transition-fast)}.clear-icon.visible{opacity:1}.searching .search-icon i{animation:rotate 1s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-dropdown{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-light);border:1px solid var(--card-border);border-radius:10px;box-shadow:0 4px 12px var(--card-shadow);margin-top:.5rem;max-height:300px;overflow-y:auto;z-index:1001;display:none}.search-dropdown.visible{display:block}.search-dropdown-item{padding:.75rem 1rem;cursor:pointer;transition:all var(--transition-fast);border-bottom:1px solid var(--card-border)}.search-dropdown-item:last-child{border-bottom:none}.search-dropdown-item:hover{background-color:var(--bg-light-gray)}.location-name{font-weight:500;color:var(--text-dark)}.location-address{font-size:var(--font-xs);color:var(--text-light-gray);margin-top:.25rem}.search-btn{position:absolute;right:0;top:0;height:100%;background-color:var(--primary-color);color:#fff;border:none;border-radius:0 50px 50px 0;padding:0 1rem;cursor:pointer;transition:all var(--transition-fast)}.search-btn:hover{background-color:var(--btn-hover)}.no-results{padding:1rem;text-align:center;color:var(--text-light-gray)}.navbar-right{display:flex;align-items:center;gap:1rem;min-width:250px;width:17vw;justify-content:flex-end}.refresh-btn{display:flex;align-items:center;justify-content:center;padding:.5rem 1rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:10px;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);min-width:100px}.refresh-btn:hover{background-color:var(--btn-hover)}.refresh-btn-disabled{background-color:var(--text-light-gray);cursor:not-allowed}.refresh-btn-disabled:hover{background-color:var(--text-light-gray)}.refresh-btn i{margin-right:.5rem}.refresh-btn.refreshing{position:relative;overflow:hidden}.refresh-btn.refreshing i{animation:spin 1s linear infinite}.auto-refresh{position:relative}.auto-refresh-btn{padding:.5rem 1rem;background-color:var(--bg-light);border:1px solid var(--card-border);border-radius:10px;font-size:var(--font-sm);cursor:pointer;display:flex;color:var(--text-gray);align-items:center}.auto-refresh-dropdown{position:absolute;top:100%;right:0;background-color:var(--bg-light);border:1px solid var(--card-border);border-radius:10px;box-shadow:0 4px 12px var(--card-shadow);min-width:120px;z-index:1001;margin-top:.25rem}.dropdown-item{padding:.5rem 1rem;cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-sm)}.dropdown-item:hover{background-color:var(--bg-light-gray)}.navbar-link{padding:.5rem .75rem;color:var(--text-gray);text-decoration:none;font-size:var(--font-base);font-weight:500;transition:color var(--transition-fast);white-space:nowrap}.navbar-link:hover{color:var(--primary-color)}.reset-search-btn{margin-left:10px;background-color:var(--primary-color);color:var(--text-white);border:none;border-radius:10px;padding:6px 12px 5px;font-size:var(--font-sm);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 1px 3px var(--card-shadow)}.reset-search-btn:hover{background-color:var(--text-light-gray);color:#fff}@media (max-width: 1000px){.navbar-container{flex-wrap:wrap;gap:.75rem}.navbar-left{order:1;width:100%;justify-content:space-between;margin-bottom:.75rem}.navbar-center{order:3;width:100%;max-width:100%;padding:0;margin-top:.75rem}.navbar-right{order:2;gap:.5rem;min-width:auto;width:100%;justify-content:flex-end}.navbar-link{font-size:var(--font-sm);padding:.5rem}}@media (max-width: 768px){.navbar{padding:1rem .75rem;width:94vw;margin:0 3vw;border-radius:0 0 25px 25px}.navbar-container{flex-direction:column;width:100%;gap:1rem}.navbar-left{flex-wrap:wrap;gap:.25rem;justify-content:center;margin-bottom:.5rem}.navbar-logo{font-size:var(--font-lg);margin-right:auto}.navbar-logo-img{width:24px;height:24px;margin-right:8px}.navbar-link{padding:.25rem .5rem;font-size:var(--font-xs)}.navbar-right{width:100%;justify-content:space-between;gap:.5rem}.refresh-btn,.auto-refresh-btn{font-size:var(--font-xs);padding:.4rem .5rem;min-width:auto;flex:1}.refresh-btn i{margin-right:.25rem}.auto-refresh-btn{max-width:110px}.navbar-center{flex-direction:column;align-items:stretch;width:100%}.search-container{max-width:100%}.search-input{font-size:var(--font-xs);padding:.4rem 1rem .4rem 2rem}.reset-search-btn{margin:.5rem auto 0;display:block;width:40%}.search-dropdown{max-height:200px}.search-dropdown-item{padding:.5rem .75rem}.dropdown-item{padding:.5rem .75rem;font-size:var(--font-xs)}}@media (max-width: 480px){.navbar{width:96vw;margin:0 2vw;padding:.75rem .5rem}.navbar-left{justify-content:space-between;width:100%}.navbar-logo-img{width:20px;height:20px;margin-right:5px}.navbar-link{font-size:calc(var(--font-xs) - 1px);padding:.25rem}.reset-search-btn{width:100%;margin-top:.5rem}.refresh-btn,.auto-refresh-btn{padding:.4rem;font-size:calc(var(--font-xs) - 1px)}.refresh-btn span{display:none}.refresh-btn i{margin-right:0}}.mobile-navbar{padding:.75rem .5rem}.mobile-container{width:100%;display:flex;flex-direction:row;justify-content:space-between;padding:1.5vh 5vw;align-items:center}.mobile-navbar-left{display:flex;align-items:center}.mobile-navbar-actions{display:flex;align-items:center;gap:.75rem}.mobile-refresh-btn,.mobile-search-btn,.mobile-menu-btn{background:transparent;border:none;color:var(--text-gray);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--font-base);transition:background-color var(--transition-fast)}.mobile-refresh-btn:hover,.mobile-search-btn:hover,.mobile-menu-btn:hover{background-color:var(--bg-light-gray)}.mobile-refresh-btn.refresh-btn-disabled{color:var(--text-light-gray);cursor:not-allowed;background-color:var(--bg-light-gray)}.mobile-refresh-btn .mobile-cooldown{position:absolute;top:10px;right:63px;font-size:.5rem;background-color:var(--text-light-gray);color:#fff;border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;font-weight:700}.mobile-menu-dropdown{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-light);box-shadow:0 8px 16px #0000001a;border-radius:15px;z-index:300;padding:2vw;margin:1vh 2vw;animation:slideDown .3s ease-out;max-height:80vh;overflow-y:auto}.mobile-menu-close{display:flex;position:fixed;justify-content:center;width:36px;height:36px;border-radius:50%;background-color:var(--bg-light);right:20px;top:14px}.mobile-nav-close-btn{background:transparent;border:none;color:var(--text-gray);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--font-base);transition:background-color var(--transition-fast)}.mobile-nav-close-btn:hover{background-color:var(--bg-light-gray);color:var(--primary-color)}.mobile-menu-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;margin-left:-2vw;background-color:#00000080;z-index:200;animation:fadeIn .2s ease-out}.mobile-menu-item{padding:.875rem 1.25rem;display:flex;align-items:center;gap:.75rem;color:var(--text-gray);border-radius:12px;font-size:var(--font-sm);cursor:pointer;transition:background-color var(--transition-fast);text-decoration:none}.mobile-menu-item:hover,.mobile-menu-item.active{background-color:var(--primary-color);color:var(--text-white)}.refresh-settings{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem;margin:10px 0;font-size:var(--font-sm);color:var(--text-gray);cursor:pointer;transition:background-color var(--transition-fast)}.refresh-time{width:105px;padding:.6rem 1.25rem;display:flex;justify-content:center;align-items:center;border:1px solid var(--card-border)}.mobile-menu-item i{width:20px;text-align:center}.mobile-menu-section{margin-top:.5rem;border-top:1px solid var(--card-border);padding-top:.5rem}.mobile-menu-section-title{padding:.5rem 1.25rem;font-size:var(--font-xs);color:var(--text-light-gray);font-weight:500}.mobile-search-popup{position:absolute;top:100%;left:0;right:0;margin:1vh 2vw;background-color:var(--bg-light);box-shadow:0 8px 16px #0000001a;border-radius:15px;z-index:1000;padding:1rem;animation:slideDown .3s ease-out}.mobile-search-container{position:relative;width:100%}.mobile-search-input{width:100%;padding:.75rem 2.5rem;border-radius:50px;border:1px solid var(--card-border);font-size:var(--font-sm);background-color:var(--bg-light);color:var(--text-gray);transition:all var(--transition-fast)}.mobile-search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb33}.mobile-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-gray);pointer-events:none}.mobile-clear-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:var(--text-light-gray);opacity:0;transition:opacity var(--transition-fast);cursor:pointer}.mobile-clear-icon.visible{opacity:1}.mobile-search-dropdown{margin-top:.75rem;max-height:60vh;overflow-y:auto}.mobile-search-dropdown-item{padding:.75rem 1rem;border-bottom:1px solid var(--card-border);cursor:pointer;transition:background-color var(--transition-fast)}.mobile-search-dropdown-item:last-child{border-bottom:none}.mobile-search-dropdown-item:hover{background-color:var(--bg-light-gray)}.mobile-search-no-results{padding:1.5rem;text-align:center;color:var(--text-light-gray);font-size:var(--font-sm)}@media (max-width: 480px){.navbar{width:96vw;margin:0 2vw;padding:0}.navbar-container{width:100%;max-width:100%}.navbar-left,.navbar-center,.navbar-right{display:none}.navbar-logo-img{width:24px;height:24px;margin-right:0}.mobile-refresh-btn.refreshing i{animation:spin 1s linear infinite}}.location-card{background-color:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 4px 20px var(--card-shadow);padding:1.5rem;border:1px solid var(--card-border);transition:all var(--transition-medium);min-width:350px;max-width:375px;cursor:pointer;position:relative;border-top:4px solid var(--card-border);display:flex;flex-direction:column}.location-card.live{border-top-color:var(--success-color)}.location-card.offline{border-top-color:var(--danger-color)}.location-card:hover{box-shadow:0 6px 25px #0000001f;border-color:var(--primary-color)}.location-card.expanded{grid-column:1 / -1;width:500px;max-width:500px;margin:0 auto;cursor:default;transform:none;animation:expandCard .3s ease-out;position:relative}@keyframes expandCard{0%{opacity:.8;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.location-card.expanded:hover{transform:none}.close-expanded-card{position:absolute;top:5px;right:-45px;background-color:var(--bg-light);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all var(--transition-fast);color:var(--text-gray);font-size:var(--font-sm);box-shadow:0 2px 8px #00000026}.close-expanded-card:hover{background-color:var(--primary-color);color:#fff}.mobile-close-btn{position:absolute;bottom:-25px;left:50%;transform:translate(-50%);background-color:var(--primary-color);color:#fff;border:none;border-radius:50%;width:40px;height:40px;display:none;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 2px 8px #00000026}.location-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-grow:1}.location-info{display:flex;flex-direction:column;flex-grow:1;height:100%}.location-top{display:flex;justify-content:space-between;margin-bottom:1rem;flex-grow:1}.location-top-left{width:80%}.location-title{font-size:var(--font-lg);font-weight:600;margin:0 0 .5rem;color:var(--text-dark)}.location-address{font-size:var(--font-sm);color:var(--text-gray);margin:0}.location-map-btn{background-color:var(--bg-light-gray);border:none;border-radius:8px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast);color:var(--text-gray);z-index:5}.location-map-btn:hover{background-color:var(--primary-color);color:#fff}.location-activity{display:flex;justify-content:space-between;align-items:flex-start;flex-direction:row;flex-grow:0}.location-hours{font-size:var(--font-xs);color:var(--text-gray);text-wrap:pretty;width:70%}.location-stats{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;border-top:1px solid var(--card-border);padding-top:1.75rem;flex-grow:0}.occupancy{width:40%;text-align:center}.occupancy-count{display:flex;align-items:center;justify-content:center;gap:.5rem}.occupancy-number{font-size:var(--font-2xl);font-weight:700;color:var(--text-dark)}.occupancy-trend,.waiting-time-trend{color:var(--text-lighter-gray);font-size:var(--font-xs);display:flex;align-items:center}.trend-up{color:var(--danger-color)}.trend-down{color:var(--success-color)}.occupancy-label{font-size:var(--font-xs);color:var(--text-light-gray);margin-top:.25rem}.waiting-time-container{width:50%;display:flex;justify-content:center}.waiting-time{background-color:var(--bg-light-gray);padding:.75rem 1rem;border-radius:8px;text-align:center}.waiting-time-value-container{display:flex;align-items:center;justify-content:center;gap:.5rem}.waiting-time-value{font-size:var(--font-lg);font-weight:600;color:var(--text-dark);margin:0}.waiting-time-label{font-size:var(--font-xs);color:var(--text-light-gray);display:block;margin-top:.25rem}.trend-charts{margin-top:1.25rem;margin-bottom:.5rem;padding:1rem;border-radius:15px;border:1px solid var(--card-border);animation:fadeIn .5s ease-out;transition:opacity .3s ease,height .3s ease;min-height:220px}.trend-title{font-size:var(--font-sm);color:var(--text-dark);margin-bottom:1.5rem;font-weight:500;text-align:center}.trend-row{margin-bottom:1.5rem}.trend-row:last-child{margin-bottom:0}.trend-bars{display:flex;align-items:flex-end;height:80px;gap:7px}.trend-bar{background-color:var(--primary-color);flex-grow:1;height:5px;outline:1px solid var(--card-border);transition:height var(--transition-medium);position:relative;border-radius:8px}.trend-bar.current{background-color:var(--accent-color);position:relative;z-index:1}.trend-bar:before{content:attr(data-tooltip);position:absolute;background-color:var(--bg-dark);color:var(--text-white);padding:4px 8px;border-radius:5px;font-size:11px;bottom:calc(100% + 5px);left:50%;transform:translate(-50%) scale(0);transition:transform .2s ease;transform-origin:bottom center;white-space:nowrap;pointer-events:none;z-index:100}.trend-bar:hover:before{transform:translate(-50%) scale(1)}.trend-bar:after{content:"";position:absolute;bottom:calc(100% + 1px);left:50%;transform:translate(-50%) scale(0);transition:transform .2s ease;transform-origin:top center;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid rgba(0,0,0,.75);pointer-events:none}.trend-bar:hover:after{transform:translate(-50%) scale(1)}.trend-labels{display:flex;justify-content:space-between;margin-top:.75rem;font-size:var(--font-xs);color:var(--text-light-gray)}.location-status{display:flex;justify-content:right;align-items:center;padding-left:20px}.status-indicator{width:12px;height:12px;border-radius:50%;margin-right:10px}.status-live{background-color:var(--success-color);position:relative;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #22c55eb3}70%{box-shadow:0 0 0 10px #22c55e00}to{box-shadow:0 0 #22c55e00}}.status-offline{background-color:var(--danger-color)}.status-text{font-size:var(--font-xs);color:var(--text-gray)}.card-footer{margin-top:1.5rem;display:flex;justify-content:space-between;align-items:center;font-size:var(--font-xs);color:var(--text-light-gray);flex-grow:0}.update-interval{font-style:italic}.last-updated{text-align:right;font-style:italic}.card-click-hint{position:absolute;bottom:-7px;left:50%;transform:translate(-50%);background-color:var(--primary-color);color:#fff;padding:2px 10px;border-radius:12px;font-size:var(--font-xs);opacity:0;transition:opacity .3s ease}.card-click-hint i{margin-right:5px}.location-card:hover .card-click-hint{opacity:1}@media (max-width: 768px){.location-card{padding:1rem}.location-card.expanded{width:95%;max-width:none}.trend-bars{height:70px}}@media (max-width: 480px){.close-expanded-card{display:none}.mobile-close-btn{display:flex}}.skeleton-card{background-color:#fffc;border-radius:12px;box-shadow:0 4px 20px var(--card-shadow);padding:1.5rem;border:1px solid var(--card-border);position:relative;overflow:hidden;height:300px;min-width:350px;margin:0;display:flex;flex-direction:column;justify-content:space-between}.loading-container{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:center;width:100%;padding:25px;gap:20px}.loading-container-admin{width:100%}.skeleton-card:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,#fff0,#ffffff80,#fff0);animation:shimmer 1.5s infinite;transform:translate(-100%)}.skeleton-row{position:relative;height:56px;width:100%;overflow:hidden}.sort-hidden{opacity:0}.skeleton-row:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,#fff0,#ffffff80,#fff0);animation:shimmer 1.5s infinite;transform:translate(-100%)}.skeleton-cell{background-color:#e2e8f0;border-radius:4px;height:20px;margin:10px 0}.skeleton-id{width:70%}.skeleton-name{width:85%}.skeleton-address{width:90%}.skeleton-status{width:60%}.skeleton-interval{width:50%}.skeleton-last-updated{width:70%}.skeleton-header{padding-bottom:1.5rem}.skeleton-title{height:28px;width:70%;background-color:#e2e8f0;border-radius:6px}.skeleton-stats{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.skeleton-occupancy{height:40px;width:50%;background-color:#e2e8f0;border-radius:6px}.skeleton-waiting-time{width:80px;height:60px;background-color:#e2e8f0;border-radius:6px}.skeleton-chart{height:100px;width:100%;background-color:#e2e8f0;border-radius:6px;margin-bottom:1.5rem}.skeleton-updated{height:14px;width:40%;background-color:#e2e8f0;border-radius:4px;margin-left:auto}.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000a6;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease-out}.disclaimer-modal{background-color:var(--bg-light);max-width:600px;width:90%;border-radius:15px;padding:1.5rem;box-shadow:0 10px 25px #0003;animation:slideUp .4s ease-out;border:1px solid var(--card-border);display:flex;flex-direction:column;align-items:center}.disclaimer-title{font-size:var(--font-xl);margin-top:0;margin-bottom:1rem;color:var(--text-dark);font-weight:600}.disclaimer-content{margin:5px 20px 15px 25px;line-height:1.6;color:var(--text-gray);text-wrap:pretty}.disclaimer-content li{margin-bottom:.75rem}.disclaimer-btn{padding:.5rem 2rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:10px;font-size:var(--font-base);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.disclaimer-btn:hover{background-color:var(--btn-hover)}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 480px){.disclaimer-content{margin:5px 20px 20px 25px;line-height:1.45;color:var(--text-gray);text-wrap:pretty}}.footer{background-color:#ffffffb3;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);color:var(--text-light-gray);text-align:center;padding:15px 20px;font-family:Roboto,sans-serif;font-size:var(--font-sm);position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;justify-content:center;align-items:center;border-radius:40px 40px 0 0;box-shadow:0 -2px 35px var(--card-shadow);gap:15px}.footer-left{display:flex;align-items:center;justify-content:center}.footer-right{display:flex;align-items:center;justify-content:center;gap:15px}.refresh-timestamp{font-style:italic;color:var(--text-light-gray)}.footer-divider{width:1px;height:20px;background-color:var(--card-border);margin:0 15px}.footer-link{color:var(--text-light-gray);text-decoration:none;transition:color var(--transition-fast);font-weight:400;display:inline-flex;align-items:center;gap:7px}.footer-link:hover{color:var(--btn-hover)}@media (min-width: 1001px){.footer{width:38vw;margin:0 31vw}}@media (max-width: 1400px){.footer{width:80vw;margin:0 10vw}}@media (max-width: 768px){.footer{padding:8px 15px;flex-direction:column;gap:5px;text-align:center;width:90vw;margin:0 5vw;border-radius:30px 30px 0 0;font-size:var(--font-xs)}.mobile-footer{flex-direction:column;align-items:stretch;gap:0;width:95vw;margin:0 2.5vw;border-radius:30px 30px 0 0;box-shadow:0 -2px 35px var(--card-shadow);padding:5px 0}.mobile-refresh{width:100%;text-align:center;color:var(--text-light-gray);font-style:italic;margin-bottom:5px;margin-top:5px;padding-bottom:2px}.footer-mobile-row{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:10px;width:100%}.footer-left,.footer-right{width:auto;justify-content:center;align-items:center;display:flex;gap:0;margin-bottom:3px}.footer-divider{margin:0 8px;height:18px}.footer-link{gap:5px}}.admin-panel{display:flex;flex-direction:column;min-height:99vh;background-color:var(--bg-off-white);font-family:Roboto,sans-serif;color:var(--text-dark);width:100%;padding-top:1vh;margin:0 auto}.admin-content{flex:1;padding:80px 20px;width:80vw;margin:50px auto 0}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;padding:0 2rem}.admin-title{font-size:var(--font-3xl);font-weight:600;color:var(--text-dark);margin:0}.admin-actions{display:flex;gap:1rem;align-items:center}.add-location-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:10px;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.add-location-btn{background-color:var(--primary-color);color:#fff}.add-location-btn:hover{background-color:var(--btn-hover)}.logout-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;border-radius:10px;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);background-color:var(--danger-color);color:#fff}.logout-btn:hover{background-color:#dc2626}.locations-table{width:100%;border-collapse:separate;border-spacing:0 7px;font-size:var(--font-sm)}.locations-table thead{background-color:transparent}.locations-table thead tr{background-color:var(--bg-light);border-radius:8px}.locations-table th{padding:15px 1.25rem 20px;text-align:center;font-weight:600;font-size:var(--font-base);color:var(--text-dark);cursor:pointer;-webkit-user-select:none;user-select:none;background-color:var(--bg-off-white);transition:.3s ease}.locations-table th:hover{color:var(--primary-color)}.locations-table th i{margin-left:.5rem;color:var(--text-light-gray)}.locations-table th:hover i{color:var(--primary-color)}.locations-table tbody tr{background-color:var(--bg-light);border-radius:20px;transition:all var(--transition-fast);box-shadow:0 0 7px #0000000d}.table-row{cursor:pointer}.table-row:hover{outline:1px solid var(--primary-color)}.locations-table td{padding:15px 1.25rem;color:var(--text-gray);vertical-align:middle;background-color:inherit}.locations-table td:first-child{border-radius:20px 0 0 20px;text-align:left}.locations-table td:last-child{border-radius:0 20px 20px 0}.locations-table td:only-child{border-radius:20px}.locations-table th:nth-child(4),.locations-table th:nth-child(5),.locations-table td:nth-child(4),.locations-table td:nth-child(5){text-align:center}.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 15px;border-radius:9px;width:80px;font-size:var(--font-xs);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.status-online{background-color:var(--success-color);color:var(--text-white)}.status-offline{background-color:var(--danger-color);color:var(--text-white)}.loading-container-admin{display:grid;grid-template-columns:1fr;gap:1rem}.error-message{text-align:center;padding:5rem 2rem;color:var(--text-light-gray);font-size:var(--font-lg);border-radius:12px;box-shadow:0 4px 20px var(--card-shadow);display:flex;flex-direction:column;align-items:center;width:50%;margin:10vh auto 0;gap:2rem}.error-message i{font-size:2rem;color:var(--danger-color);margin-top:20px}.error-message .refresh-btn{background-color:var(--primary-color);color:#fff;border:none;margin:20px auto;padding:.75rem 1.5rem;border-radius:10px;cursor:pointer;font-size:var(--font-sm);transition:background-color var(--transition-fast)}.error-message .refresh-btn:hover{background-color:var(--btn-hover)}.no-results-message{text-align:center;padding:4rem 2rem;color:var(--text-light-gray);font-size:var(--font-lg);background-color:#ffffff80;border-radius:12px;box-shadow:0 4px 20px var(--card-shadow);margin:2rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.no-results-message i{font-size:2rem;color:var(--text-light-gray)}.admin-panel.refreshing .locations-table-container{position:relative;overflow:hidden}.admin-panel.refreshing .locations-table-container:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,#fff0,#ffffffb3,#fff0);animation:shimmer 1.5s infinite;transform:translate(-100%);pointer-events:none}@keyframes shimmer{to{transform:translate(100%)}}@media (max-width: 1200px){.locations-table{font-size:var(--font-xs)}.locations-table th,.locations-table td{padding:.75rem 1rem}}@media (max-width: 768px){.admin-content{padding:130px 15px 50px}.admin-header{flex-direction:column;gap:1rem;align-items:stretch;margin-bottom:1.5rem}.admin-title{font-size:var(--font-2xl);text-align:center}.admin-actions{justify-content:center;flex-wrap:wrap}.locations-table-container{overflow-x:auto}.locations-table{min-width:700px;border-spacing:0 .25rem}.locations-table th,.locations-table td{padding:.5rem .75rem;font-size:var(--font-xs)}}@media (max-width: 480px){.admin-content{padding:60px 40px 50px}.admin-actions{flex-direction:column;width:100%}.add-location-btn{width:100%;justify-content:center}.locations-table{min-width:600px}.locations-table th,.locations-table td{padding:.5rem;font-size:calc(var(--font-xs) - 1px)}.status-badge{padding:.125rem .5rem;font-size:calc(var(--font-xs) - 2px)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000a9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--bg-light);border-radius:15px;box-shadow:0 10px 30px #0000004d;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out;position:relative}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background-color:var(--bg-light-gray);border-radius:15px 15px 0 0}.modal-title{font-size:var(--font-xl);font-weight:600;color:var(--primary-color);margin:0}.modal-close-btn{background:var(--bg-light);border:none;color:var(--text-gray);cursor:pointer;padding:.5rem;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;position:absolute;right:32%;top:12%;transform:translateY(-7px) translate(5px);transition:all var(--transition-fast)}.modal-close-btn:hover{background-color:var(--danger-color);color:var(--bg-light)}.modal-form{padding:1rem 2rem 2rem}.form-section{margin-bottom:2rem}.form-section:last-of-type{margin-bottom:1rem}.section-title{font-size:var(--font-lg);font-weight:500;color:var(--primary-color);margin:40px 0 5px;padding-bottom:.5rem;border-bottom:1px solid var(--card-border)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column}.form-group label{font-size:var(--font-sm);font-weight:500;color:var(--text-dark);margin-bottom:.5rem;margin-top:1rem;margin-left:5px}.form-group input{padding:.75rem 1rem;border:1px solid var(--card-border);border-radius:8px;font-size:var(--font-sm);color:var(--text-gray);background-color:var(--bg-light);transition:all var(--transition-fast)}.form-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 1px #2563eb33}.form-group input.disabled{background-color:var(--bg-light-gray);color:var(--text-light-gray);cursor:not-allowed}.form-group input:disabled{background-color:var(--bg-light-gray);color:var(--text-light-gray);cursor:not-allowed}.error-message{display:flex;align-items:center;gap:.5rem;background-color:#ef44441a;color:var(--danger-color);padding:.75rem 1rem;border-radius:8px;font-size:var(--font-sm);margin-bottom:1rem;border:1px solid rgba(239,68,68,.3)}.error-message i{flex-shrink:0}.modal-actions{display:flex;justify-content:center;align-items:center;padding-top:1.2rem;border-top:1px solid var(--card-border);margin-bottom:-10px}.primary-actions{display:flex;gap:.75rem}.secondary-actions{display:flex;align-items:center}.cancel-btn,.save-btn,.delete-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:10px 1.25rem;border:none;width:110px;border-radius:10px;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.cancel-btn{background-color:var(--bg-light-gray);color:var(--text-gray);border:1px solid var(--card-border)}.cancel-btn:hover{background-color:var(--bg-light);border-color:var(--text-gray)}.save-btn{background-color:var(--primary-color);color:#fff}.save-btn:hover{background-color:var(--btn-hover)}.delete-btn{background-color:var(--danger-color);color:#fff;margin-left:.75rem}.delete-btn:hover{background-color:#dc2626}.cancel-btn:disabled,.save-btn:disabled,.delete-btn:disabled{opacity:.6;cursor:not-allowed}.delete-confirm{display:flex;align-items:center;gap:.75rem;font-size:var(--font-sm);color:var(--text-gray)}.delete-confirm-btn,.delete-cancel-btn{padding:.5rem .75rem;border:none;border-radius:6px;font-size:var(--font-xs);font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.delete-confirm-btn{background-color:var(--danger-color);color:#fff}.delete-confirm-btn:hover{background-color:#dc2626}.delete-cancel-btn{background-color:var(--bg-light-gray);color:var(--text-gray)}.delete-cancel-btn:hover{background-color:var(--bg-light)}.modal-form .fa-spin{animation:spin 1s linear infinite}@media (max-width: 768px){.modal-overlay{padding:1rem}.modal-content{max-height:95vh}.modal-header{padding:1rem 1.5rem}.modal-title{font-size:var(--font-lg)}.modal-form{padding:1.5rem}.form-row{grid-template-columns:1fr;gap:.75rem}.modal-actions{flex-direction:column;gap:1rem;align-items:stretch}.primary-actions,.secondary-actions{justify-content:center;width:100%}.delete-confirm{flex-direction:column;gap:.5rem;text-align:center}.delete-confirm>div{display:flex;gap:.5rem;justify-content:center}}@media (max-width: 480px){.modal-overlay{padding:.5rem}.modal-header,.modal-form{padding:1rem}.form-row{gap:.5rem}.form-group input{padding:.625rem .75rem;font-size:var(--font-xs)}.cancel-btn,.save-btn,.delete-btn{padding:.625rem 1rem;font-size:var(--font-xs)}.primary-actions{flex-direction:column;width:100%}.primary-actions button{width:100%;justify-content:center}}.admin-toast{position:fixed;bottom:15px;right:-350px;max-width:500px;min-width:350px;background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;transition:right .3s ease-in-out;z-index:1000;overflow:hidden;opacity:0}.admin-toast.visible{right:20px;opacity:1}.toast-content{display:flex;align-items:center;padding:15px 20px}.toast-content i{margin-right:15px;font-size:20px}.admin-toast.error i{color:#e74c3c}.admin-toast.success i{color:#2ecc71}.admin-toast.info i{color:#3498db}.admin-toast.confirm i{color:#f39c12}.toast-message{flex:1;font-size:14px;color:#333}.toast-close{background:none;border:none;cursor:pointer;font-size:16px;color:#95a5a6;padding:0;margin-left:15px}.toast-close i{margin:0 auto}.toast-close:hover{color:#7f8c8d}.toast-progress{height:3px;width:100%;background-color:#ecf0f1}.progress-bar{height:100%;transition:width .1s linear}.admin-toast.error .progress-bar{background-color:#e74c3c}.admin-toast.success .progress-bar{background-color:#2ecc71}.admin-toast.info .progress-bar{background-color:#3498db}.admin-toast.confirm .progress-bar{background-color:#f39c12}.toast-actions{display:flex;padding:0 20px 15px;gap:10px;justify-content:flex-end}.toast-actions button{padding:6px 12px;border-radius:4px;font-size:13px;cursor:pointer;border:none;font-weight:500}.toast-actions .confirm-btn{background-color:#e74c3c;color:#fff}.toast-actions .cancel-btn{background-color:#95a5a6;color:#fff}.toast-actions .confirm-btn:hover{background-color:#c0392b}.toast-actions .cancel-btn:hover{background-color:#7f8c8d}.admin-toast.error{border-left:4px solid #e74c3c}.admin-toast.success{border-left:4px solid #2ecc71}.admin-toast.info{border-left:4px solid #3498db}.admin-toast.confirm{border-left:4px solid #f39c12}.toast-container{position:fixed;top:0;right:0;z-index:1000;pointer-events:none}.toast-container .admin-toast{pointer-events:all;margin-bottom:10px}.admin-login{display:flex;align-items:center;justify-content:center;height:95vh;padding:2rem;background-color:var(--bg-off-white)}.admin-login-container{background-color:var(--bg-light);border-radius:15px;box-shadow:0 10px 30px #0000001a;width:500px;max-width:400px;padding:2.5rem;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.admin-login-header{text-align:center;margin-bottom:3rem}.admin-login-title{font-size:var(--font-2xl);font-weight:600;color:var(--primary-color);margin:0 0 .5rem}.admin-login-subtitle{font-size:var(--font-sm);color:var(--text-gray);margin:0}.admin-login-form{display:flex;flex-direction:column;gap:15px}.admin-login-form .form-group{display:flex;flex-direction:column}.admin-login-form .form-group label{font-size:var(--font-sm);font-weight:500;color:var(--text-dark);margin-bottom:.5rem;margin-left:5px}.admin-login-form .form-group input{padding:.875rem 1rem;border:1px solid var(--card-border);border-radius:10px;font-size:var(--font-sm);color:var(--text-gray);background-color:var(--bg-light);transition:all var(--transition-fast)}.admin-login-form .form-group input:focus{outline:none;border-color:var(--primary-color)}.admin-login-form .form-group input:disabled{background-color:var(--bg-light-gray);color:var(--text-light-gray);cursor:not-allowed}.login-btn{display:flex;align-items:center;justify-content:center;gap:.7rem;padding:.875rem 1.5rem;border:none;border-radius:10px;font-size:var(--font-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);background-color:var(--primary-color);color:#fff;margin-top:35px}.login-btn:hover:not(:disabled){background-color:var(--btn-hover)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-hint{display:flex;justify-content:center;margin-top:-5px;margin-bottom:-15px}.hint-btn{background:none;border:none;color:var(--text-light-gray);font-size:var(--font-xs);cursor:pointer;display:flex;align-items:center;gap:.25rem;padding:.5rem;border-radius:6px;transition:all var(--transition-fast)}.hint-btn:hover{color:var(--primary-color);background-color:var(--bg-light-gray)}.hint-btn i{font-size:var(--font-xs)}.login-btn .fa-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.admin-login{padding:1rem;min-height:60vh}.admin-login-container{padding:2rem 1.5rem;max-width:350px}.admin-login-title{font-size:var(--font-xl)}}@media (max-width: 480px){.admin-login{padding:.5rem}.admin-login-container{padding:1.5rem 1rem;max-width:300px}.admin-login-title{font-size:var(--font-lg)}.admin-login-form .form-group input{padding:.75rem;font-size:var(--font-xs)}.login-btn{padding:.75rem 1.25rem;font-size:var(--font-xs)}}
