:root{color-scheme:light;font-family:Arial,sans-serif;--bca-blue: #005baa;--bca-blue-dark: #014782;--bca-blue-soft: #e9f2fb;--page-bg: #ffffff;--panel-border: #d9e2ec;--text-main: #1f2933;--text-soft: #52606d;--sidebar-width: 280px;--topbar-height: 64px}*{box-sizing:border-box}body{margin:0;background:var(--page-bg);color:var(--text-main)}body.locked{overflow:hidden}body.locked .app-shell{display:none}body.modal-open{overflow:hidden}body.sidebar-collapsed .sidebar{width:88px}body.sidebar-collapsed .sidebar-label,body.sidebar-collapsed .sidebar-brand-copy,body.sidebar-collapsed .sidebar-section-title,body.sidebar-collapsed .sidebar-meta,body.sidebar-collapsed .sidebar-profile-name,body.sidebar-collapsed .sidebar-profile-role,body.sidebar-collapsed .sidebar-footer button span{display:none}body.sidebar-collapsed .sidebar-footer button{justify-content:center}body.sidebar-collapsed .sidebar-menu-button{justify-content:center;padding-inline:0}body.sidebar-collapsed .app-main{margin-left:88px}.app-shell{min-height:100vh;background:linear-gradient(180deg,#f7fbff,#fff 26%)}.sidebar{position:fixed;inset:0 auto 0 0;width:var(--sidebar-width);background:linear-gradient(180deg,var(--bca-blue) 0%,var(--bca-blue-dark) 100%);color:#fff;display:flex;flex-direction:column;z-index:10;transition:width .18s ease;box-shadow:10px 0 30px #01478226}.sidebar-brand{display:flex;align-items:center;gap:14px;padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.14)}.sidebar-brand-mark{width:44px;height:44px;border-radius:14px;background:#ffffff29;display:grid;place-items:center;font-weight:700;letter-spacing:1px}.sidebar-brand-copy strong{display:block;font-size:16px}.sidebar-brand-copy span{display:block;margin-top:2px;font-size:12px;color:#ffffffb8}.sidebar-profile{margin:16px;padding:14px;border-radius:18px;background:#ffffff1f}.sidebar-profile-name{font-size:14px;font-weight:700}.sidebar-profile-role{margin-top:4px;font-size:12px;color:#ffffffb8}.sidebar-nav{flex:1;overflow:auto;padding:4px 12px 16px}.sidebar-section+.sidebar-section{margin-top:14px}.sidebar-section-title{padding:8px 12px;font-size:11px;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:#ffffff9e}.sidebar-menu-list{display:grid;gap:6px}.sidebar-menu-button{width:100%;border:0;border-radius:14px;background:transparent;color:#fff;display:flex;align-items:center;gap:12px;padding:11px 14px;font-size:14px;cursor:pointer;text-align:left;transition:background .14s ease,transform .14s ease}.sidebar-menu-button:hover,.sidebar-menu-button.active{background:#ffffff29;transform:translate(2px)}.sidebar-icon{width:18px;text-align:center;font-size:16px;flex:0 0 18px}.sidebar-meta{margin-left:auto;font-size:11px;color:#ffffffb8}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.14)}.sidebar-footer button{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:14px;background:#fff;color:var(--bca-blue);padding:12px 14px;font-weight:700;cursor:pointer}.app-main{margin-left:var(--sidebar-width);transition:margin-left .18s ease}.topbar{position:sticky;top:0;z-index:1010;height:var(--topbar-height);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 22px;background:#fffffff0;border-bottom:1px solid #e4edf5;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-left{display:flex;align-items:center;gap:14px}.burger{width:42px;height:42px;border:1px solid #d7e7f5;background:#fff;border-radius:12px;display:grid;place-items:center;cursor:pointer;color:var(--bca-blue);font-size:18px}.topbar-title strong{display:block;font-size:17px;color:var(--bca-blue-dark)}.topbar-title span{display:block;margin-top:2px;font-size:12px;color:var(--text-soft)}.topbar-right{display:flex;align-items:center;gap:20px}.header-info{display:flex;flex-direction:column;align-items:flex-end;gap:2px;text-align:right}.header-greeting{font-size:14px;font-weight:700;color:var(--bca-blue-dark)}.header-clock{font-size:12px;color:var(--text-soft);font-weight:500;font-variant-numeric:tabular-nums}.profile-menu-wrap{position:relative}.profile-trigger{border:1px solid #d7e7f5;background:#fff;border-radius:16px;display:flex;align-items:center;gap:12px;padding:8px 12px;color:var(--bca-blue-dark);cursor:pointer;min-width:220px;justify-content:space-between;box-shadow:0 8px 24px #03487b14}.profile-trigger-main{display:flex;align-items:center;gap:10px;min-width:0}.profile-avatar{width:38px;height:38px;border-radius:999px;background:linear-gradient(135deg,#0f5fa8,#3b92dd);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700;flex:0 0 38px}.profile-trigger-text{min-width:0;text-align:left}.profile-trigger-name{display:block;font-size:14px;font-weight:700;color:var(--bca-blue-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-trigger-email{display:block;margin-top:2px;font-size:12px;color:var(--text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-trigger-caret{color:var(--text-soft);font-size:12px}.profile-dropdown{position:absolute;top:calc(100% + 12px);right:0;width:290px;background:#fff;border:1px solid #dbe7f2;border-radius:18px;box-shadow:0 24px 60px #0f172a2e;overflow:hidden;display:none;z-index:1020}.profile-dropdown.active{display:block}.profile-dropdown-header{display:flex;align-items:center;gap:12px;padding:18px;background:linear-gradient(180deg,#f8fbff,#fff);border-bottom:1px solid #edf2f7}.profile-dropdown-body{padding:8px 0}.profile-dropdown-section{padding:10px 18px 6px;color:var(--text-soft);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px}.profile-dropdown-item{width:100%;border:0;background:#fff;display:flex;align-items:center;gap:12px;padding:12px 18px;font-size:14px;color:var(--text-main);cursor:pointer;text-align:left}.profile-dropdown-item:hover{background:#f6fbff}.profile-dropdown-item.logout{color:#ba1c1c;border-top:1px solid #edf2f7;margin-top:6px}.profile-dropdown-icon{width:18px;text-align:center;color:var(--bca-blue-dark);flex:0 0 18px}.profile-dropdown-item.logout .profile-dropdown-icon{color:#ba1c1c}.content-wrap{padding:12px 24px 24px;display:grid;gap:20px}.hero{background:linear-gradient(135deg,#fff,#f3f9ff);border:1px solid #dce9f6;border-radius:22px;padding:24px;box-shadow:0 16px 40px #03487b14}.hero h1{margin:0 0 8px;color:var(--bca-blue-dark);font-size:26px}.hero p{margin:0;max-width:760px;color:var(--text-soft);line-height:1.5}.hero-meta{margin-top:10px;color:var(--bca-blue-dark);font-size:13px;font-weight:700}.hero-pillbar{margin-top:18px;display:flex;flex-wrap:wrap;gap:10px}.hero-pill{padding:9px 12px;border-radius:999px;background:#fff;border:1px solid #d7e7f5;color:var(--bca-blue-dark);font-size:12px;font-weight:700}.panel{background:#fff;border:1px solid var(--panel-border);border-radius:20px;overflow:hidden;box-shadow:0 10px 28px #0f172a0d}.dashboard-card{padding:22px 24px;border:1px dashed #cfe0f2;border-radius:18px;background:linear-gradient(180deg,#fff,#f8fbff)}.dashboard-card h3{margin:0 0 8px;color:var(--bca-blue-dark);font-size:20px}.dashboard-card p{margin:0;color:var(--text-soft);line-height:1.5}.panel-header{padding:20px 22px 14px;border-bottom:1px solid #edf2f7}.panel-header h2{margin:0 0 6px;font-size:19px;color:var(--bca-blue-dark)}.panel-header p{margin:0;color:var(--text-soft);font-size:14px}.menu-help{padding:14px 22px 0;color:var(--text-soft);font-size:13px}.controls{display:flex;gap:12px;align-items:center;padding:18px 22px;background:#fff}.controls input,.auth-form input{width:min(320px,100%);padding:11px 13px;border:1px solid #cbd7e6;border-radius:12px;font-size:14px;background:#fff}.controls button,.auth-form button{padding:11px 16px;border:0;border-radius:12px;background:var(--bca-blue);color:#fff;font-size:14px;cursor:pointer;font-weight:700}.controls button:disabled,.auth-form button:disabled{opacity:.7;cursor:wait}.status{min-height:20px;font-size:14px;color:var(--text-soft)}.table-wrap{overflow:auto;border-top:1px solid #edf2f7}table{width:100%;border-collapse:collapse;min-width:1100px}th,td{padding:12px 14px;border-bottom:1px solid #edf2f7;text-align:left;vertical-align:top;font-size:13px}th{background:#f8fbff;position:sticky;top:0;z-index:1;color:var(--bca-blue-dark)}.empty{padding:18px 22px 22px;color:var(--text-soft);font-size:14px}.hidden-panel{display:none}.toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}.button-secondary,.button-danger,.button-warning,.button-soft{border:0;border-radius:10px;padding:8px 12px;font-size:12px;font-weight:700;cursor:pointer}.button-secondary{background:#0f5fa8;color:#fff}.button-danger{background:#ba1c1c;color:#fff}.button-warning{background:#d97706;color:#fff}.button-soft{background:#e9f2fb;color:#0f5fa8;border:1px solid #cfe0f2}.action-stack{display:flex;gap:8px;flex-wrap:wrap}.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:11px;font-weight:700}.status-badge.active{background:#e6f6ec;color:#136f3a}.status-badge.blocked{background:#fde8e8;color:#b42318}.perm-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:6px;padding:3px 6px;font-size:10px;font-weight:700;margin-right:4px;border:1px solid transparent;width:18px;height:18px}.perm-badge.active{background:#e6f6ec;color:#136f3a;border-color:#136f3a}.perm-badge.inactive{background:#f1f5f9;color:#94a3b8;border-color:#cbd5e1;text-decoration:line-through}.assigned-role-menu-perms{display:flex;gap:12px;margin-top:6px;flex-wrap:wrap}.assigned-role-menu-perms label{font-size:11px;font-weight:600;color:#475569;display:inline-flex;align-items:center;gap:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.assigned-role-menu-perms input[type=checkbox]{width:auto!important;height:auto!important;margin:0!important;cursor:pointer}#map{height:460px;border-top:1px solid #edf2f7}.auth-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:radial-gradient(circle at top right,rgba(0,91,170,.35),transparent 35%),linear-gradient(145deg,#005baaeb,#014782f0);padding:16px;z-index:9999}.auth-overlay.active{display:flex}.auth-card{width:min(420px,100%);background:#fff;border-radius:22px;padding:28px;box-shadow:0 30px 80px #01234647}.auth-card h1{margin:0 0 8px;font-size:28px;color:var(--bca-blue-dark)}.auth-card p{margin:0 0 22px;color:var(--text-soft);font-size:14px;line-height:1.5}.auth-form{display:grid;gap:12px}.auth-form label{display:grid;gap:6px;font-size:14px;color:var(--text-main)}.auth-link-button{border:0!important;background:transparent!important;color:var(--bca-blue-dark)!important;padding:0!important;justify-self:center;font-size:13px!important;font-weight:700;cursor:pointer}.auth-link-button:hover{text-decoration:underline}.auth-error{min-height:20px;color:#b42318;font-size:13px}.modal-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:#0f172a73;padding:18px;z-index:9999}.modal-overlay.active{display:flex}.modal-card{width:min(560px,100%);background:#fff;border-radius:22px;box-shadow:0 28px 70px #0f172a38;overflow:hidden}.modal-header{padding:20px 22px 12px;border-bottom:1px solid #edf2f7}.modal-header h3{margin:0 0 6px;color:var(--bca-blue-dark);font-size:20px}.modal-header p{margin:0;color:var(--text-soft);font-size:14px}.modal-body{padding:20px 22px;display:grid;gap:14px}.modal-form{display:grid;gap:14px}.modal-form label,.radio-group-label{display:grid;gap:6px;font-size:14px;color:var(--text-main)}.modal-form input{width:100%;padding:11px 13px;border:1px solid #cbd7e6;border-radius:12px;font-size:14px;background:#fff}.field-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.radio-row{display:flex;gap:12px;flex-wrap:wrap}.radio-pill{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border:1px solid #d7e7f5;border-radius:12px;background:#f8fbff;cursor:pointer}.confirm-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}.confirm-list li{display:flex;justify-content:space-between;gap:14px;padding:10px 12px;border-radius:12px;background:#f8fbff;border:1px solid #e4edf5;font-size:14px}.confirm-list strong{color:var(--bca-blue-dark)}.modal-error,.modal-success{min-height:20px;font-size:13px}.field-help{margin-top:4px;color:var(--text-soft);font-size:12px;line-height:1.4}.modal-error{color:#b42318}.modal-success{color:#136f3a}.modal-footer{padding:0 22px 22px;display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.button-ghost{border:1px solid #cfe0f2;border-radius:12px;padding:10px 14px;background:#fff;color:var(--bca-blue-dark);font-weight:700;cursor:pointer}.generated-box{padding:14px 16px;border-radius:14px;background:#f6fbff;border:1px solid #d7e7f5;color:var(--bca-blue-dark);font-family:Courier New,monospace;font-size:18px;letter-spacing:.5px;word-break:break-all}@media (max-width: 980px){.sidebar{width:88px}.sidebar-label,.sidebar-brand-copy,.sidebar-section-title,.sidebar-meta,.sidebar-profile-name,.sidebar-profile-role,.sidebar-footer button span{display:none}.sidebar-menu-button{justify-content:center;padding-inline:0}.sidebar-footer button{justify-content:center}.app-main{margin-left:88px}}@media (max-width: 720px){.sidebar{transform:translate(-100%);width:var(--sidebar-width)}body.sidebar-open .sidebar{transform:translate(0)}body.sidebar-open:before{content:"";position:fixed;inset:0;background:#0f172a40;z-index:9}.sidebar-label,.sidebar-brand-copy,.sidebar-section-title,.sidebar-meta,.sidebar-profile-name,.sidebar-profile-role,.sidebar-footer button span{display:block}.sidebar-menu-button{justify-content:flex-start;padding-inline:14px}.app-main{margin-left:0}.content-wrap{padding:8px 16px 16px}.controls{flex-wrap:wrap}.field-grid{grid-template-columns:1fr}.status{width:100%}.header-info,.topbar-title span{display:none!important}}.transfer-container{display:flex;gap:16px;align-items:stretch;margin-top:10px;height:380px}.transfer-box{flex:1;display:flex;flex-direction:column;border:1.5px solid #edf2f7;border-radius:12px;background:#f8fafc;overflow:hidden}.transfer-header{padding:10px 14px;background:#edf2f7;font-weight:600;color:var(--bca-blue-dark);font-size:13px;border-bottom:1.5px solid #edf2f7;display:flex;justify-content:space-between;align-items:center}.transfer-search-container{padding:8px 12px;border-bottom:1px solid #edf2f7;background:#fff}.transfer-search-container input{width:100%!important;padding:6px 10px!important;border:1px solid #cbd5e1!important;border-radius:6px!important;font-size:13px!important;background:#fff!important;height:auto!important;box-shadow:none!important;outline:none}.transfer-list-wrapper{flex:1;overflow-y:auto;background:#fff}.transfer-list{list-style:none;padding:0;margin:0}.transfer-item{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid #f1f5f9;cursor:pointer;font-size:13px;transition:background .15s ease;-webkit-user-select:none;user-select:none;color:#1e293b}.transfer-item:hover{background:#f1f5f9}.transfer-item.selected{background:#e2e8f0}.transfer-item input[type=checkbox]{width:auto!important;height:auto!important;padding:0!important;margin:0 10px 0 0!important;border:none!important;border-radius:0!important;box-shadow:none!important;cursor:pointer}.transfer-actions{display:flex;flex-direction:column;justify-content:center;gap:10px}.transfer-btn{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:none;background:var(--bca-blue);color:#fff;font-size:18px;cursor:pointer;box-shadow:0 4px 6px #0000000d;transition:all .2s ease}.transfer-btn:hover{background:var(--bca-blue-dark);transform:translateY(-1px)}.transfer-btn:disabled{background:#cbd5e1;cursor:not-allowed;transform:none}.assigned-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid #f1f5f9;font-size:13px;background:#fff;transition:background .15s ease}.assigned-item:hover{background:#f8fafc}.assigned-item-info{flex:1;display:flex;flex-direction:column;gap:2px}.assigned-item-company{font-size:10px;font-weight:700;color:var(--bca-blue);background:#e0f2fe;padding:1px 5px;border-radius:4px;width:fit-content}.assigned-item-name{font-weight:500;color:#1e293b}.assigned-item-id{font-size:11px;color:#64748b}.assigned-item-actions{display:flex;align-items:center;gap:12px}.assigned-default-radio{display:flex;align-items:center;gap:4px;font-size:11px;color:#64748b;cursor:pointer}.assigned-default-radio input{cursor:pointer}.assigned-delete-btn{background:none;border:none;color:#ef4444;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.assigned-delete-btn:hover{background:#fee2e2}.tracking-layout{display:flex;height:calc(100vh - var(--topbar-height, 64px) - 24px);background:#fff;border:1px solid #dce9f6;border-radius:20px;overflow:hidden;box-shadow:0 10px 28px #0f172a0d}.tracking-sidebar{width:310px;flex-shrink:0;display:flex;flex-direction:column;background:#fff;border-right:1px solid #edf2f7;z-index:10}.sidebar-hdr{display:flex;align-items:center;justify-content:space-between;padding:18px 16px 14px;border-bottom:1px solid #edf2f7}.sidebar-hdr-left{display:flex;align-items:center;gap:10px}.sidebar-hdr h2{margin:0;font-size:17px;font-weight:800;color:var(--bca-blue-dark, #014782)}.unit-count-badge{font-size:11px;font-weight:700;color:var(--bca-blue, #005baa);background:var(--bca-blue-soft, #e9f2fb);padding:3px 10px;border-radius:999px}.ws-status-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;display:inline-flex;align-items:center;gap:4px}.ws-status-badge:before{content:"";width:6px;height:6px;border-radius:50%;display:inline-block}.ws-live{background:#dcfce7;color:#166534}.ws-live:before{background:#22c55e;animation:wsPulse 2s infinite}.ws-reconnecting{background:#fef3c7;color:#92400e}.ws-reconnecting:before{background:#f59e0b;animation:wsPulse 1s infinite}.ws-disconnected{background:#fee2e2;color:#991b1b}.ws-disconnected:before{background:#ef4444}@keyframes wsPulse{0%,to{opacity:1}50%{opacity:.3}}.refresh-icon-btn{width:36px;height:36px;border:1px solid #dce9f6;background:#fff;border-radius:10px;cursor:pointer;display:grid;place-items:center;color:var(--bca-blue, #005baa);transition:all .15s ease}.refresh-icon-btn:hover{background:#f8fbff}.refresh-icon-btn:disabled{opacity:.5;cursor:wait}.sidebar-search{padding:10px 16px;display:flex;align-items:center;gap:8px;border-bottom:1px solid #edf2f7}.sidebar-search input{flex:1;border:1px solid #dce9f6;border-radius:10px;padding:9px 12px 9px 32px;font-size:13px;background:#f8fbff;color:#1f2933;outline:none;transition:border-color .15s}.sidebar-search input:focus{border-color:var(--bca-blue, #005baa);background:#fff}.search-icon{position:absolute;margin-left:10px;pointer-events:none}.sidebar-search{position:relative}.sidebar-search .search-icon{position:absolute;left:26px;top:50%;transform:translateY(-50%)}.filter-chips{display:flex;flex-wrap:wrap;gap:6px;padding:10px 16px;border-bottom:1px solid #edf2f7}.chip{display:inline-flex;align-items:center;gap:5px;border:1px solid #dce9f6;background:#fff;border-radius:999px;padding:5px 12px;font-size:12px;font-weight:600;color:#52606d;cursor:pointer;transition:all .15s}.chip:hover{background:#f8fbff}.chip.active{background:var(--bca-blue, #005baa);color:#fff;border-color:var(--bca-blue, #005baa)}.chip.active .chip-count{color:#ffffffd9}.chip.active .chip-dot{border-color:#fff}.chip-count{font-size:11px;font-weight:700;color:#94a3b8}.chip-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot-moving{background:#22c55e}.dot-idle{background:#f59e0b}.dot-parking{background:#94a3b8}.dot-offline{background:#ef4444}.show-all-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #edf2f7;background:#f8fbff}.toggle-label{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:600;color:#334155;cursor:pointer}.toggle-label input{display:none}.toggle-slider{width:34px;height:18px;background:#cbd5e1;border-radius:999px;position:relative;transition:background .2s}.toggle-slider:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-label input:checked+.toggle-slider{background:var(--bca-blue, #005baa)}.toggle-label input:checked+.toggle-slider:after{transform:translate(16px)}.aktif-badge{font-size:11px;font-weight:700;color:#22c55e;background:#f0fdf4;padding:3px 10px;border-radius:999px}.vehicle-cards-scroll{flex:1;overflow-y:auto}.vehicle-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-bottom:1px solid #f1f5f9;cursor:pointer;transition:all .15s;border-left:3px solid transparent}.vehicle-card:hover{background:#f8fbff}.vehicle-card.selected{background:var(--bca-blue-soft, #e9f2fb);border-left-color:var(--bca-blue, #005baa)}.card-left{padding-top:3px}.status-circle{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;border:2.5px solid}.status-circle.sc-moving{background:#f0fdf4;border-color:#22c55e}.status-circle.sc-idle{background:#fffbeb;border-color:#f59e0b}.status-circle.sc-parking{background:#f1f5f9;border-color:#94a3b8}.status-circle.sc-offline{background:#fef2f2;border-color:#ef4444}.card-body{flex:1;min-width:0}.card-top-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.card-plate{font-size:14px;font-weight:800;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-pill{font-size:10.5px;font-weight:700;padding:2px 10px;border-radius:999px;white-space:nowrap;flex-shrink:0}.pill-moving{background:#dcfce7;color:#166534}.pill-idle{background:#fef3c7;color:#92400e}.pill-parking{background:#f1f5f9;color:#475569}.pill-offline{background:#fee2e2;color:#991b1b}.card-location{display:flex;align-items:center;gap:4px;margin-top:4px;font-size:12px;color:#64748b;min-width:0}.card-location svg{flex-shrink:0}.card-location span{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.35}.card-metrics{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.metric-tag{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;color:#64748b;background:#f1f5f9;padding:2px 8px;border-radius:6px}.empty-cards{padding:40px 16px;text-align:center;color:#94a3b8;font-size:13px}.tracking-map-area{flex:1;position:relative;display:flex;flex-direction:column}#map{width:100%;flex:1;z-index:1;border:none}.map-count-banner{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:1000;display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #dce9f6;border-radius:999px;padding:7px 18px;font-size:12.5px;font-weight:600;color:#334155;box-shadow:0 4px 12px #00000014}.banner-dot{width:8px;height:8px;background:#22c55e;border-radius:50%}.map-status-overlay{position:absolute;bottom:14px;left:50%;transform:translate(-50%);z-index:1000;background:#0f172ad9;color:#fff;padding:6px 16px;border-radius:8px;font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.detail-panel{width:0;overflow:hidden;background:#fff;border-left:none;display:flex;flex-direction:column;transition:width .25s cubic-bezier(.4,0,.2,1)}.detail-panel.open{width:360px;border-left:1px solid #edf2f7;overflow-x:hidden;overflow-y:auto}.dp-header{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 20px 12px;border-bottom:1px solid #edf2f7;min-width:360px}.dp-plate{margin:0;font-size:22px;font-weight:800;color:#0f172a;letter-spacing:.5px}.dp-status-badge{display:inline-block;margin-top:6px;font-size:11px;font-weight:700;padding:3px 12px;border-radius:999px}.dp-close{border:none;background:transparent;font-size:24px;color:#94a3b8;cursor:pointer;line-height:1;padding:0 4px}.dp-close:hover{color:#475569}.dp-driver-row{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid #edf2f7;min-width:360px}.dp-driver-label{font-size:11px;font-weight:700;color:#94a3b8}.dp-driver-name{font-size:14px;font-weight:700;color:#0f172a;flex:1}.dp-engine-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:6px}.engine-on{background:#dcfce7;color:#166534}.engine-off{background:#fee2e2;color:#991b1b}.dp-metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:14px 20px;border-bottom:1px solid #edf2f7;min-width:360px}.dp-metric-card{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid #edf2f7;border-radius:14px;background:#f8fbff;transition:box-shadow .15s}.dp-metric-card:hover{box-shadow:0 2px 8px #0000000d}.dp-metric-icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}.icon-speed{background:#dbeafe;color:#2563eb}.icon-heading{background:#e0e7ff;color:#4f46e5}.icon-odo{background:#fce7f3;color:#db2777}.icon-voltage{background:#fef3c7;color:#d97706}.dp-metric-body{display:flex;flex-direction:column;gap:1px;min-width:0}.dp-metric-value{font-size:16px;font-weight:800;color:#0f172a}.dp-metric-value small{font-size:11px;font-weight:600;color:#64748b;margin-left:2px}.dp-metric-label{font-size:11px;font-weight:600;color:#94a3b8}.dp-section{padding:14px 20px;border-bottom:1px solid #edf2f7;min-width:360px}.dp-section-title{margin:0 0 10px;font-size:11px;font-weight:700;letter-spacing:.8px;color:#94a3b8;text-transform:uppercase}.dp-info-row{display:flex;justify-content:space-between;align-items:flex-start;padding:5px 0;gap:12px}.dp-info-label{font-size:13px;font-weight:500;color:#64748b;flex-shrink:0}.dp-info-value{font-size:13px;color:#0f172a;text-align:right;word-break:break-word;white-space:normal}.dp-info-tujuan{max-width:210px;overflow:visible;text-overflow:clip;line-height:1.45}.dp-info-bold{font-weight:700}.alert-detail-section{background:snow}.alert-detail-item{padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid #fee2e2}.alert-detail-item:last-child{padding-bottom:0;margin-bottom:0;border-bottom:none}.alert-detail-banner{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;margin-bottom:10px;border:1px solid}.alert-detail-fatigue{background:#fffbeb;border-color:#fde68a}.alert-detail-overspeed{background:#fef2f2;border-color:#fecaca}.alert-detail-icon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:#fff;font-size:18px;flex-shrink:0}.alert-detail-title{font-size:13px;font-weight:800;color:#991b1b}.alert-detail-subtitle{font-size:12px;font-weight:700;color:#0f172a;margin-top:2px}.dp-address-card{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#f8fbff;border:1px solid #edf2f7;border-radius:12px}.dp-addr-icon{flex-shrink:0;margin-top:1px}.dp-addr-text{font-size:13px;color:#334155;line-height:1.5;word-break:break-word}.dp-actions{padding:14px 20px;display:flex;gap:10px;margin-top:0;min-width:360px}.dp-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;border-radius:12px;padding:10px 16px;font-size:13px;font-weight:700;cursor:pointer;transition:all .15s}.dp-btn-center{flex:1;background:var(--bca-blue-soft, #e9f2fb);color:var(--bca-blue-dark, #014782);border:1px solid #cfe0f2}.dp-btn-center:hover{background:#dbeafe}.dp-btn-share{width:42px;background:#f1f5f9;color:#64748b}.dp-btn-share:hover{background:#e2e8f0}::ng-deep .leaflet-popup-content{white-space:normal!important;word-break:break-word!important}::ng-deep .leaflet-popup-content-wrapper{border-radius:14px!important;padding:6px!important;box-shadow:0 20px 25px -5px #0f172a1f!important;border:1px solid #edf2f7!important}::ng-deep .leaflet-bar{border:none!important;box-shadow:0 4px 12px #00000014!important;border-radius:10px!important;overflow:hidden}::ng-deep .leaflet-bar a{background:#fff!important;color:#475569!important;border-bottom:1px solid #f1f5f9!important;width:34px!important;height:34px!important;line-height:34px!important}::ng-deep .leaflet-bar a:hover{background:#f8fafc!important;color:#0f172a!important}::ng-deep .leaflet-bar a:last-child{border-bottom:none!important}::ng-deep .custom-circle-marker{background:transparent!important;border:none!important}::ng-deep .nopol-tooltip{background:#0f172a!important;border:none!important;color:#fff!important;font-family:system-ui,sans-serif!important;font-weight:600!important;padding:5px 10px!important;border-radius:6px!important;font-size:11.5px!important;box-shadow:0 4px 12px #00000040!important;white-space:nowrap!important}::ng-deep .nopol-tooltip:before{border-top-color:#0f172a!important}.alert-panel{position:absolute;bottom:16px;right:16px;z-index:1001;width:380px;max-height:480px;background:#fff;border:1px solid #dce9f6;border-radius:18px;box-shadow:0 20px 50px #0f172a26;display:flex;flex-direction:column;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.alert-panel.collapsed{width:auto;max-height:none;border-radius:999px;box-shadow:0 8px 24px #0f172a1f}.alert-panel.collapsed .alert-chevron{transform:rotate(180deg)}.alert-toggle-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:none;background:transparent;cursor:pointer;font-size:13px;font-weight:700;color:#334155;width:100%;text-align:left;border-bottom:1px solid #edf2f7;transition:background .15s}.alert-panel.collapsed .alert-toggle-btn{border-bottom:none}.alert-toggle-btn:hover{background:#f8fbff}.alert-toggle-icon{font-size:16px}.alert-toggle-label{font-weight:800;color:#0f172a}.alert-count-badge{background:#ef4444;color:#fff;font-size:11px;font-weight:800;padding:2px 8px;border-radius:999px;min-width:22px;text-align:center}.alert-count-badge.pulse{animation:alertPulse 2s infinite}@keyframes alertPulse{0%,to{transform:scale(1);box-shadow:0 0 #ef444466}50%{transform:scale(1.1);box-shadow:0 0 0 6px #ef444400}}.alert-chevron{margin-left:auto;color:#94a3b8;transition:transform .3s}.alert-body{display:flex;flex-direction:column;min-height:0;flex:1;overflow:hidden}.alert-tabs{display:flex;gap:0;border-bottom:1px solid #edf2f7;padding:0}.alert-tab{flex:1;border:none;background:transparent;padding:10px 12px;font-size:12.5px;font-weight:700;color:#64748b;cursor:pointer;transition:all .15s;border-bottom:2px solid transparent}.alert-tab:hover{background:#f8fbff}.alert-tab.active.tab-fatigue{color:#d97706;border-bottom-color:#d97706;background:#fffbeb}.alert-tab.active.tab-overspeed{color:#dc2626;border-bottom-color:#dc2626;background:#fef2f2}.tab-count{font-size:11px;opacity:.8}.alert-loading{padding:24px;text-align:center;color:#94a3b8;font-size:13px}.alert-cards-scroll{flex:1;overflow-y:auto;max-height:340px;padding:8px}.alert-empty{padding:24px 16px;text-align:center;color:#94a3b8;font-size:13px}.alert-card{display:flex;align-items:flex-start;gap:10px;padding:12px;border-radius:14px;margin-bottom:6px;cursor:pointer;transition:all .15s;border:1px solid transparent}.alert-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.alert-fatigue{background:#fffbeb;border-color:#fde68a}.alert-fatigue:hover{background:#fef3c7}.alert-overspeed{background:#fef2f2;border-color:#fecaca}.alert-overspeed:hover{background:#fee2e2}.alert-card-icon{font-size:20px;flex-shrink:0;width:36px;height:36px;border-radius:10px;display:grid;place-items:center}.fatigue-icon{background:#fde68a}.overspeed-icon{background:#fecaca}.alert-card-body{flex:1;min-width:0}.alert-card-title{font-size:12px;font-weight:800;color:#0f172a;margin-bottom:3px}.alert-fatigue .alert-card-title{color:#92400e}.alert-overspeed .alert-card-title{color:#991b1b}.alert-card-detail{font-size:12px;color:#475569;line-height:1.5}.alert-card-detail strong{color:#0f172a}.alert-card-time{font-size:11px;color:#94a3b8;margin-top:4px}.alert-dismiss{border:none;background:transparent;color:#94a3b8;font-size:18px;cursor:pointer;padding:0 4px;line-height:1;flex-shrink:0}.alert-dismiss:hover{color:#475569}
