:root{--bg:#f6fbf4;--panel:#fff;--panel2:#eef7eb;--text:#10281b;--muted:#5f7767;--line:#d6e5d6;--primary:#2f9e44;--primary-weak:#e8f6e9;--success:#16a34a;--info:#2563eb;--warning:#d97706;--danger:#dc2626;--neutral:#64748b;--shadow:0 10px 25px #0f2a1814;--radius:14px;--primary-soft-border:#b5dcba;--primary-soft:#77c38a;--road-lane-bg:#dceedd;--road-dash-bg:#c7e2cb;--cab-bg:#bfe3c4;--cab-border:#91c89b;--truck-window:#cfe8d7;--primary-gradient-from:#49b45d;--primary-gradient-to:#2f9e44;--hero-bg-start:#ebf8e9;--hero-bg-mid:#fff;--hero-bg-end:#f5fbf3;--table-head-bg:#77818b;--table-head-text:#f8fafc;--table-head-border:#aeb6bf;--table-row-bg:#f1f3f5;--table-row-alt:#fff;--table-row-hover:#e9edf1;--table-cell-border:#d4dae0}*{box-sizing:border-box;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial}body{background:var(--bg);color:var(--text);margin:0}.hybridBanner{z-index:3000;color:#fff7ed;letter-spacing:.06em;text-align:center;text-transform:uppercase;background:repeating-linear-gradient(-45deg,#991b1b,#991b1b 10px,#b91c1c 10px 20px);border-bottom:1px solid #7f1d1d;justify-content:center;align-items:center;min-height:38px;padding:8px 14px;font-size:11px;font-weight:800;display:flex;position:sticky;top:0}a{color:inherit}.app{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.app.sidebar-collapsed{grid-template-columns:56px 1fr}.sidebar{border-right:1px solid var(--line);background:var(--panel);height:100vh;padding:14px;position:sticky;top:0}.sidebar-collapsed .sidebar{border-right:none;width:0;padding:0;overflow:hidden}.brand{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);align-items:center;gap:10px;padding:10px;display:flex}.logo{background:var(--primary-weak);border:1px solid var(--primary-soft-border);width:42px;height:42px;color:var(--primary);border-radius:12px;place-items:center;font-weight:900;display:grid}.brandLogoImage{object-fit:contain;background:#fff;border-radius:10px;width:100%;height:100%}.brand h1{margin:0;font-size:14px;line-height:1.1}.brand p{color:var(--muted);margin:3px 0 0;font-size:12px}.nav{flex-direction:column;gap:6px;margin-top:12px;display:flex}.nav button,.nav .navLink{cursor:pointer;width:100%;color:var(--text);text-align:left;background:0 0;border:1px solid #0000;border-radius:12px;align-items:center;gap:10px;padding:10px;font-weight:650;text-decoration:none;display:flex}.nav button:hover,.nav .navLink:hover{background:var(--panel2);border-color:var(--line)}.nav .navLink.active,.nav button.active{background:var(--primary-weak);border-color:var(--primary-soft-border);color:var(--primary)}.navLinkIcon{flex:none}.navPendingBadge{color:#fff;background:#dc2626;border-radius:999px;justify-content:center;align-items:center;min-width:40px;height:20px;margin-left:auto;padding:0 8px;font-size:11px;font-weight:700;line-height:1;display:inline-flex}.tabSwitch{background:var(--panel2);border:1px solid var(--line);border-radius:14px;gap:6px;margin:0 18px 10px;padding:6px;display:inline-flex}.tabSwitch button{cursor:pointer;color:var(--text);background:0 0;border:1px solid #0000;border-radius:10px;padding:8px 12px;font-weight:650}.tabSwitch button.active{border-color:var(--line);color:var(--primary);background:#fff}.sidebar .foot{border-top:1px solid var(--line);color:var(--muted);justify-content:space-between;align-items:center;gap:10px;padding-top:12px;font-size:12px;display:flex;position:absolute;bottom:14px;left:14px;right:14px}.mini{border:1px solid var(--line);background:var(--panel);color:var(--muted);border-radius:999px;align-items:center;gap:8px;padding:8px 10px;font-weight:600;display:inline-flex}.main{padding:18px 18px 28px}.topbar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.title h2{margin:0;font-size:18px}.titleWithIcon{align-items:center;gap:8px;display:inline-flex}.titleWithIconCentered{justify-content:center;width:100%}.title span{color:var(--muted);margin-top:4px;font-size:12px;display:block}.actions{align-items:center;gap:10px;display:flex}.workspaceTabsCard{border:1px solid var(--line);background:var(--panel);border-radius:12px;margin-bottom:14px;padding:12px}.workspaceTabsHeader{color:var(--muted);justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;font-size:12px;display:flex}.workspaceTabsList{flex-wrap:wrap;gap:8px;display:flex}.workspaceTabBtn{border:1px solid var(--line);background:var(--panel2);color:var(--text);cursor:pointer;border-radius:999px;align-items:center;gap:8px;max-width:100%;padding:6px 12px 6px 6px;font-weight:700;display:inline-flex}.workspaceTabBtn.active{border-color:var(--primary);background:color-mix(in srgb,var(--primary)12%,white);color:#0f172a}.workspaceTabLogoWrap{border:1px solid var(--line);background:#fff;border-radius:999px;flex:0 0 22px;justify-content:center;align-items:center;width:22px;height:22px;display:inline-flex;overflow:hidden}.workspaceTabLogo{object-fit:contain;width:100%;height:100%}.workspaceTabLogoFallback{color:#0f172a;background:#e2e8f0;justify-content:center;align-items:center;width:100%;height:100%;font-size:10px;font-weight:800;display:inline-flex}.workspaceTabLabel{white-space:nowrap;text-overflow:ellipsis;max-width:min(40vw,280px);overflow:hidden}.workspaceTabsError{color:#b91c1c;font-size:12px}.workspaceTabsEmpty{color:var(--muted);font-size:12px}.requestTenantBox{border:2px solid var(--line);background:var(--panel2);border-radius:12px;gap:8px;padding:12px;display:grid}.requestTenantBox.warning{background:#fef2f2;border-color:#ef4444}.requestTenantBox.selected{background:#f0fdf4;border-color:#16a34a}.requestTenantBox.locked{background:#eff6ff;border-color:#0ea5e9}.requestTenantHeader{justify-content:space-between;align-items:center;gap:8px;display:flex}.requestTenantRequiredTag{color:#334155;background:#fff;border:1px solid #cbd5e1;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700}.requestTenantSelected{background:#fff;border:1px solid #86efac;border-radius:10px;gap:2px;padding:8px 10px;display:grid}.requestTenantSelected code{color:#475569;font-size:11px}.requestTenantWarning{color:#b91c1c;background:#fff;border:1px solid #fecaca;border-radius:10px;padding:8px 10px;font-size:12px;font-weight:600}.requestTenantHint{color:#475569;font-size:12px}.btnContent{justify-content:center;align-items:center;gap:8px;display:inline-flex}.linkWithIcon,.labelWithIcon,.inlineInfoWithIcon{align-items:center;gap:6px;display:inline-flex}.decorativeEmoji{font-size:16px;line-height:1}.kpiLabelWithIcon{align-items:center;gap:6px;display:inline-flex}.cardSectionTitle{border-bottom:1px solid #eee;align-items:center;gap:8px;margin:0;padding:16px 20px;font-size:16px;display:flex}.spinIcon{animation:.8s linear infinite spin}.btn{border:1px solid var(--line);background:var(--panel);cursor:pointer;border-radius:12px;padding:10px 12px;font-weight:700}.btn:hover{background:var(--panel2)}.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn.primary:hover{filter:brightness(.98)}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card.pad{padding:14px}.grid{grid-template-columns:1.25fr .85fr;gap:14px;display:grid}.grid.single{grid-template-columns:1fr}.transportadoraManageGrid{grid-template-columns:minmax(0,1fr) 460px}.transportadoraManageGrid.single{grid-template-columns:1fr}.filters{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.filterCheckbox{color:var(--text);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:0 4px;font-size:13px;font-weight:650;display:inline-flex}.filterCheckbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);margin:0}input:not([type=checkbox]):not([type=radio]),select,textarea{border:1px solid var(--line);background:#fff;border-radius:12px;outline:none;min-width:180px;padding:10px 12px}input:not([type=checkbox]):not([type=radio])::placeholder,textarea::placeholder{color:#94a3b8}.tableWrap{border:1px solid var(--table-cell-border);background:var(--table-row-bg);border-radius:8px;overflow:auto}.tableWrap table{border-collapse:collapse;border-spacing:0;width:100%;min-width:100%}.tableWrap th,.tableWrap td{border-bottom:1px solid var(--table-cell-border);border-right:1px solid var(--table-cell-border);white-space:nowrap;padding:12px 10px;font-size:13px}.tableWrap th:last-child,.tableWrap td:last-child{border-right:none}.tableWrap th{color:var(--table-head-text);text-align:center;background:var(--table-head-bg);border-bottom-color:var(--table-head-border);font-weight:700}.tableWrap tbody tr:nth-child(odd) td{background:var(--table-row-bg)}.tableWrap tbody tr:nth-child(2n) td{background:var(--table-row-alt)}.tableWrap tbody tr:hover td{background:var(--table-row-hover)}.cellTruncate{text-overflow:ellipsis;white-space:nowrap;max-width:150px;overflow:hidden}.status{border:1px solid var(--line);background:#fff;border-radius:999px;align-items:center;gap:8px;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.dot{background:var(--neutral);border-radius:999px;width:9px;height:9px}.dot.info{background:var(--info)}.dot.success{background:var(--success)}.dot.warning{background:var(--warning)}.dot.danger{background:var(--danger)}.dot.neutral{background:var(--neutral)}.link{color:var(--primary);font-weight:800;text-decoration:none}.link:hover{text-decoration:underline}.tableActionGroup{grid-template-columns:repeat(3,minmax(0,1fr));place-items:center;gap:2px;width:max-content;display:inline-grid}.iconActionButton{width:22px;min-width:22px;height:22px;color:var(--primary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;transition:transform .1s;display:inline-flex}.iconActionButton:not(:disabled):hover{transform:scale(1.08)}.iconActionButton:focus-visible{outline-offset:2px;outline:2px solid #2563eb}.iconActionButton:disabled{opacity:.35;cursor:not-allowed}.detailHead{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:12px;padding:14px;display:flex}.detailHead h3{margin:0;font-size:14px}.detailHead p{color:var(--muted);margin:4px 0 0;font-size:12px}.detailBody{padding:14px}.detailSection+.detailSection{margin-top:10px}.detailSectionTitle{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;margin:0 0 8px;font-size:11px;font-weight:800}.chips{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:650}.chipKv{align-items:center;gap:6px;min-width:0;display:inline-flex}.chipLabel{color:#64748b;white-space:nowrap}.chipValue{color:#0f172a;white-space:nowrap;text-overflow:ellipsis;max-width:180px;overflow:hidden}@media (max-width:720px){.chipValue{max-width:120px}}.vehicleBox{border:1px solid var(--line);background:#fbfbfd;border-radius:12px;margin-top:12px;padding:12px}.vehicleTop{justify-content:space-between;align-items:center;gap:10px;display:flex}.vehicleBoxSimple{background:#fff}.vehicleTopSimple{align-items:flex-end}.vehicleMetricLabel{color:var(--muted);font-size:12px;font-weight:700}.speedSimple{color:var(--text);align-items:baseline;gap:6px;font-size:16px;font-weight:700;display:inline-flex}.speedSimple strong{letter-spacing:-.3px;font-size:22px;font-weight:800}.speedSimple small{color:var(--muted);font-size:12px;font-weight:700}.vehicleMeta{color:var(--muted);gap:4px;margin-top:10px;font-size:12px;display:grid}.speed{color:var(--text);letter-spacing:-.5px;font-size:28px;font-weight:900}.speed small{color:var(--muted);margin-left:6px;font-size:12px;font-weight:750}.road{border:1px solid var(--line);background:#fff;border-radius:12px;height:92px;margin-top:10px;position:relative;overflow:hidden}.lane{background:var(--road-lane-bg);height:2px;position:absolute;top:46px;left:0;right:0}.dash{background:var(--road-dash-bg);border-radius:99px;width:70px;height:4px;animation:1.2s linear infinite dash;position:absolute;top:45px}@keyframes dash{0%{left:-90px}to{left:110%}}.truck{align-items:center;gap:8px;animation:6s linear infinite move;display:flex;position:absolute;top:26px;left:-140px}.cab{background:var(--cab-bg);border:1px solid var(--cab-border);border-radius:10px;width:56px;height:32px}.trailer{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:10px;width:84px;height:32px}@keyframes move{0%{transform:translate(0)}to{transform:translate(1100px)}}.modal{z-index:999;background:#0f172a73;padding:18px;display:none;position:fixed;inset:0}.modal.open{display:block}.modalBox{border:1px solid var(--line);max-width:980px;box-shadow:var(--shadow);background:#fff;border-radius:16px;margin:0 auto;overflow:hidden}.modalHead{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;font-weight:900;display:flex}.editShipmentModalBox{flex-direction:column;width:min(1100px,100%);max-height:calc(100vh - 36px);display:flex}.editShipmentForm{padding:20px;overflow-y:auto}.editShipmentGrid{gap:12px;display:grid}.editShipmentGrid input,.editShipmentGrid select{min-width:0}.editShipmentFields4{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;display:grid}.editShipmentFields3{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.editShipmentFields2{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.editShipmentActions{gap:12px;margin-top:8px;display:flex}.mapArea{background:#f8fafc;height:520px;position:relative;overflow:hidden}.mapFrame{position:absolute;inset:0}.mapCanvas{width:100%;height:100%}.mapOverlay{pointer-events:none;justify-content:flex-start;align-items:flex-start;display:flex;position:absolute;inset:12px}.mapBadge{color:#f8fafc;letter-spacing:.2px;background:#0f172ae6;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:700}.timelineInteractiveLayout{background:#fff;grid-template-columns:minmax(0,1.8fr) minmax(280px,1fr);height:100%;display:grid}.timelineMapPane{border-right:1px solid var(--line);min-height:0;position:relative}.timelineMapPane .mapFrame{position:absolute;inset:0}.timelineListPane{min-height:0;padding:12px;overflow-y:auto}.timelineEventCard{border:1px solid var(--line);cursor:pointer;background:#f8fafc;border-radius:12px;padding:8px 10px;transition:border-color .12s,background-color .12s}.timelineEventCard:hover{border-color:#2563eb66}.timelineEventCard.active{background:#2563eb14;border-color:#2563eb80}.truckMarker{--truck-size:44px;width:var(--truck-size);height:var(--truck-size);pointer-events:none;background:radial-gradient(circle at center,var(--truck-pulse,#16a34a33)0%,#fff0 72%);filter:drop-shadow(0 5px 10px #0f172a47);border-radius:50%;place-items:center;display:grid;position:relative}.truckMarker:after{content:"";border:2px solid var(--truck-pulse-border,#16a34a73);border-radius:50%;animation:2.2s ease-out infinite truckPulseRing;position:absolute;inset:2px}.truckGlow{background:radial-gradient(circle,var(--truck-glow,#16a34a73)0%,#fff0 68%);filter:blur(4px);border-radius:50%;animation:2.2s ease-in-out infinite truckGlowPulse;position:absolute;inset:6px}.truckMotion{z-index:2;transform-origin:50% 58%;will-change:transform;width:32px;height:32px;position:relative}.truckSvg3d{width:32px;height:32px;overflow:visible}.truckShadow{fill:#0f172a47}.truckCargo{fill:var(--truck-fill,#16a34a);stroke:#0f172acc;stroke-width:1px}.truckCab{fill:var(--truck-accent,#4ade80);stroke:#0f172acc;stroke-width:1px}.truckWindow{fill:var(--truck-window);opacity:.95}.truckStripe{fill:#ffffff59}.truckBumper{fill:#0f172ab3}.truckWheel{fill:#111827}.truckWheelHub{fill:#cbd5e1}.truckHighlight{stroke:#ffffffb3;stroke-width:1px;fill:none}.truckMarker--moving .truckGlow{opacity:1}.truckMarker--stopped .truckGlow{opacity:.75}.truckMarker--offline{filter:saturate(.7)opacity(.92)drop-shadow(0 4px 8px #0f172a2e)}.truckMarker--offline:after{opacity:.34;animation:none}.truckMarker--offline .truckGlow{opacity:.35;animation:none}.truckSpeed{z-index:3;color:#f8fafc;white-space:nowrap;pointer-events:none;background:#0f172aeb;border:1px solid #ffffff2e;border-radius:999px;padding:3px 7px;font-size:11px;font-weight:800;line-height:1.15;position:absolute;top:-24px;left:50%;transform:translate(-50%);box-shadow:0 4px 10px #0f172a40}.routePin{color:#fff;border-radius:50%;place-items:center;width:28px;height:28px;font-size:13px;font-weight:800;display:grid;transform:translate(-14px,-14px);box-shadow:0 2px 6px #0000004d}.routePin span{line-height:1}.routePin--origin{background:#16a34a}.routePin--dest{background:#dc2626}.routePin--manual{background:linear-gradient(135deg,#f59e0b,#f97316);border:2px solid #fff;width:34px;height:34px;box-shadow:0 4px 10px #0f172a59}.routePin--manual span{color:#fff;text-shadow:0 1px 1px #00000052;font-size:14px;font-weight:900}@keyframes truckGlowPulse{0%{opacity:.65;transform:scale(.88)}60%{opacity:1;transform:scale(1.08)}to{opacity:.45;transform:scale(1.2)}}@keyframes truckPulseRing{0%{opacity:.7;transform:scale(.7)}65%{opacity:.08;transform:scale(1.4)}to{opacity:0;transform:scale(1.45)}}@media (max-width:720px){.timelineInteractiveLayout{grid-template-rows:minmax(220px,1fr) auto;grid-template-columns:1fr}.timelineMapPane{border-right:0;border-bottom:1px solid var(--line)}.timelineListPane{max-height:40vh}.truckMarker{--truck-size:40px}.truckMotion,.truckSvg3d{width:29px;height:29px}.truckSpeed{padding:2px 6px;font-size:10px;top:-22px}}@media (prefers-reduced-motion:reduce){.truckGlow,.truckMarker:after{animation:none}}.fieldGrid2{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.fieldGrid3{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.fieldGrid4{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.fieldGrid5{grid-template-columns:repeat(5,1fr);gap:12px;display:grid}.fieldGridAddr{grid-template-columns:2fr 1fr 1fr 1fr;gap:12px;display:grid}.sidebarExpandBtn{z-index:980;border:1px solid var(--line);background:var(--panel2);width:40px;height:40px;color:var(--text);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;padding:0;transition:background .2s;display:inline-flex;position:fixed;top:12px;left:8px;box-shadow:0 4px 10px #0f2a1814}.sidebarExpandBtn:hover{background:var(--panel2)}.sidebarCollapseInlineBtn{border:1px solid var(--line);background:var(--panel2);width:100%;height:34px;color:var(--text);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:6px;margin-top:10px;font-size:12px;font-weight:700;display:inline-flex}.sidebarCollapseInlineBtn:hover{background:var(--panel)}.hybridMode .sidebarExpandBtn,.hybridMode .sidebarToggle{top:54px}.sidebarToggle,.sidebarOverlay{display:none}@media (max-width:980px){.grid,.transportadoraManageGrid{grid-template-columns:1fr}}@media (max-width:768px){.app,.app.sidebar-collapsed{grid-template-columns:1fr}.sidebar-collapsed .sidebar{border-right:1px solid var(--line);width:260px;padding:14px;overflow:visible}.sidebar{z-index:1000;width:260px;transition:transform .25s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.sidebar--open{transform:translate(0)}.sidebarToggle{z-index:999;border:1px solid var(--line);background:var(--panel);width:40px;height:40px;box-shadow:var(--shadow);cursor:pointer;color:var(--text);border-radius:10px;justify-content:center;align-items:center;display:flex;position:fixed;top:12px;left:12px}.sidebarOverlay--visible{z-index:999;background:#0f172a73;display:block;position:fixed;inset:0}.main{padding-top:60px}.sidebarExpandBtn,.sidebarCollapseInlineBtn{display:none}.topbar{flex-direction:column;align-items:flex-start;gap:10px}.actions{flex-wrap:wrap;width:100%}.actions .btn{text-align:center;flex:1;min-width:0}.iconActionButton{width:20px;min-width:20px;height:20px;font-size:15px}input:not([type=checkbox]):not([type=radio]),select{width:100%;min-width:0}.filters{flex-direction:column;align-items:stretch}.tableWrap th,.tableWrap td{white-space:normal;padding:10px 8px;font-size:12px}.shipmentTable th:nth-child(2),.shipmentTable td:nth-child(2),.shipmentTable th:nth-child(4),.shipmentTable td:nth-child(4),.shipmentTable th:nth-child(7),.shipmentTable td:nth-child(7),.shipmentTable th:nth-child(8),.shipmentTable td:nth-child(8),.shipmentTable th:nth-child(9),.shipmentTable td:nth-child(9),.shipmentTable th:nth-child(11),.shipmentTable td:nth-child(11){display:none}.grid,.fieldGrid2,.fieldGrid3,.fieldGrid4,.fieldGrid5,.fieldGridAddr,.publicGrid{grid-template-columns:1fr}.publicMap,.publicClientMap{height:300px}.form-grid{grid-template-columns:1fr}.modalBox{max-width:100%}}@media (max-width:1024px) and (min-width:769px){.fieldGrid4,.fieldGrid5,.fieldGridAddr{grid-template-columns:repeat(2,1fr)}}@media (max-width:1024px){.editShipmentFields4,.editShipmentFields3{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:720px){.editShipmentModalBox{max-height:calc(100vh - 20px)}.editShipmentForm{padding:14px}.editShipmentFields4,.editShipmentFields3,.editShipmentFields2{grid-template-columns:1fr}.editShipmentActions{grid-template-columns:1fr;gap:8px;display:grid}}.loginHero{background:url(/images/login/login-bg-green.avif) 50%/cover no-repeat;align-items:center;min-height:100vh;padding:clamp(16px,2.5vw,34px);display:grid;position:relative;overflow:hidden}.loginContent{z-index:1;grid-template-columns:minmax(330px,430px);justify-content:end;align-items:center;gap:clamp(18px,3vw,60px);width:100%;margin:0;display:grid;position:relative}.loginBrandPane{align-content:center;gap:16px;padding:clamp(8px,1vw,14px);display:grid}.loginBrandWordmark{align-items:center;gap:14px;display:inline-flex}.loginBrandWordmarkIcon{color:#166534;background:#22c55e29;border:1px solid #16653440;border-radius:14px;place-items:center;width:60px;height:60px;display:grid}.loginBrandWordmark h1{color:#166534;letter-spacing:-.03em;margin:0;font-size:clamp(36px,4vw,62px);font-weight:900;line-height:1}.loginBrandSubtitle{color:#1f2937;text-wrap:balance;margin:0;font-size:clamp(24px,2.6vw,52px);font-weight:700;line-height:1.1}.loginBrandTenant{color:#166534;background:#f0fdf4d9;border:1px solid #16653447;border-radius:999px;width:fit-content;margin:2px 0 0;padding:8px 12px;font-size:13px;font-weight:700;display:inline-flex}.loginPanelWrap{justify-content:flex-end;display:flex}.loginPanel{-webkit-backdrop-filter:blur(6px);background:#ffffffe0;border:1px solid #94a3b857;border-radius:22px;width:min(430px,100%);padding:clamp(24px,2.2vw,34px);box-shadow:0 24px 64px #0f172a2e}.loginHeader{text-align:center;margin-bottom:26px}.loginLogo{background:var(--primary-weak);border:1px solid var(--primary-soft-border);width:56px;height:56px;color:var(--primary);border-radius:14px;place-items:center;margin:0 auto 16px;font-size:24px;font-weight:900;display:grid}.loginLogoImage{object-fit:contain;background:#fff;border-radius:12px;width:100%;height:100%}.loginHeader h1{color:#111827;margin:0;font-size:22px;font-weight:800;line-height:1}.loginHeader p{color:#4b5563;margin:10px 0 0;font-size:14px}.loginForm{flex-direction:column;gap:14px;display:flex}.loginField{flex-direction:column;gap:6px;display:flex}.loginField label{color:var(--text);font-size:13px;font-weight:700}.loginField input{width:100%;min-width:0}.passwordInputWrap{position:relative}.passwordInputWrap input{width:100%;padding-right:40px}.passwordToggleBtn{color:#64748b;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;display:inline-flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.passwordToggleBtn:hover{color:#334155}.loginBtn{background:linear-gradient(180deg,var(--primary-gradient-from)0%,var(--primary-gradient-to)100%);border-radius:12px;width:100%;margin-top:6px;padding:12px;font-size:14px;line-height:1}.loginBtn:disabled{opacity:.7;cursor:not-allowed}.loginAuthDivider{background:#e5e7eb;width:100%;height:1px;margin-top:4px}.loginActions{flex-direction:column;align-items:center;gap:10px;margin-top:2px;display:flex}.loginForgotLink{color:#64748b;font-size:14px;font-weight:600;text-decoration:none}.loginForgotLink:hover{text-decoration:underline}.loginForgotLink--highlight{text-align:center;border:1px solid var(--primary-soft-border);background:var(--primary-weak);width:100%;max-width:250px;color:var(--primary);border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:10px 14px;font-weight:700;text-decoration:none;transition:background-color .2s,border-color .2s,transform .2s;display:inline-flex}.loginForgotLink--highlight:hover{border-color:var(--primary);background:#e6f0ff;text-decoration:none;transform:translateY(-1px)}.loginForgotLinkIcon{flex:none;width:16px;height:16px}@media (min-width:1024px){.loginHero{background-position:50% 22%;background-size:100% 100%}}.loginError{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:12px;font-size:13px;font-weight:600}.loginLoading{text-align:center;color:var(--muted);padding:40px;font-weight:600}@media (max-width:1140px){.loginBrandWordmark h1{font-size:clamp(30px,4vw,48px)}.loginBrandSubtitle{font-size:clamp(22px,2.8vw,36px)}.loginHeader h1{font-size:21px}.loginBtn,.loginForgotLink{font-size:14px}.loginForgotLink--highlight{max-width:100%}}@media (max-width:920px){.loginContent{grid-template-columns:1fr;justify-items:end;gap:18px}.loginBrandPane{width:min(620px,100%)}.loginBrandSubtitle{font-size:clamp(20px,3.8vw,28px)}}@media (max-width:640px){.loginHero{background-position:21%;padding:14px}.loginContent{justify-items:end;width:100%}.loginBrandPane{gap:12px;width:min(460px,100%)}.loginBrandWordmarkIcon{width:48px;height:48px}.loginBrandWordmark h1{font-size:clamp(28px,9vw,36px)}.loginBrandSubtitle{font-size:clamp(19px,6.4vw,26px)}.loginPanel{border-radius:18px;width:min(460px,100%);padding:22px 18px}.loginHeader h1{font-size:20px}.loginBtn{font-size:14px}.loginForgotLink{font-size:13px}}.forgotPage{background:linear-gradient(135deg,var(--hero-bg-start)0%,var(--hero-bg-end)100%);place-items:center;min-height:100vh;padding:18px;display:grid}.forgotBox{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);width:100%;max-width:430px;box-shadow:var(--shadow);padding:32px}.forgotHeader{text-align:center;margin-bottom:24px}.forgotHeader h1{margin:0;font-size:22px}.forgotHeader p{color:var(--muted);margin:8px 0 0;font-size:14px}.forgotForm{flex-direction:column;gap:14px;display:flex}.forgotInfo{color:#0f766e;background:#ecfeff;border:1px solid #a5f3fc;border-radius:10px;padding:12px;font-size:13px;font-weight:600}.forgotHint{color:#334155;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;font-size:13px}.forgotActions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.forgotSuccess{text-align:center;gap:10px;padding:8px 0;display:grid}.forgotSuccess h2{margin:0;font-size:20px}.forgotSuccess p{color:var(--muted);margin:0}.forgotFooter{text-align:center;margin-top:18px}.forgotInlineLink{color:var(--primary);font-size:14px;font-weight:600;text-decoration:none}.forgotInlineLink:hover{text-decoration:underline}@media (max-width:560px){.forgotBox{padding:24px 18px}.forgotActions{grid-template-columns:1fr}}.termsGatePage{background:linear-gradient(135deg,#f8fafc 0%,#eef2ff 100%);place-items:center;min-height:100vh;padding:18px;display:grid}.termsGateCard{border:1px solid var(--line);border-radius:var(--radius);width:100%;max-width:860px;box-shadow:var(--shadow);background:#fff;padding:24px}.termsGateHeader{text-align:center;margin-bottom:18px}.termsGateHeader p{color:var(--muted);margin:8px 0 0}.termsGateMeta{font-size:13px}.termsGateForm{gap:14px;display:grid}.termsGateContent{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;gap:12px;max-height:min(56vh,520px);padding:16px;display:grid;overflow:auto}.termsGateContent section{gap:6px;display:grid}.termsGateContent h2{color:#0f172a;margin:0;font-size:16px}.termsGateContent p{color:#334155;margin:0;font-size:14px;line-height:1.5}.termsGateContent ul{gap:6px;margin:0;padding-left:20px;display:grid}.termsGateContent a{color:#1d4ed8}.termsGateCheckbox{color:#0f172a;align-items:flex-start;gap:10px;font-size:14px;display:flex}.termsGateCheckbox input{margin-top:2px}.termsGateActions{justify-content:space-between;align-items:center;gap:10px;display:flex}.termsGateActions .btn{min-width:120px}@media (max-width:720px){.termsGateCard{padding:18px}.termsGateContent{max-height:min(52vh,460px)}.termsGateActions{grid-template-columns:1fr;display:grid}}.loadingScreen{background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.loadingSpinner{border:3px solid var(--line);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loadingScreen p{color:var(--muted);font-weight:600}.logoutBtn{cursor:pointer;width:100%;color:var(--muted);text-align:left;background:0 0;border:1px solid #0000;border-radius:12px;align-items:center;gap:10px;padding:10px;font-size:14px;font-weight:650;display:flex}.logoutBtn:hover{color:#dc2626;background:#fef2f2;border-color:#fecaca}.publicPage{background:linear-gradient(135deg,var(--hero-bg-start)0%,var(--hero-bg-mid)40%,var(--hero-bg-end)100%);min-height:100vh;padding:28px 18px 40px}.publicShell{gap:16px;max-width:1100px;margin:0 auto;display:grid}.publicHero{justify-content:space-between;align-items:center;gap:16px;display:flex}.publicBrand{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);align-items:center;gap:10px;padding:10px 12px;display:flex}.publicBrand h1{margin:0;font-size:14px}.publicBrand p{color:var(--muted);margin:4px 0 0;font-size:12px}.publicStatus{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.publicToken{color:var(--muted);font-size:12px;font-weight:600}.publicGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.publicCard{padding:16px}.publicCard h2{margin:0 0 10px;font-size:14px}.publicRow{border-bottom:1px dashed var(--line);justify-content:space-between;align-items:center;gap:10px;padding:8px 0;font-size:13px;display:flex}.publicRow span{color:var(--muted)}.publicRow strong{text-align:right}.publicRow:last-child{border-bottom:none}.publicMapHeader{justify-content:space-between;align-items:center;gap:12px;margin-bottom:10px;display:flex}.publicMapHeader h2{margin:0;font-size:14px}.publicMapHeader p{color:var(--muted);margin:4px 0 0;font-size:12px}.publicMapMeta{color:var(--muted);flex-direction:column;align-items:flex-end;gap:6px;font-size:12px;font-weight:600;display:flex}.publicMap{border:1px solid var(--line);border-radius:14px;height:420px;position:relative;overflow:hidden}.publicLoading{text-align:center;color:var(--muted);padding:24px 0;font-weight:600}.publicError{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:18px;font-size:13px;font-weight:600}.publicTokenForm{align-items:center;gap:10px;margin-top:12px;display:flex}.publicTokenForm input{flex:1;min-width:0}.publicMuted{color:var(--muted);font-size:13px;font-weight:600}.publicTimeline{gap:12px;margin-top:8px;display:grid}.publicTimelineItem{grid-template-columns:10px 1fr;align-items:flex-start;gap:10px;display:grid}.publicTimelineDot{background:var(--primary);border-radius:999px;width:10px;height:10px;margin-top:6px;box-shadow:0 0 0 4px #2563eb1f}.publicTimelineLabel{font-size:13px;font-weight:700}.publicTimelineTime{color:var(--muted);margin-top:2px;font-size:12px}.publicHistory{gap:10px;margin-top:10px;display:grid}.publicHistoryItem{border:1px solid var(--line);background:#f8fafc;border-radius:12px;grid-template-columns:1.2fr 1fr .6fr;gap:10px;padding:10px 12px;font-size:12px;font-weight:600;display:grid}.publicHistoryTime{color:var(--text)}.publicHistoryCoords{color:var(--muted)}.publicHistorySpeed{text-align:right;color:var(--muted)}@media (max-width:640px){.publicHistoryItem{grid-template-columns:1fr;gap:6px}.publicHistorySpeed{text-align:left}}.driverTrackPage{background:var(--bg);min-height:100vh;color:var(--text)}.driverTrackHeader{border-bottom:1px solid var(--line);z-index:10;background:#fff;padding:14px 16px;position:sticky;top:0}.driverTrackHeader h1{margin:0;font-size:16px}.driverTrackWrap{gap:10px;padding:12px 16px 20px;display:grid}.driverTrackCard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px}.driverTrackRow{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.driverTrackRowMeta{margin-top:10px}.driverTrackPills{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.driverTrackPill{background:var(--panel2);border:1px solid var(--line);border-radius:999px;padding:6px 10px;font-size:12px}.driverTrackPill.ok{color:#166534;background:#16a34a1f;border-color:#16a34a40}.driverTrackPill.warn{color:#b45309;background:#f59e0b24;border-color:#f59e0b4d}.driverTrackPill.bad{color:#b91c1c;background:#ef44441f;border-color:#ef44444d}.driverTrackPill code{background:#f1f5f9;border-radius:8px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono}.driverTrackDelivery{border:1px solid var(--line);background:var(--panel2);border-radius:12px;gap:8px;margin-top:12px;padding:12px;display:grid}.driverTrackDelivery.active{background:#2563eb14;border-color:#2563eb47}.driverTrackDeliveryHead{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.driverTrackDeliveryHead h2{letter-spacing:.03em;text-transform:uppercase;color:var(--muted);margin:0;font-size:12px;font-weight:800}.driverTrackDeliveryBadge{color:#166534;background:#16a34a1f;border:1px solid #16a34a47;border-radius:999px;padding:4px 8px;font-size:11px;font-weight:700}.driverTrackDeliveryBadge.muted{color:#475569;background:#f1f5f9;border-color:#cbd5e1}.driverTrackDeliveryMain{color:#0f172a;margin:0;font-size:14px;font-weight:800;line-height:1.35}.driverTrackDeliveryGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.driverTrackDeliveryItem{background:#fff;border:1px solid #94a3b859;border-radius:10px;gap:4px;padding:8px 10px;display:grid}.driverTrackDeliveryItem span{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-size:10px;font-weight:800}.driverTrackDeliveryItem strong{word-break:break-word;font-size:12px;line-height:1.3}.driverTrackDeliveryEmpty{color:var(--muted);margin:0;font-size:12px;font-weight:600}.driverTrackActions{gap:10px;margin-top:12px;display:grid}.driverTrackToggle{color:var(--text);align-items:flex-start;gap:8px;margin-top:12px;font-size:13px;display:flex}.driverTrackToggle input{width:16px;height:16px;margin-top:2px}.driverTrackToggle span{font-weight:700;line-height:1.3}.driverTrackBtn{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border:0;border-radius:12px;width:100%;padding:12px;font-weight:800}.driverTrackBtn.primary{background:var(--primary);color:#fff}.driverTrackBtn.danger{color:#fff;background:#ef4444}.driverTrackBtn.ghost{background:var(--panel);color:var(--text);border:1px solid var(--line)}.driverTrackBtn:disabled{opacity:.6;cursor:not-allowed}.driverTrackMap{border:1px solid var(--line);border-radius:14px;height:50vh;position:relative;overflow:hidden}.driverTrackSmall{opacity:.9;color:var(--muted);margin:10px 0 0;font-size:12px;line-height:1.35}.driverTrackError{white-space:pre-wrap;word-break:break-word;color:#b91c1c;background:#ef44441f;border:1px solid #ef444459;border-radius:12px;margin-top:10px;padding:10px;font-size:12px;font-weight:700}.driverTrackWarn{white-space:pre-wrap;word-break:break-word;color:#b45309;background:#f59e0b1f;border:1px solid #f59e0b59;border-radius:12px;margin-top:10px;padding:10px;font-size:12px;font-weight:700}.publicClientPage{color:#e6eefc;background:#0b1220;min-height:100vh}.publicClientHeader{text-align:center;background:#111b2e;border-bottom:1px solid #ffffff14;padding:20px}.publicClientHeader h1{margin-bottom:5px;font-size:24px}.publicClientHeader p{color:#9bb0d0;margin:0;font-size:14px}.publicClientContainer{gap:20px;max-width:900px;margin:0 auto;padding:20px;display:grid}.publicClientCard{background:#111b2e;border:1px solid #ffffff14;border-radius:14px;padding:20px}.publicClientCard h2{color:#2dd4bf;margin-bottom:16px;font-size:18px}.publicClientMap{border:1px solid #ffffff14;border-radius:12px;height:500px;position:relative;overflow:hidden}.publicClientMapMeta{color:#9bb0d0;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;font-size:12px;display:flex}.publicClientLastUpdate{color:#9bb0d0;font-size:12px}.publicClientStatusBadge{text-transform:uppercase;border-radius:999px;padding:6px 12px;font-size:12px;font-weight:700;display:inline-block}.publicClientStatusBadge.online{color:#4ade80;background:#4ade801f;border:1px solid #4ade8059}.publicClientStatusBadge.offline{color:#fb7185;background:#fb71851f;border:1px solid #fb718559}.publicClientInfoGrid{gap:12px;display:grid}.publicClientInfoRow{border-bottom:1px solid #ffffff0f;justify-content:space-between;padding:12px 0;display:flex}.publicClientInfoRow:last-child{border-bottom:none}.publicClientLabel{color:#9bb0d0;font-size:14px;font-weight:600}.publicClientValue{text-align:right;font-size:14px;font-weight:600}.publicClientDocs{background:#2dd4bf0d;border:1px solid #2dd4bf33;border-radius:10px;gap:12px;margin-top:16px;padding:16px;display:grid}.publicClientDocsTitle{color:#2dd4bf;text-transform:uppercase;margin-bottom:4px;font-size:12px;font-weight:700}.publicClientTimeline{padding-left:40px;position:relative}.publicClientTimelineItem{padding-bottom:24px;position:relative}.publicClientTimelineItem:before{content:"";background:#2dd4bf33;width:2px;position:absolute;top:8px;bottom:-16px;left:-28px}.publicClientTimelineItem:last-child:before{display:none}.publicClientTimelineDot{background:#2dd4bf;border:3px solid #111b2e;border-radius:50%;width:16px;height:16px;position:absolute;top:4px;left:-35px}.publicClientTimelineTime{color:#9bb0d0;margin-bottom:4px;font-size:12px}.publicClientTimelineLabel{font-size:14px;font-weight:600}.publicClientAlert{border-radius:10px;padding:16px;font-size:14px;font-weight:600}.publicClientAlert.error{color:#fb7185;background:#fb71851f;border:1px solid #fb718559}.publicClientTokenForm{align-items:center;gap:10px;margin-top:12px;display:flex}.publicClientTokenForm input{color:#e6eefc;background:#0b1220;border:1px solid #ffffff26;border-radius:10px;flex:1;min-width:0;padding:12px}.publicClientPrimary,.publicClientRefresh{color:#0b1220;cursor:pointer;background:#2dd4bf;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;transition:all .3s}.publicClientPrimary:hover,.publicClientRefresh:hover{background:#38e4ce;transform:translateY(-2px)}.publicClientRefresh:active{transform:scale(.95)}.publicClientRefresh:disabled{opacity:.7;cursor:not-allowed}.publicClientMuted{color:#9bb0d0;font-size:14px}.publicClientLoading{text-align:center;color:#9bb0d0;padding:40px;font-weight:600}@media (max-width:980px){.publicHero{flex-direction:column;align-items:flex-start}.publicStatus{align-items:flex-start}.publicGrid{grid-template-columns:1fr}.publicMapHeader{flex-direction:column;align-items:flex-start}.publicMapMeta{align-items:flex-start}}@media (max-width:720px){.driverTrackHeader{padding:12px 14px}.driverTrackWrap{padding:10px 12px 18px}.driverTrackMap{height:40vh}.driverTrackBtn{font-size:15px}.driverTrackDeliveryGrid{grid-template-columns:1fr}.publicClientTokenForm{flex-direction:column;align-items:stretch}.publicClientMapMeta{flex-direction:column;align-items:flex-start}}.autocomplete-container{width:100%;position:relative}.autocomplete-input{border:1px solid var(--line);border-radius:var(--radius);width:100%;padding:.75rem;font-size:.9rem}.autocomplete-dropdown{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);z-index:1000;max-height:300px;margin-top:4px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.autocomplete-item{cursor:pointer;border-bottom:1px solid var(--line);padding:.75rem 1rem}.autocomplete-item:last-child{border-bottom:none}.placeAutocompleteItemButton{text-align:left;width:100%;font:inherit;background:0 0;border:0}.autocomplete-item:hover{background:var(--primary-weak)}.autocomplete-item .item-main{justify-content:space-between;align-items:center;gap:1rem;display:flex}.autocomplete-item .item-document{color:#666;font-size:.85rem}.autocomplete-item .item-address{color:#888;margin-top:.25rem;font-size:.8rem;display:block}.autocomplete-loading,.autocomplete-empty{text-align:center;color:#666;padding:1rem}.autocomplete-empty .btn-create-new{color:var(--primary);cursor:pointer;background:0 0;border:none;margin:.5rem auto 0;font-weight:500;display:block}.selected-entity{background:var(--primary-weak);border:1px solid var(--primary);border-radius:var(--radius);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.selected-entity .entity-info{flex-direction:column;gap:.25rem;display:flex}.selected-entity .document{color:#666;font-size:.85rem}.selected-entity .location{color:#888;font-size:.8rem}.selected-entity .btn-clear{color:var(--primary);cursor:pointer;background:0 0;border:none;font-weight:500}.badge{border-radius:4px;margin-right:.25rem;padding:.2rem .5rem;font-size:.75rem;font-weight:500;display:inline-block}.badge-remetente{color:#1976d2;background:#e3f2fd}.badge-destinatario{color:#f57c00;background:#fff3e0}.form-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.checkbox-group{gap:1.5rem;display:flex}
