@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&display=swap";:root{font-family:Montserrat,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}#homePageMain{position:relative;width:100vw;height:100vh;overflow:hidden;display:flex;justify-content:flex-start;align-items:stretch}#backgroundImageContainer{position:absolute;top:0;left:0;width:70%;height:100%;z-index:1;overflow:hidden}#backgroundImageContainer img{width:100%;height:100%;object-fit:cover}#backgroundImageContainer video{width:100%;height:100%;object-fit:cover}#formContainer{position:relative;z-index:2;width:35%;height:100%;margin-left:auto;background-color:#fff;border-top-left-radius:60px;border-bottom-left-radius:60px;box-shadow:-4px 0 20px #0000001a;display:flex;align-items:center;justify-content:center}.formBox{width:80%;max-width:400px;text-align:left}.logo{display:block;margin:0 auto 1.5rem;width:180px}h2{color:#4a7c2e;margin-bottom:.5rem;text-align:center}p{text-align:center;color:#555;font-size:.8rem;font-weight:500;margin-bottom:1.5rem}form{display:flex;flex-direction:column}input[type=email],input[type=password]{padding:10px 12px;margin-bottom:1rem;border:1px solid #ccc;border-radius:6px;font-size:1rem}a{display:block;text-align:center;color:#4a7c2e;text-decoration:none;font-size:.9rem}a:hover{text-decoration:underline}@media(max-width:992px){#formContainer{width:50%;border-radius:40px 0 0 40px}}@media(max-width:768px){#formContainer{position:static;width:100%;height:auto;border-radius:0;box-shadow:none}#backgroundImageContainer{position:relative;height:40vh}}.rounded-button{border:none;padding:10px 20px;border-radius:25px;font-size:1rem;cursor:pointer;margin-bottom:1rem;transition:all .3s ease}.rounded-button:hover{transform:translateY(-2px)}label{display:block;margin-bottom:6px;font-size:clamp(.85rem,.9vw,1.05rem);color:#171717;font-weight:500;letter-spacing:.3px;font-family:Montserrat,sans-serif}input[type=email],input[type=password]{width:100%;max-width:clamp(360px,30vw,520px);padding:clamp(10px,1vw,14px);margin-bottom:1.2rem;border:1px solid #737373;border-radius:8px;font-size:clamp(.85rem,.9vw,1rem);color:#171717;background-color:#fff;box-sizing:border-box;transition:all .25s ease;font-family:Montserrat,sans-serif}input[type=email]:focus,input[type=password]:focus{border-color:#4a7c2e;box-shadow:0 0 6px #4a7c2e59;outline:none}.link-button button{width:100%;max-width:clamp(360px,30vw,520px);padding:clamp(10px,1vw,14px);border-radius:8px;font-size:clamp(.9rem,1vw,1.05rem)}.navItem-main-div{display:flex;align-items:center;gap:12px;padding:12px 18px;margin:6px 0;border-radius:8px;cursor:pointer;transition:all .3s ease;color:#fff;position:relative;width:100%;box-sizing:border-box}.navItem-main-div:hover{background-color:#f5ffed}.navItem-main-div.selected{background-color:#e6f3de}.navItem-main-div.selected:before{content:"";position:absolute;left:0;top:0;width:6px;height:100%;background-color:#3b6625;border-top-right-radius:4px;border-bottom-right-radius:4px;transition:width .3s ease}.navItem-logo{width:25px;height:25px;object-fit:contain;margin-left:10px;transition:margin-left .3s ease,width .3s ease}.navItem-text{font-size:.65rem;font-weight:500;white-space:nowrap;color:#737373;opacity:1;transform:translate(0);transition:opacity .3s ease,transform .3s ease;flex-grow:1}#admin-sidebar-nav.collapsed .navItem-main-div{justify-content:center;padding:12px 8px;gap:0}#admin-sidebar-nav.collapsed .navItem-text{opacity:0;transform:translate(-10px);width:0;overflow:hidden}#admin-sidebar-nav.collapsed .navItem-logo{margin-left:0}#admin-sidebar-nav.collapsed .navItem-main-div.selected:before{width:4px}@media screen and (min-width:1536px){.navItem-main-div{gap:14px;padding:14px 20px}.navItem-logo{width:28px;height:28px}.navItem-text{font-size:.8rem}}@media screen and (min-width:1366px)and (max-width:1535px){.navItem-main-div{gap:10px;padding:12px 16px}.navItem-logo{width:24px;height:24px}.navItem-text{font-size:.7rem}}@media screen and (min-width:1024px)and (max-width:1365px){.navItem-main-div{gap:8px;padding:10px 14px}.navItem-logo{width:22px;height:22px}.navItem-text{font-size:.65rem}}@media screen and (max-width:1023px){.navItem-main-div{justify-content:flex-start;gap:6px;padding:10px;margin:4px 8px}.navItem-logo{width:22px;height:22px;margin-left:0}.navItem-text{display:block;font-size:.8rem}.navItem-main-div.selected:before{left:0;width:4px}}#admin-main-div{display:flex;flex-direction:row;width:100vw;height:100vh;margin:0;padding:0;overflow:hidden;background-color:#f5f6fa}#admin-sidebar-nav{width:20%;padding:20px;box-sizing:border-box;background-color:#fff;border-radius:12px;display:flex;flex-direction:column;position:relative;transition:width .3s ease;box-shadow:0 4px 12px #00000014}#brand-main-container{display:flex;flex-direction:row;justify-content:center;align-items:center;margin-bottom:2rem;margin-top:0;height:5rem}#cosmica-main{height:5rem;margin-left:10px}#cosmica-minimal{height:3rem}#admin-dashboard-content{flex:1;padding:0;background-color:#fff;overflow-y:auto;height:100%}#admin-sidebar-nav.collapsed{width:80px;transition:width .3s ease;align-items:center;padding:20px 10px}#admin-sidebar-nav{transition:width .3s ease}.sidebar-toggle-btn{position:absolute;top:17%;box-shadow:0 2px 8px #0000001a;right:-20px;transform:translateY(-50%);background-color:inherit;width:40px;display:flex;align-items:center;justify-content:center;border-radius:50px;cursor:pointer;z-index:100;transition:right .3s ease,transform .3s ease,background .3s ease}.sidebar-toggle-btn img{width:40px;height:40px;transition:transform .3s ease}#admin-sidebar-nav.collapsed .sidebar-toggle-btn img{transform:rotate(180deg)}@media screen and (min-width:1536px)and (max-width:1920px){#admin-sidebar-nav{width:18%;padding:24px}#admin-sidebar-nav.collapsed{width:90px}#cosmica-main{height:30px}#cosmica-minimal{height:3.5rem}.sidebar-toggle-btn img{width:65px;height:65px}}@media screen and (min-width:1366px)and (max-width:1535px){#admin-sidebar-nav{width:19%;padding:18px}#admin-sidebar-nav.collapsed{width:75px}#cosmica-main{height:22px}#cosmica-minimal{height:2.6rem}.sidebar-toggle-btn img{width:55px;height:55px}#brand-main-container{margin-bottom:1.5rem}}@media screen and (min-width:1024px)and (max-width:1365px){#admin-sidebar-nav{width:22%;padding:16px}#admin-sidebar-nav.collapsed{width:70px}#cosmica-main{height:20px}#cosmica-minimal{height:2.4rem}#brand-main-container{margin-bottom:1rem}.sidebar-toggle-btn img{width:50px;height:50px}}@media screen and (max-width:1023px){#admin-sidebar-nav{position:fixed;z-index:999;height:100vh;width:250px;left:0;top:0;padding:20px;transition:transform .3s ease;transform:translate(0)}#admin-sidebar-nav.collapsed{transform:translate(-100%)}.sidebar-toggle-btn{position:fixed;left:10px;top:20px;border-radius:8px;box-shadow:0 2px 8px #0000001a;right:auto}.sidebar-toggle-btn img{width:45px;height:45px}}#sidebar-bottom-logo{position:absolute;bottom:20px;left:0;right:0;display:flex;justify-content:center;align-items:center;padding:1rem;background-color:inherit}#admin-sidebar-nav{position:relative;min-height:100vh;display:flex;flex-direction:column}#navItem-main-container{flex:1;overflow-y:auto}#admin-sidebar-nav.collapsed #sidebar-bottom-logo{padding:.5rem}#sidebar-bottom-logo img{opacity:.7;transition:opacity .3s ease}#sidebar-bottom-logo img:hover{opacity:1}#master-header-main{display:flex;justify-content:space-around;align-items:center;width:100%;padding:.75rem 1.5rem;box-sizing:border-box;background-color:#fff;border-bottom:1px solid #1717171F;margin-bottom:1rem;flex-wrap:wrap}#master-header-text{flex:1;min-width:180px}#master-header-title{font-size:1.25rem;font-weight:600;color:#333;margin:0 0 .2rem;font-family:Montserrat,sans-serif;text-align:left}#master-header-description{font-size:.85rem;color:#777;margin:0;font-family:Montserrat,sans-serif;text-align:left}#master-header-buttons{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-end}@media(max-width:768px){#master-header-main{flex-direction:column;align-items:flex-start;padding:.75rem}#master-header-buttons{width:100%;justify-content:flex-start;margin-top:.75rem}#master-header-title{font-size:1.1rem}#master-header-description{font-size:.8rem}}#back-button-container{width:56px;height:40px;border-radius:8px;background-color:#eaffd8;display:flex;justify-content:center;align-items:center;margin-right:10px;cursor:pointer}.master-dashboard-button{display:inline-flex;align-items:center;justify-content:center;gap:6px;background-color:#4a7c2e;color:#fff;font-family:Montserrat,sans-serif;font-size:.85rem;font-weight:500;border:none;border-radius:8px;padding:7px 14px;cursor:pointer;transition:all .3s ease}.master-dashboard-button:hover{background-color:#3a6625;transform:translateY(-2px);box-shadow:0 2px 5px #0000001a}.master-dashboard-button:active{transform:translateY(0);box-shadow:none}.master-button-icon{width:16px;height:16px;object-fit:contain}.master-button-text{white-space:nowrap}@media(max-width:768px){.master-dashboard-button{font-size:.8rem;padding:6px 12px}.master-button-icon{width:14px;height:14px}}#chip-main-div{display:inline-flex;align-items:center;justify-content:center;border:1px solid #737373;border-radius:9999px;padding:.1rem .2rem;margin:.25rem;cursor:pointer;background-color:#fff;transition:all .3s ease;min-width:60px;-webkit-user-select:none;user-select:none}#chip-text{font-family:Montserrat,sans-serif;font-size:.7rem;font-weight:500;color:#737373;margin:0;text-align:center;padding:.3rem;white-space:nowrap}#chip-main-div:hover,#chip-main-div:active{background-color:#eaf5e7;transform:scale(1.03)}#chip-main-div.selected{background-color:#4a7c2e;border-color:#4a7c2e}#chip-main-div.selected #chip-text{color:#fff}#display-chips-sub-container{display:flex;flex-wrap:wrap;gap:.3rem}@media(max-width:768px){#chip-main-div{padding:.35rem .8rem}#chip-text{font-size:.85rem}}@media(max-width:480px){#chip-main-div{padding:.3rem .7rem;margin:.2rem}#chip-text{font-size:.8rem}}#display-chips-container{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0 0 1.8rem}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-container{background:#fff;border-radius:12px;width:500px;max-width:90%;padding:1.5rem;box-shadow:0 4px 15px #0000001a;animation:fadeIn .2s ease-in}.modal-header{display:flex;justify-content:space-between;align-items:center;color:#538d22}.modal-header p{color:#538d22;font-weight:600;font-size:larger}.close-btn{cursor:pointer}.checkbox-group{display:flex;align-items:center;flex-direction:row;gap:8px;margin-top:15px}.checkbox-group input[type=checkbox]{width:18px;height:18px;accent-color:#538d22;cursor:pointer}.add-zone-form{display:flex;flex-direction:column;gap:.7rem;background:#fff;border-radius:10px;font-family:Montserrat,sans-serif;padding:1rem}.form-group textarea{background-color:#fff!important}.add-zone-form-title{font-size:1.2rem;font-weight:600;color:#2d3e50;margin-bottom:.5rem}.add-zone-form-group{display:flex;flex-direction:column;gap:.2rem}.add-zone-form-group label{font-size:.85rem;font-weight:500;color:#444}.add-zone-form-group input{background-color:#fff;border:1px solid #bfbfbf;border-radius:12px;padding:6px 10px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.85rem;color:#737373;transition:all .25s ease;font-family:Montserrat,sans-serif;white-space:nowrap;min-height:34px;width:auto}.add-zone-form-group input:focus{border-color:#4a7c2e}.add-zone-form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1rem}.save-btn,.cancel-btn{padding:8px 14px;font-size:.9rem;border:none;border-radius:6px;cursor:pointer;transition:background .25s ease}.save-btn{background:#4a7c2e;color:#fff;width:100%}.save-btn:hover{background:#3d6a25}.cancel-btn{background:#f1f1f1;color:#333}.cancel-btn:hover{background:#e2e2e2}.custom-file-upload{display:flex;align-items:center;gap:.5rem;background-color:#fff;border:1px solid #bfbfbf;border-radius:12px;padding:9px 10px;font-family:Montserrat,sans-serif;position:relative;cursor:pointer;transition:border-color .25s ease}.custom-file-upload input[type=file]{position:absolute;opacity:0;pointer-events:none;width:0;height:0}.file-name{flex:1;font-size:.85rem;color:#737373;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.browse-btn{background-color:#4a7c2e;color:#fff;border:none;border-radius:8px;padding:6px 14px;font-size:.85rem;cursor:pointer;transition:background-color .25s ease}.browse-btn:hover{background-color:#3d6a25}.custom-file-upload:hover,.custom-file-upload:focus-within{border-color:#4a7c2e}.add-user-form{margin:0 auto;background-color:#fff;border-radius:16px;padding:1rem;font-family:Montserrat,sans-serif;color:#171717}.form-section h3{font-size:1rem;color:#1a1a1a;margin-bottom:.4rem;margin-top:0;font-weight:600}.form-row{display:flex;gap:2rem}.form-group{display:flex;flex-direction:column;margin-bottom:1rem;width:100%}.form-group.half{width:calc(50% - .75rem)}label{font-weight:500;font-size:.9rem;color:#171717;margin-bottom:.25rem}.form-section h3{font-size:1rem;color:#1a1a1a;margin-bottom:1rem;margin-top:0;font-weight:600;display:flex;align-items:center;gap:.5rem}.form-section h3:before{content:"";display:block;width:4px;height:16px;background-color:#538d22;border-radius:2px}.create-user-input{border:1px solid #737373;border-radius:8px;font-family:inherit;height:1.5rem;padding:10px 12px;font-size:.85rem;color:#333;background-color:#fff!important}textarea,select{border:1px solid #737373;border-radius:8px;font-family:inherit;padding:10px 12px;font-size:.85rem;color:#333}.required{color:red}.create-btn{width:100%;background-color:#538d22;color:#fff;border:none;border-radius:10px;padding:12px;font-size:1rem;font-weight:600;cursor:pointer}.create-btn:hover{background-color:#40701b}@media(max-width:1440px){.add-user-form{width:90%;padding:1.5rem}}@media(max-width:1024px){.form-row{flex-direction:column}.form-group.half{width:100%}}.yellow-container-compliance{border-radius:10px;display:flex;flex-direction:row;background-color:#fafff5;height:82px;padding:0 16px;justify-content:space-between;align-items:center}.yellow-container-compliance-content{display:flex;flex-direction:column;justify-content:center;text-align:left;flex:1}.yellow-container-compliance-content-header{font-size:14px;font-weight:500;margin:0;color:#171717;text-align:left}.yellow-container-compliance-content-advice{font-size:10px;color:#737373;margin:3px 0 0;line-height:1.2;text-align:left}.yellow-container-compliance-toggle{display:flex;justify-content:center;align-items:center;min-width:60px}.form-info-note{padding:15px 20px;margin-bottom:10px;background-color:#f0f7ff;border:1px solid #cce0ff;border-radius:8px;font-size:14px;line-height:1.5;color:#193cb8}.form-info-note .note-header{font-weight:700;color:#193cb8;margin-right:5px}.alert-days-container{padding:10px 0;color:#f0f0f0}.alert-days-label{display:block;color:#171717;margin-bottom:10px;font-size:14px;font-weight:500}.alert-input-wrapper{display:flex;align-items:center;gap:8px;margin-bottom:5px}.alert-days-input{width:80px;padding:0 12px;height:40px;background-color:#fff;border:1px solid #538D22;border-radius:8px;box-shadow:none;color:#171717;font-size:14px;text-align:center}.unit-label{font-size:14px;color:#737373}.alert-description{font-size:10px;color:#737373;width:fit-content}.dropdown-container{position:relative;width:160px;font-family:Montserrat,sans-serif}.dropdown-header{background-color:#fff;border:1px solid #bfbfbf;border-radius:6px;padding:8px 12px;display:flex;font-weight:600;align-items:center;justify-content:space-between;cursor:pointer;font-size:.65rem;color:#737373;transition:all .25s ease;height:13px}.dropdown-header:hover{border-color:#4a7c2e}.dropdown-arrow{transition:transform .25s ease;width:14px;height:14px}.dropdown-arrow.rotated{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:105%;left:0;width:100%;background-color:#fff;border:1px solid #e2e2e2;border-radius:6px;box-shadow:0 3px 6px #00000014;list-style:none;margin:0;padding:4px 0;z-index:20;animation:fadeIn .2s ease}.dropdown-item{padding:6px 12px;font-size:.8rem;cursor:pointer;color:#333;transition:background .2s ease,color .2s ease}.dropdown-item:hover{background-color:#ecf6e9}.dropdown-item.selected{background-color:#4a7c2e;color:#fff}@media(max-width:1024px){.dropdown-container{width:160px}.dropdown-header{font-size:.8rem;padding:7px 10px}.dropdown-item{font-size:.75rem;padding:5px 10px}}@media(max-width:768px){.dropdown-container{width:100%}.dropdown-header{font-size:.8rem;padding:7px 12px;height:34px}}@media(max-width:480px){.dropdown-container{width:100%}.dropdown-header{font-size:.75rem;padding:6px 10px;height:32px}.dropdown-item{font-size:.7rem;padding:5px 8px}}.dynamic-dropdown-wrapper{position:relative;display:inline-block;min-width:160px;max-width:100%;font-family:Montserrat,sans-serif}.dynamic-dropdown-header{background-color:#fff;border:1px solid #bfbfbf;border-radius:9px;padding:6px 10px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;font-size:.85rem;color:#444;transition:all .25s ease;white-space:nowrap;min-height:29px;width:auto}.dynamic-dropdown-header:hover{border-color:#4a7c2e}.dynamic-dropdown-arrow{transition:transform .25s ease;width:14px;height:14px;flex-shrink:0}.dynamic-dropdown-arrow.rotated{transform:rotate(180deg)}.dynamic-dropdown-menu{position:absolute;top:105%;left:0;min-width:100%;width:max-content;background-color:#fff;border:1px solid #e2e2e2;border-radius:6px;box-shadow:0 3px 6px #00000014;list-style:none;margin:0;padding:4px 0;z-index:20;animation:fadeIn .2s ease}.dynamic-dropdown-item{padding:6px 12px;font-size:.8rem;cursor:pointer;color:#333;transition:background .2s ease,color .2s ease;white-space:nowrap}.dynamic-dropdown-item:hover{background-color:#ecf6e9}.dynamic-dropdown-item.selected{background-color:#4a7c2e;color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.dynamic-dropdown-wrapper,.dynamic-dropdown-header{width:100%}}#dynamic-inline-search{border:none;outline:none;flex:1;font-size:.85rem}.add-shift-form{background:#fff;border-radius:12px;padding:16px;max-width:580px;font-family:Montserrat,sans-serif;box-shadow:0 2px 8px #0000000d}.add-shift-title{color:#2f7d32;font-size:1.3rem;font-weight:600;margin-bottom:4px;font-family:Montserrat,sans-serif}.add-shift-description{font-size:.9rem;color:#737373;margin-bottom:16px}.add-shift-form-group{margin-bottom:16px;display:flex;flex-direction:column}.add-shift-form-group label{font-size:.9rem;font-family:Montserrat,sans-serif;color:#555;margin-bottom:6px;font-weight:500}.add-shift-form-group input[type=text],.add-shift-form-group input[type=time]{background-color:#fff!important;border:1px solid #c9c9c9;border-radius:6px;padding:8px 12px;font-size:.9rem;color:#333!important;font-family:Montserrat,sans-serif;outline:none;transition:border-color .2s,box-shadow .2s}.add-shift-form-group input:-webkit-autofill{-webkit-box-shadow:0 0 0 1000px white inset!important;-webkit-text-fill-color:#333!important}.add-shift-form-group input:focus{border-color:#4a7c2e;box-shadow:0 0 4px #4a7c2e4d}input:checked+.slider{background-color:#4a7c2e}.add-shift-time-row{display:flex;gap:12px}.add-shift-form-group.half{flex:1}.add-shift-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.cancel-btn,.create-btn{border:none;border-radius:8px;padding:8px 16px;font-size:.9rem;cursor:pointer;transition:background .2s}.cancel-btn{background:#f3f3f3;color:#737373}.create-btn{background:#4a7c2e;color:#fff;font-weight:500}.add-route-form{background:#fff;border-radius:12px;padding:10px;max-width:620px;font-family:Montserrat,sans-serif}.add-route-form,.add-route-form *{font-family:inherit}.add-route-title{color:#2f7d32;font-size:1.3rem;font-weight:600;margin-bottom:4px}.add-route-description{font-size:.9rem;color:#555;margin-bottom:16px}.add-route-form-group{margin-bottom:16px;display:flex;flex-direction:column}.add-route-form-group label{font-size:.9rem;color:#333;margin-bottom:6px}.add-route-form-group input,.add-route-form-group textarea{border:1px solid #c9c9c9;border-radius:8px;padding:10px 12px;font-size:.9rem;color:#333;outline:none;transition:border-color .2s;background-color:#fff!important;resize:none;font-family:inherit}.add-route-form-group input:focus,.add-route-form-group textarea:focus{border-color:#4a7c2e}.required{color:red;margin-left:4px}.add-route-row{display:flex;gap:16px}.add-route-form-group.half{flex:1}.add-route-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.cancel-btn,.create-btn{border:none;border-radius:8px;padding:10px 16px;font-size:.9rem;cursor:pointer;font-family:inherit}.cancel-btn{background:#f3f3f3;color:#333}.create-btn{background:#4a7c2e;color:#fff;font-weight:500;width:100%;padding:12px}.create-btn:hover{background:#3a6324}@media(max-width:600px){.add-route-row{flex-direction:column}}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;overflow:auto}.modal-container{background:#fff;border-radius:12px;width:600px;max-width:90%;max-height:85vh;padding:1.4rem;box-shadow:0 4px 15px #0000001a;animation:fadeIn .2s ease-in;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;color:#538d22;margin-bottom:.75rem;flex-shrink:0}.modal-header p{color:#538d22;font-weight:600;font-size:1.1rem;margin:0}.close-btn{cursor:pointer;width:20px;height:20px}.modal-content{overflow-y:auto;flex-grow:1;padding-right:.3rem;max-height:calc(85vh - 60px)}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-thumb{background-color:#538d2280;border-radius:3px}.modal-content::-webkit-scrollbar-thumb:hover{background-color:#538d22b3}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}#allroutes-main-container{margin-top:15px;width:inherit;display:flex;flex-direction:column;gap:1.5rem;padding:.6rem 2rem;font-family:Montserrat,sans-serif}#allroutes-filter-container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.role-list-grid{display:flex;flex-direction:row;gap:1rem;flex-wrap:wrap}#role-content-container{display:flex;flex-direction:row;flex-wrap:wrap;gap:1.5rem}#allroutes-left-filters{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}#allroutes-searchbar{display:flex;justify-content:flex-end;flex:1;min-width:220px}#allroutes-content-container{background:#f9fafb;border-radius:8px;padding:1rem 1.5rem;font-size:.9rem;color:#333}@media(max-width:768px){#allroutes-main-container{padding:1rem}#allroutes-filter-container{flex-direction:column;align-items:flex-start}#allroutes-left-filters,#allroutes-searchbar{width:100%;justify-content:flex-start}#allroutes-content-container{font-size:.85rem}}.dynamic-table-container{width:100%;background-color:#fff;border-radius:8px;box-shadow:0 2px 6px #0000000d;overflow-x:auto;font-family:Montserrat,sans-serif;border:1px solid #538D22}.dynamic-table{width:100%;border-collapse:collapse;min-width:800px}.dynamic-table thead{background-color:#f5faef}.dynamic-table th{text-align:center;padding:12px 16px;font-size:.8rem;font-weight:500;color:#333;border-bottom:1px solid #e2e2e2}.dynamic-table td{text-align:center;padding:12px 16px;font-size:.7rem;color:#171717;border-bottom:1px solid #f0f0f0}.dynamic-table tr:hover{background-color:#f8fff4}.no-data{text-align:center;padding:20px;color:#999}.table-pagination{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-top:1px solid #eaeaea}.pagination-btn{background-color:#fff;border:1px solid #4a7c2e;color:#4a7c2e;font-family:Montserrat,sans-serif;font-weight:500;font-size:.9rem;border-radius:6px;padding:6px 14px;cursor:pointer;transition:all .3s ease}.pagination-btn:hover:not(:disabled){background-color:#4a7c2e;color:#fff}.pagination-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.dynamic-table th,.dynamic-table td{font-size:.8rem;padding:8px 10px}.pagination-btn{font-size:.8rem;padding:5px 10px}}.view-route-btn{background-color:#fff;color:#64803d;border:solid #538D22 1px}#allroutes-filter-container{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem}#allroutes-left-filters{display:flex;flex-wrap:wrap;gap:.5rem}#allroutes-searchbar{margin-left:auto}.edit-btn{background:#fff;border:1px solid #4a7c2e;color:#4a7c2e;padding:6px 12px;font-size:.85rem;border-radius:6px;cursor:pointer;transition:all .3s ease}.edit-btn:hover{background:#4a7c2e;color:#fff}@media(max-width:768px){#allroutes-filter-container{flex-direction:column;align-items:stretch}#allroutes-left-filters{flex-direction:column}#allroutes-searchbar{margin-left:0;width:100%}}@media screen and (min-width:1536px)and (max-width:1920px){.dynamic-table th,.dynamic-table td{font-size:.85rem;padding:14px 18px}.pagination-btn{font-size:.9rem;padding:8px 16px}}@media screen and (min-width:1366px)and (max-width:1535px){.dynamic-table th,.dynamic-table td{font-size:.8rem;padding:12px 16px}.pagination-btn{font-size:.85rem;padding:6px 14px}#allroutes-filter-container{gap:.75rem}}@media screen and (min-width:1024px)and (max-width:1365px){.dynamic-table-container{border-radius:6px}.dynamic-table th,.dynamic-table td{font-size:.75rem;padding:10px 12px}.pagination-btn{font-size:.8rem;padding:5px 10px}#allroutes-filter-container{flex-wrap:wrap;gap:.75rem}#allroutes-searchbar{width:240px}}@media screen and (min-width:768px)and (max-width:1023px){.dynamic-table{min-width:650px}.dynamic-table th,.dynamic-table td{font-size:.75rem;padding:8px 10px}.pagination-btn{font-size:.75rem;padding:5px 8px}#allroutes-filter-container{flex-direction:column;align-items:stretch;gap:.75rem}#allroutes-left-filters{flex-direction:column;gap:.5rem}#allroutes-searchbar{margin-left:0;width:100%}}@media screen and (max-width:767px){.dynamic-table-container{border-radius:0;box-shadow:none;border:none}.dynamic-table{min-width:600px}.dynamic-table th,.dynamic-table td{font-size:.7rem;padding:8px}.table-pagination{flex-direction:column;align-items:stretch;gap:.5rem}.pagination-btn{font-size:.7rem;padding:6px 8px;width:100%}#allroutes-filter-container{flex-direction:column;align-items:stretch}#allroutes-left-filters{flex-direction:column;width:100%}#allroutes-searchbar{width:100%;margin:0}}.role-badge{display:inline-block;padding:2px 10px;background-color:#f3e8ff;border-radius:16px;font-size:.75rem;font-weight:500;text-align:center;min-width:80px;white-space:nowrap}.role-badge:hover{background-color:#ddc3f9;transform:translateY(-1px);transition:all .2s ease}.role-badge.admin{background-color:#fdf6db}.role-badge.driver{background-color:#dbeafe}.role-badge.subadmin{background-color:#fce7f3}.toggle-row{flex-direction:row;justify-content:space-between;align-items:center}.switch{position:relative;display:inline-block;width:44px;height:22px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;background-color:#ccc;border-radius:22px;inset:0;transition:.3s}.slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.slider{background-color:#65b339}input:checked+.slider:before{transform:translate(22px)}.add-role-form{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;max-height:80vh}.form-title{font-size:1.4rem;font-weight:600;color:#333;border-bottom:1px solid #ddd;padding-bottom:.5rem}.form-group label{display:block;font-weight:500;margin-bottom:.3rem}.form-group input{width:100%;padding:.5rem;border-radius:8px;border:1px solid #ccc}.permissions-section{background:#fafafa;border-radius:10px;padding:1rem}.module-block{background:#fff;border:1px solid #e3e3e3;border-radius:10px;margin-bottom:1rem;padding:1rem}.module-header{display:flex;justify-content:space-between;align-items:center}.module-header p{font-size:.85rem;color:#666;margin-top:.2rem}.submodule-list{margin-top:.8rem;border-top:1px dashed #ddd;padding-top:.6rem;padding-left:1rem}.submodule-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.access-level-group{display:flex;gap:.5rem}.access-option{background:#f0f0f0;padding:.3rem .7rem;border-radius:6px;cursor:pointer;transition:background .2s ease;font-size:.9rem}.access-option input{display:none}.access-option.selected{background:#538d22;color:#fff}.access-option:hover{background:#386513}.form-actions{display:flex;justify-content:flex-end}.add-role-form,.permissions-section *{color:#000!important}.rolebox-container{display:flex;align-items:center;justify-content:space-between;width:fit-content;min-height:60px;padding:12px 20px;margin-bottom:15px;background-color:#fff;border-radius:16px;box-shadow:0 4px 12px #00000014;border:1px solid #f0f0f0;transition:box-shadow .2s ease-in-out,transform .2s ease-in-out}.rolebox-container:hover{box-shadow:0 6px 18px #0000001f;transform:translateY(-2px)}.rolebox-left{display:flex;align-items:center;margin-right:15px}.rolebox-icon{width:30px;height:30px}.rolebox-middle{flex-grow:1;text-align:left;min-width:100px}.rolebox-name{font-size:16px;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rolebox-right-button{background:none;border:none;cursor:pointer;padding:8px;margin-left:15px;border-radius:50%;transition:background-color .1s ease}.rolebox-right-button:hover{background-color:#f5f5f5}.rolebox-edit-icon{width:20px;height:20px;vertical-align:middle}.document-config-main-container{margin-top:15px;width:inherit;display:flex;justify-content:center;flex-direction:column;gap:.5rem;padding:.6rem 2rem;font-family:Montserrat,sans-serif}.document-title-action-row{display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap}.document-config-title p{font-size:1rem;font-weight:600;color:#333;margin:0}.searchbar-container{display:flex;align-items:center;border:1px solid #bfbfbf;border-radius:8px;padding:4px 8px;background-color:#fff;width:100%;height:28px;max-width:360px;transition:all .3s ease}.searchbar-container:focus-within{border-color:#4a7c2e;box-shadow:0 0 4px #4a7c2e33}.searchbar-input{border:none;outline:none;flex:1;font-size:.9rem;color:#333;font-family:Montserrat,sans-serif}.searchbar-input::placeholder{color:#999}.searchbar-icon{background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.searchbar-icon:hover svg{stroke:#4a7c2e}@media(max-width:768px){.searchbar-container{max-width:100%;padding:6px 10px}.searchbar-input{font-size:.85rem}}.vehicle-tag-container{display:flex;flex-wrap:wrap;gap:10px}.vehicle-tag-chip{padding:4px 15px;border-radius:20px;cursor:pointer;font-size:12px;transition:all .2s ease-in-out;display:flex;align-items:center;justify-content:center;background-color:transparent;border:1px solid #737373;color:#737373}.vehicle-tag-chip.selected{background-color:#f5ffed;border:1px solid #538D22;color:#538d22;font-weight:500;padding-right:10px}.remove-icon{margin-left:8px;width:16px;height:16px}.chip-tooltip-container{position:relative;display:inline-block;display:flex;justify-content:center;align-items:center}.chip-tooltip{visibility:hidden;background:#000;color:#fff;padding:4px 8px;border-radius:6px;font-size:12px;position:absolute;bottom:-32px;left:50%;transform:translate(-50%);white-space:nowrap;z-index:100}.chip-tooltip-container:hover .chip-tooltip{visibility:visible}.stat-card{padding:14px;width:205px;height:68px;border-radius:8px;cursor:pointer;transition:transform .25s ease-in-out;box-shadow:0 4px 8px -3px #00000014,0 2px 4px -2px #0000000a}.stat-card.hovered{transform:scale(1.03)}.gradient-default{background:linear-gradient(to right,#fff,#f9f9f9)}.gradient-indigo{background:linear-gradient(to right,#fff,#f7f8ff)}.gradient-green{background:linear-gradient(to right,#fff,#f4fff6)}.gradient-yellow{background:linear-gradient(to right,#fff,#fffceb)}.stat-card-content{display:flex;align-items:center;justify-content:space-between}.stat-card-icon{width:32px;height:32px;margin-bottom:45px;flex-shrink:0}.stat-card-details{display:flex;flex-direction:column;align-items:flex-end}.stat-card-text{font-size:10px;font-weight:600;color:#4b5563;text-transform:uppercase;letter-spacing:.03em;margin-bottom:2px}.stat-card-count{font-size:16px;font-weight:700;color:#1f2937;line-height:1}.driver-compliance-container{height:inherit;width:inherit}.stat-card-list{display:flex;flex-direction:row;flex-wrap:wrap;gap:10px;padding:10px;justify-content:flex-start;align-items:center}.driver-compliance-search-row{display:flex;justify-content:right}.searchbar-driver-compliance{width:400px}.veh-reg-main-container{width:inherit;height:inherit}#veh-reg-search-bar{display:flex;flex-direction:row;justify-content:flex-end;align-items:center;margin-right:10px;margin-bottom:1rem}#veh-reg-table{padding:10px 20px}.route-legends-container{width:180px;max-height:280px;position:absolute;top:15px;right:15px;background:#fff;border-radius:10px;box-shadow:0 4px 12px #0000001a;border:1px solid rgba(0,0,0,.08);z-index:1000;overflow:hidden;display:flex;flex-direction:column}.route-legends-header{padding:8px 10px;background:#f8f8f8;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;cursor:pointer}.route-legends-header h3{margin:0;font-size:12px;font-weight:600;color:#538d22}.legend-arrow.open{transform:rotate(180deg)}.route-legends-list{overflow-y:auto;padding:0}.route-legends-list::-webkit-scrollbar{width:4px}.route-legends-list::-webkit-scrollbar-thumb{background:#00000026;border-radius:10px}.route-legend-item-premium{display:flex;align-items:center;border-radius:0;background:#fff;margin:0;transition:all .1s ease;cursor:pointer;min-height:24px;border:none;border-bottom:1px solid #f0f0f0;overflow:hidden}.route-legend-item-premium:last-child{border-bottom:none}.route-legend-item-premium:hover{background:#f1f1f1;transform:none;box-shadow:none}.route-color-bar{width:26px;height:8px;border-radius:15px;margin-right:5px;margin-left:10px}.route-info{padding:4px 6px}.route-name-premium{font-size:11px;font-weight:500;color:#444}.vehicle-card{width:100%;max-width:440px;background-color:#fff;border-radius:10px;padding:14px;box-shadow:0 3px 6px #00000014;margin-bottom:16px;box-sizing:border-box;transition:all .25s ease}.vehicle-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 8px 18px #0000002e;cursor:pointer}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.header-info{display:flex;align-items:center}.vehicle-icon{font-size:24px;margin-right:8px}.vehicle-number{font-weight:700;font-size:15px;color:#333}.status-text{font-size:12px;font-weight:500;display:flex;align-items:center}.dot{width:6px;height:6px;border-radius:50%;background-color:#d9534f;margin-right:4px}.time-info{text-align:right;font-size:10px;color:#888}.last-updated{color:#4a5565;padding:4px;margin-bottom:2px;display:flex;flex-direction:row;justify-content:space-evenly;align-items:center;border-radius:10px;background-color:#f3f4f6}.stats-pills{display:flex;gap:6px;margin-bottom:14px}.stat-pill{padding:4px 2px;border-radius:16px;font-size:10px;font-weight:500;text-align:center;flex:1 1 0}.stat-pill.speed{background-color:#e6f0ff;color:#337ab7}.stat-pill.today-km{background-color:#e6ffe6;color:#5cb85c}.stat-pill.duration{background-color:#f0e6ff;color:#6a5acd}.icon-statuses{display:flex;justify-content:space-between;text-align:center;padding:10px 0;border-bottom:1px solid #eee;border-top:1px solid #eee;margin-bottom:10px}.icon-status{flex:1;display:flex;flex-direction:column;align-items:center}.icon{font-size:24px;margin-bottom:3px}.ignition-off{color:#d9534f}.strong-signal{color:#5cb85c}.device-on{color:#337ab7}.icon-status .label{font-size:10px;color:#555;font-weight:500}.location-section{background-color:#f8fdf4;padding:3px}.location-header{display:flex;align-items:center;color:#538d22;margin-bottom:4px;font-weight:500}.location-icon{font-size:16px;margin-right:4px}.location-label{font-size:14px}.location-text{font-size:12px;color:#364153;padding-left:20px}.card-row-container{display:flex;flex-wrap:wrap;gap:14px}.card-row-container>.vehicle-card{width:calc(50% - 7px);min-width:260px}@media(max-width:600px){.card-row-container>.vehicle-card{width:100%}}#vehicleStatus-main-container{width:inherit;display:flex;flex-direction:column;gap:1.5rem;padding:.6rem 2rem;font-family:Montserrat,sans-serif;display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px;margin-top:20px;align-items:start}.status-text.moving{color:#5cb85c}.dot.moving{background-color:#5cb85c}.status-text.parked{color:#d9534f}.dot.parked{background-color:#d9534f}.status-text.waiting{color:#f0ad4e}.dot.waiting{background-color:#f0ad4e}.since-text{font-size:8px;color:#888;margin-top:2px;line-height:1}.group-map-container{position:relative;width:100%;height:100vh;display:flex;flex-direction:column}.gm-style-iw{max-width:300px!important}.gm-style img{max-width:none}.group-map-header{flex-shrink:0}.group-google-map{width:100%;height:100%!important}.loader-overlay{position:absolute;inset:0;background:#ffffffd9;display:flex;justify-content:center;align-items:center;z-index:10;font-size:18px;color:#333;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.map-wrapper{position:relative;flex:1;width:100%}.map-filter-overlay{position:absolute;top:20px;z-index:1000;pointer-events:auto}.map-filter-overlay.left{left:20px}.map-filter-overlay.right{right:20px}.tripInsightWrapper{display:flex;flex-direction:column;padding:1px;gap:10px}.route-marker-toggle{display:flex;align-items:center;gap:70px;margin-top:15px}.route-marker-toggle p{margin:0;font-size:14px;font-weight:500;color:#333}.tripInsightBox{background:#f0fdf4;border:1px solid #e3e8f0;padding:12px;border-radius:20px;box-shadow:0 1px 2px #0000000a;display:flex;flex-direction:column;gap:8px}.tripInsightHeader{font-size:13px;font-weight:600;color:#4b5563;border-bottom:1px solid #d5d8dc;padding-bottom:6px}.tripInsightRow,.tripInsightMetric{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#6b7280}.tripInsightRow strong,.tripInsightMetric strong{font-weight:600;color:#111827}.tripInsightAddress{font-size:12.5px;color:#374151;padding:10px;border-radius:4px;line-height:1.4}.tripInsightEmpty{padding:16px;text-align:center;color:#9ca3af;font-size:13px}.filter-container{width:280px;background:#fff;border-radius:10px;box-shadow:0 3px 15px #0000001f;padding:16px;transition:all .3s ease;max-height:calc(70vh - 10px);overflow-y:auto;overflow-x:hidden}.filter-container::-webkit-scrollbar{width:4px}.filter-container::-webkit-scrollbar-track{background:transparent}.filter-container::-webkit-scrollbar-thumb{background-color:#4d8123;border-radius:6px}.filter-container::-webkit-scrollbar-thumb:hover{background-color:#3f6d1c}.filter-container{scrollbar-width:thin;scrollbar-color:#4d8123 transparent}.filter-container.collapsed{width:200px;padding:12px}.filter-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;cursor:pointer;-webkit-user-select:none;user-select:none;padding-bottom:12px;border-bottom:1px solid #E5E7EB}.filter-container.collapsed .filter-header{margin-bottom:0;padding-bottom:0;border-bottom:none}.icon-text{display:flex;align-items:center;gap:10px}.header-title{font-size:14px;font-weight:600;color:#538d22;margin:0;line-height:1.2}.toggle-icon{width:14px;height:14px;transition:transform .3s ease;filter:invert(27%) sepia(51%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%)}.filter-container.collapsed .toggle-icon{transform:rotate(180deg)}.input-group{margin-bottom:16px}.label-vehicle{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.date-group{margin-bottom:16px}.date-label{display:block;font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}.required{color:#ef4444}.date-input-container{position:relative;width:100%}.date-input-container input{width:100%;height:38px;padding:8px 10px 8px 36px;border:1px solid #D1D5DB;border-radius:6px;font-size:13px;color:#1f2937;background:#fff;transition:all .2s ease;box-sizing:border-box}.date-input-container input:hover{border-color:#9ca3af;cursor:pointer}.date-input-container input:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px #3b82f61a}.calendar-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;pointer-events:none;filter:invert(27%) sepia(51%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%)}.button-group{display:flex;gap:10px;margin-top:20px}.reset-button,.view-button{flex:1;height:36px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;justify-content:center}.reset-button{background:#fff;color:#6b7280;border:1px solid #D1D5DB}.reset-button:hover{background:#f9fafb;border-color:#9ca3af}.reset-button:active{background:#f3f4f6}.view-button{background:#538d22;color:#fff}.view-button:hover{background:linear-gradient(135deg,#538d22,#4d8123)}.checkbox-group{margin-top:16px;padding-top:16px;border-top:1px solid #E5E7EB}.checkbox-option{display:flex;align-items:center;gap:8px;margin-bottom:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-option:last-child{margin-bottom:0}.checkbox-option input[type=checkbox]{width:14px;height:14px;accent-color:#EF4444;cursor:pointer}.checkbox-option label{font-size:13px;color:#4b5563;cursor:pointer}@media(max-width:768px){.map-filter-overlay{position:relative;top:0;left:0;margin:16px auto;width:95%}.filter-container{width:100%;max-width:280px;margin:0 auto}.filter-container.collapsed{width:100%;max-width:200px}}@media(max-width:480px){.filter-container{width:100%;max-width:220px;padding:12px}.filter-container.collapsed{max-width:180px;padding:10px}.header-title{font-size:14px}.history-icon{width:18px;height:18px}}.playback-controls{margin-top:0}.playback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;color:#545454}.point-counter{font-size:12px;color:#6b7280;background:#f3f4f6;padding:4px 8px;border-radius:4px;font-weight:400}.playback-buttons{display:flex;justify-content:center;align-items:center;gap:12px;margin-bottom:16px}.playback-button{background-color:#e9e9e9}.control-button{width:40px;height:40px;border-radius:8px;border:none;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.control-button:hover:not(:disabled){background:#f9fafb;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.control-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #0000001a}.control-button:disabled{opacity:.5;cursor:not-allowed;background:#f3f4f6}.control-button img{width:18px;height:18px;filter:invert(27%) sepia(51%) saturate(2878%) hue-rotate(346deg) brightness(104%) contrast(97%)}.play-button.playing{background:#ef4444}.play-button.playing img{filter:brightness(0) invert(1)}.play-button.playing:hover:not(:disabled){background:#dc2626}.playback-info{margin-top:12px}.speed-control{display:flex;align-items:center;justify-content:space-between}.speed-control label{font-size:12px;color:#6b7280;font-weight:500}.speed-select{width:70px;height:32px;padding:4px 8px;border:1px solid #D1D5DB;border-radius:6px;background:#fff;font-size:12px;color:#374151;cursor:pointer;transition:all .2s ease}.speed-select:hover{border-color:#9ca3af}.speed-select:focus{outline:none;border-color:#000;box-shadow:0 0 0 2px #3b82f61a}@media(max-width:768px){.playback-buttons{gap:10px}.control-button{width:36px;height:36px}.control-button img{width:16px;height:16px}.playback-title{font-size:12px}.point-counter{font-size:11px}}.speed-pill{min-width:42px;height:26px;padding:0 8px;border-radius:6px;font-size:12px;font-weight:600;color:#374151;background:#f3f4f6;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.speed-pill:hover{background:#e5e7eb}.speed-pill.active{background:#4d8123;color:#fff}.playback-progress{width:100%;height:7px;background-color:#e5e7eb;border-radius:4px;margin-top:8px;overflow:hidden}.playback-progress-fill{height:100%;background-color:#4d8123;width:0%;border-radius:4px;transition:width .25s linear}.playback-progress-fill{transition:width .15s linear}.point-stats{display:flex;flex-direction:column;gap:6px;font-size:12px;margin-top:5px}.point-stats .stat-row{display:flex;justify-content:space-between;gap:8px;color:#000}.point-stats strong{color:#1f2937}.address-text{max-width:140px;text-align:right;font-size:11px;color:#4d8123}.accordion__header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:10px;border-radius:6px;transition:background-color .2s ease;color:#0f5a15;margin-top:10px}.accordion__header:hover{background-color:#f3f4f6}.accordion__header:active{background-color:#e5e7eb}.accordion__title-container{display:flex;align-items:center;font-size:14px;gap:6px;margin:0}.accordion__title-container h3{font-size:12px;font-weight:600;color:#374151;margin:0}.accordion__content-wrapper{margin-top:8px}.accordion__toggle-icon{width:8px;height:8px;border-right:2px solid #6B7280;border-bottom:2px solid #6B7280;transform:rotate(45deg);transition:transform .2s ease,border-color .2s ease}.accordion__header:hover .accordion__toggle-icon{border-color:#4d8123}.accordion__toggle-icon.is-open{transform:rotate(-135deg)}.accordion__toggle-icon.is-closed{transform:rotate(45deg)}:root{--color-primary: #4f46e5;--color-success: #10b981;--color-idle: #f97316}.vli-compact-card{width:240px;background:#fff;border:1px solid #e0e7ff;border-radius:10px;box-shadow:0 4px 10px #0000001a;overflow:hidden;padding:0;font-family:Inter,Segoe UI,sans-serif}.vli-header-top{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background-color:#f8faff;border-bottom:1px solid #eef2ff}.vehicle-title-group{display:flex;align-items:center}.vehicle-icon{font-size:18px;margin-right:5px}.vehicle-number-text{font-size:14px;font-weight:700;margin:0;color:var(--color-primary)}.status-pill{font-size:10px;font-weight:700;padding:3px 7px;border-radius:15px;text-transform:uppercase;letter-spacing:.2px}.status-running{color:var(--color-success);background-color:#d1fae5}.status-idle{color:var(--color-idle);background-color:#ffe8d7}.vli-data-grid-compact{display:grid;grid-template-columns:1.3fr .85fr .85fr;gap:8px 4px;padding:10px 10px 8px}.data-item{display:flex;flex-direction:column;text-align:center}.speed-focus{grid-column:1 / 2;background-color:#f0f4ff;border-radius:4px;padding:4px 0}.data-label{font-size:9px;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:1px}.data-value-speed{font-size:18px;font-weight:900;color:var(--color-primary);line-height:1.1}.data-value-dense{font-size:11px;font-weight:700;color:#374151}.data-unit{font-size:9px;font-weight:600;color:#6b7280;margin-left:2px}.timestamp-item-compact{grid-column:1 / 4;text-align:center;padding-top:5px;border-top:1px dotted #e5e7eb}.data-value-timestamp{font-size:11px;font-weight:600;color:#4b5563}.vli-address-footer-compact{padding:8px 12px 10px;background-color:#fafbfd;border-top:1px solid #eef2ff}.address-label{display:block;font-size:10px;font-weight:700;color:#4b5563;margin-bottom:2px}.address-text-compact{font-size:11px;color:#4b5563;line-height:1.3;margin:0;max-height:28px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-overlay-close{position:absolute;top:6px;right:6px;font-size:13px;cursor:pointer;color:#94a3b8;padding:4px;line-height:1;z-index:1001}.map-overlay-close:hover{color:#1e293b}.route-detail-box{width:100%;max-height:55vh;padding:8px 4px;box-sizing:border-box;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#d1d5db #f3f4f6}.route-detail-box::-webkit-scrollbar{width:4px}.route-detail-box::-webkit-scrollbar-track{background:#f3f4f6;border-radius:4px}.route-detail-box::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.route-empty{font-size:13px;color:#6b7280;text-align:center;padding:24px 16px;background:#f9fafb;border-radius:12px;border:1.5px dashed #e5e7eb;margin:4px 0}.route-empty:before{content:"📍";display:block;font-size:20px;margin-bottom:8px;opacity:.5}.route-card{background:linear-gradient(to bottom right,#fff,#fcfcfd);border-radius:12px;padding:12px;margin-bottom:8px;border:1px solid #f1f5f9;box-shadow:0 1px 3px #0000000a,0 1px 2px #00000008;transition:all .2s ease;position:relative;overflow:hidden}.route-text{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.route-name{font-weight:600;font-size:13px;line-height:1.3;color:#111827;padding:2px 0;position:relative;display:flex;align-items:center}.route-name:after{content:"→";margin-left:6px;font-size:12px;color:#9ca3af;opacity:0;transition:opacity .2s ease,transform .2s ease}.route-card:hover .route-name:after{opacity:1;transform:translate(2px)}.route-chips{display:flex;gap:4px;flex-wrap:wrap;margin-top:6px;margin-bottom:6px}.chip{font-size:10px;padding:3px 8px;border-radius:16px;font-weight:500;white-space:nowrap;border:1px solid transparent;transition:all .2s ease}.chip:hover{transform:scale(1.05)}.chip-zone{background:linear-gradient(135deg,#e0f2fe,#dbeafe);color:#1e40af;border-color:#93c5fd}.chip-ward{background:linear-gradient(135deg,#ecfeff,#d1fae5);color:#065f46;border-color:#5eead4}.chip-shift{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-color:#fcd34d}.route-info{font-size:11.5px;color:#4b5563;padding:6px 0;margin:6px 0;border-top:1px solid #f3f4f6;display:flex;align-items:center;gap:6px}.route-info:before{content:"";width:12px;height:12px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%236b7280'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 010-5 2.5 2.5 0 010 5z'/%3E%3C/svg%3E");background-size:contain;opacity:.7}.route-toggles{display:grid;grid-template-columns:1fr;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid #f3f4f6}.toggle-row{display:flex;flex-direction:column;justify-content:space-between;align-items:center;padding:6px 8px;background:#f9fafb;border-radius:8px;transition:background-color .2s ease}.toggle-row:hover{background:#f3f4f6}.toggle-label{font-size:12px;color:#374151;font-weight:500;display:flex;align-items:center;gap:6px}.toggle-label:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}.toggle-row:first-child .toggle-label{color:#3b82f6}.toggle-row:last-child .toggle-label{color:#10b981}@media(min-width:640px){.route-toggles{grid-template-columns:repeat(2,1fr);gap:12px}.toggle-row{padding:8px 10px}}.route-detail-box:empty{display:none}.route-card:last-child{margin-bottom:0}.route-card:active{transform:scale(.99)}.route-card.skeleton .route-name,.route-card.skeleton .chip,.route-card.skeleton .route-info,.route-card.skeleton .toggle-label{color:transparent;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s infinite;border-color:#f0f0f0}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.route-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer}.expand-icon{font-size:14px;color:#9ca3af}.route-card.expanded{border-color:#dbeafe}:root{--color-leaf-green: #38a169;--color-compost-brown: #92400e;--color-neutral-bg: #f9fdfa;--color-card-bg: #ffffff;--color-text-dark: #1f2937;--color-text-medium: #4b5563;--color-border-subtle: #d1fae5}.checkpoint-infowindow{background:var(--color-card-bg);border-radius:16px;padding:14px 16px;min-width:220px;max-width:280px;border:1px solid var(--color-border-subtle);box-sizing:border-box;overflow:hidden}.checkpoint-header{display:flex;gap:10px;align-items:center;margin-bottom:12px}.checkpoint-icon{font-size:16px;background:linear-gradient(45deg,var(--color-leaf-green),#48bb78);color:var(--color-card-bg);width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center}.checkpoint-title{font-size:14px;font-weight:700;color:var(--color-text-dark);line-height:1.2}.checkpoint-subtitle{font-size:11px;color:var(--color-leaf-green);font-weight:500;margin-top:2px}.checkpoint-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.meta-chip{font-size:10px;padding:4px 8px;border-radius:999px;font-weight:600;white-space:nowrap;text-transform:uppercase;max-width:100%;overflow:hidden;text-overflow:ellipsis}.meta-chip.time{background-color:#fef3c7;color:var(--color-compost-brown);border:1px solid var(--color-compost-brown)}.meta-chip.type{background-color:var(--color-leaf-green);color:var(--color-card-bg);border:1px solid var(--color-leaf-green)}.checkpoint-footer{display:flex;justify-content:space-between;font-size:11px;color:var(--color-text-medium);padding-top:10px;border-top:2px solid #f3f4f6}.gm-style .checkpoint-infowindow{max-width:280px!important}.option-bar-main-container{display:flex;background-color:#f7f7f7;border:1px solid #73b84b;border-radius:12px;width:fit-content}.geofence-option{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:8px;cursor:pointer;background-color:transparent;transition:background-color .2s ease,transform .1s ease}.geofence-option .option-icon{width:1rem;height:1rem}.geofence-option:hover{background-color:#73b84b1a;transform:translateY(-1px)}.geofence-option:active{transform:scale(.95)}.option-icon{width:32px;height:32px;object-fit:contain}@media(max-width:768px){.option-bar-main-container{gap:8px;padding:8px}.drawing-hint{font-size:12px;padding:6px 8px}.option-icon{width:28px;height:28px}}.popup-main-container{display:flex;justify-content:center;align-items:center;background-color:#ecebeb;border-radius:50px;padding:4px;width:fit-content;max-width:100%;margin:0 auto}.popup-sub-container{display:flex;align-items:center;justify-content:space-between;background-color:#538d22;border-radius:40px;padding:6px 14px;color:#fff;gap:12px;width:fit-content;max-width:100%;box-sizing:border-box}.popup-icon{width:22px;height:22px;flex-shrink:0}.popup-text{text-align:center;font-size:15px;font-weight:500;color:#fff;margin:0;display:flex;align-items:center;justify-content:center;white-space:nowrap;padding:0 4px}.geofence-action-button{background-color:#ffffff40;border:1px solid rgba(255,255,255,.4);color:#f5ffed;font-weight:500;border-radius:20px;padding:4px 14px;cursor:pointer;font-size:14px;transition:all .2s ease-in-out;white-space:nowrap;margin:0 2px}.geofence-action-button:hover{background-color:#fff;color:#538d22}@media(max-width:768px){.popup-main-container{padding:6px}.popup-sub-container{flex-wrap:wrap;justify-content:center;text-align:center;padding:8px 10px;gap:10px;border-radius:30px}.popup-text{font-size:14px;line-height:1.3;flex-basis:100%;white-space:normal}.geofence-action-button{padding:5px 12px;font-size:13px}.popup-icon{width:20px;height:20px}}.geofence-map-wrapper{position:relative;width:100%;height:85vh}.geofence-option-bar{position:absolute;top:15px;right:20px;z-index:10;border-radius:10px;padding:8px 12px}.geofence-item{display:flex;align-items:flex-start;justify-content:space-between;padding:10px;border:1px solid #d1d5db;border-radius:12px;margin-bottom:8px;background-color:#fff;color:#374151;gap:8px;cursor:pointer}.geofence-logo{flex:0 0 40px;display:flex;height:60px;align-items:center;justify-content:center}.geofence-logo img{width:32px;height:32px}.geofence-main-info{flex:1;min-width:0}.geofence-main-info .name-row{margin-bottom:4px}.geofence-main-info .name-row h3{margin:0;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.geofence-main-info .details-row{margin-bottom:4px;font-size:12px;color:#6b7280;display:flex;flex-wrap:wrap;gap:8px}.geofence-main-info .details-row span{white-space:nowrap}.geofence-main-info .tag-type-row{font-size:11px;margin-top:6px;display:flex;flex-wrap:wrap;gap:6px}.geofence-tag{background-color:#3b82f620;padding:3px 8px;border-radius:6px;color:#3b82f6;white-space:nowrap}.geofence-type{padding:3px 8px;border-radius:6px;color:#000;font-weight:500;white-space:nowrap}.geofence-actions{flex:0 0 30px;display:flex;justify-content:flex-end}.geofence-actions .delete-btn{border:none;background:transparent;cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s}.geofence-actions .delete-btn:hover{background-color:#f3f4f6}.geofence-actions .delete-btn img{width:16px;height:16px}@media(max-width:480px){.geofence-item{padding:8px;border-radius:10px;gap:6px}.geofence-logo{flex:0 0 32px;height:50px}.geofence-logo img{width:24px;height:24px}.geofence-main-info .name-row h3{font-size:13px}.geofence-main-info .details-row{font-size:11px;gap:6px}.geofence-main-info .tag-type-row{font-size:10px;gap:4px}.geofence-tag,.geofence-type{padding:2px 6px}.geofence-actions{flex:0 0 24px}.geofence-actions .delete-btn img{width:14px;height:14px}}@media(max-width:360px){.geofence-main-info .details-row{flex-direction:column;gap:2px}.geofence-item{flex-wrap:wrap}.geofence-actions{flex:0 0 100%;justify-content:flex-end;margin-top:4px}}.gf-side-modal{position:fixed;top:0;right:-400px;width:400px;height:100vh;background-color:#fff;border-top-left-radius:14px;border-bottom-left-radius:14px;box-shadow:-2px 0 8px #0003;display:flex;flex-direction:column;transition:right .3s ease;z-index:1000;overflow:hidden}.gf-side-modal.open{right:0}.gf-side-modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #ddd}.gf-side-modal-title{margin:0;font-size:18px;font-weight:600}.gf-side-close-btn{border:none;background:transparent;cursor:pointer;padding:0}.gf-side-modal-body{flex:1;overflow-y:auto;padding:12px 16px}.gf-side-modal-body::-webkit-scrollbar{width:8px}.gf-side-modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.gf-side-modal-body::-webkit-scrollbar-thumb{background-color:#4caf50;border-radius:4px}.confirmation-modal-container{width:inherit;border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:20px}.confirmation-modal-image-container h1{font-size:18px;font-weight:700;text-align:center;color:#171717}.confirmation-modal-action-container{display:flex;gap:10px;width:100%}.confirmation-cancel-btn,.confirmation-save-btn{width:50%;padding:12px 0;border:none;border-radius:32px;font-size:15px;cursor:pointer;font-weight:500}.confirmation-cancel-btn{background:#e5e7eb}.confirmation-cancel-btn:hover{background:#d1d5db}.confirmation-save-btn{background:#538d22;color:#fff}.confirmation-save-btn:hover{background:#3d6918}.confirmation-modal-video-container{height:100%;width:100%;display:flex;justify-content:center;align-items:center;overflow:hidden}.confirmation-modal-video{width:90%;height:100%;object-fit:cover}@media(max-width:480px){.confirmation-modal-container{width:90%}}.upload-excel-container{max-width:500px;margin:0 auto;padding:20px;font-family:Arial,sans-serif}.download-section{text-align:center;margin-bottom:20px}.download-template-btn{background-color:#538d22;color:#fff;border:none;padding:12px 24px;border-radius:12px;font-size:16px;cursor:pointer;transition:background-color .3s}.download-template-btn:hover{background-color:#417119}.download-template-btn:disabled{background-color:#6c757d;cursor:not-allowed}.or-separator{display:flex;align-items:center;text-align:center;margin:10px 0;color:#6c757d}.or-separator:before,.or-separator:after{content:"";flex:1;border-bottom:1px solid #dee2e6}.or-separator span{padding:0 15px;font-weight:700}.upload-section{text-align:center}.upload-area{border:2px solid #538D22;border-radius:12px;padding:10px 20px;cursor:pointer;transition:all .3s ease;background-color:#fbfff8;margin-bottom:20px}.upload-area.has-file{border-color:#17722c;background-color:#f0fff4}.upload-icon{width:50px;height:50px}.upload-text{color:#000}.drag-text{font-size:16px;margin-bottom:8px;font-weight:500}.browse-text{font-size:14px;color:#538d22;font-weight:500}.file-selected{font-size:14px;margin-bottom:5px;color:#538d22}.file-name{font-size:16px;font-weight:600;color:#495057;word-break:break-all}.action-buttons{display:flex;gap:12px;justify-content:center}.cancel-btn-excel,.upload-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .3s;min-width:100px}.cancel-btn-excel{color:#000;border:#538D22 solid 1px;border-radius:8px;background-color:#fff}.cancel-btn:hover:not(:disabled){background-color:#5a6268}.upload-btn{background-color:#538d22;color:#fff}.upload-btn:hover:not(:disabled){background-color:#218838}.cancel-btn:disabled,.upload-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.upload-excel-container{padding:15px}.upload-area{padding:30px 15px}.action-buttons{flex-direction:column}.cancel-btn,.upload-btn{width:100%}}
