:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{box-sizing:border-box;flex-direction:column;width:100%;min-height:100svh;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0}:root{--bg-app:#0b0f1a;--bg-sidebar:#0d1220;--bg-header:#0d1220;--bg-yard:#111827;--bg-panel:#fff;--bg-parking:#0ea5e90f;--bg-dock:#f973160d;--border-parking:#0ea5e94d;--border-dock:#f973164d;--border-panel:#e8edf4;--text-primary:#f0f4ff;--text-secondary:#8896ae;--text-dark:#0f172a;--text-mid:#475569;--green:#22c55e;--light-blue:#64748b;--blue:#3b82f6;--amber:#f59e0b;--red:#dc2626;--slate:#64748b;--cyan:#06b6d4;--orange:#f97316;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,sans-serif}body{background:var(--bg-app);overscroll-behavior:none;-webkit-overflow-scrolling:touch;overflow:hidden}.app{height:100dvh;display:flex;overflow:hidden}.sidebar{background:var(--bg-sidebar);border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;justify-content:space-between;width:220px;padding:20px 14px;display:flex}.sidebar-top{flex-direction:column;gap:20px;display:flex}.sidebar-logo{border-bottom:1px solid #ffffff12;align-items:center;gap:10px;padding:4px 6px 16px;display:flex}.logo-icon{border-radius:var(--radius-sm);color:#fff;letter-spacing:.02em;background:linear-gradient(135deg,#2563eb,#0ea5e9);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:800;display:flex;box-shadow:0 4px 12px #2563eb66}.logo-title{color:var(--text-primary);letter-spacing:.1em;font-size:13px;font-weight:700}.logo-sub{color:var(--text-secondary);letter-spacing:.12em;text-transform:uppercase;font-size:10px}.sidebar-actions{flex-direction:column;gap:8px;display:flex}.btn-arrival,.btn-departure{border-radius:var(--radius-sm);cursor:pointer;border:none;align-items:center;gap:8px;width:100%;padding:10px 12px;font-size:12.5px;font-weight:600;transition:all .15s;display:flex}.btn-arrival{color:#60a5fa;background:#2563eb26;border:1px solid #2563eb40}.btn-arrival:hover{background:#2563eb40;border-color:#2563eb80}.btn-departure{color:#f87171;background:#dc26261a;border:1px dashed #dc262633}.btn-departure:hover{background:#dc262633}.sidebar-nav{flex-direction:column;gap:2px;display:flex}.nav-item{border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:9px;padding:9px 10px;font-size:12.5px;font-weight:500;transition:all .15s;display:flex}.nav-item:hover{color:var(--text-primary);background:#ffffff0d}.nav-item.active{color:#60a5fa;background:#2563eb1f}.legend{border-top:1px solid #ffffff12;padding-top:16px}.legend-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);margin-bottom:10px;font-size:10px;font-weight:700}.legend-item{color:var(--text-secondary);align-items:center;gap:8px;padding:3px 0;font-size:11.5px;display:flex}.dot{border-radius:3px;flex-shrink:0;width:10px;height:10px}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.header{background:var(--bg-header);border-bottom:1px solid #ffffff0f;flex-shrink:0;justify-content:flex-end;align-items:center;height:64px;padding:0 24px;display:flex;position:relative}.header-right{align-items:center;gap:10px;display:flex}.stat-pill{background:#ffffff0d;border:1px solid #ffffff14;border-radius:20px;align-items:baseline;gap:5px;padding:5px 12px;display:flex}.stat-num{color:var(--text-primary);font-size:14px;font-weight:700}.stat-label{color:var(--text-secondary);font-size:11px}.btn-refresh{border-radius:var(--radius-sm);color:#60a5fa;cursor:pointer;background:#2563eb26;border:1px solid #2563eb4d;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.btn-refresh:hover{background:#2563eb40}.header-user{border:1px solid var(--border);background:#ffffff0a;border-radius:8px;align-items:center;gap:6px;margin-left:4px;padding:5px 10px 5px 8px;display:flex}.header-user-info{color:var(--text-dim);align-items:center;gap:7px;display:flex}.header-user-text{flex-direction:column;gap:1px;display:flex}.header-user-name{color:var(--text-main);font-size:12px;font-weight:600;line-height:1}.header-user-role{color:var(--text-dim);font-size:10px;line-height:1}.header-logout-btn{width:26px;height:26px;color:var(--text-mid);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-left:2px;transition:background .15s,color .15s,border-color .15s;display:flex}.header-logout-btn:hover{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.content{flex:1;grid-template-columns:1fr 320px;display:grid;overflow:hidden}.yard{background:var(--bg-yard);gap:0;display:flex;position:relative;overflow:hidden}.parking-zone{background:var(--bg-parking);border-right:2px dashed var(--border-parking);flex-direction:column;flex:none;gap:16px;width:45%;min-height:0;padding:20px 16px;display:flex;overflow-y:auto}.zone-header{flex-shrink:0;align-items:center;gap:10px;display:flex}.zone-icon{border-radius:var(--radius-sm);color:#38bdf8;background:#0ea5e933;border:1px solid #0ea5e959;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:800;display:flex}.dock-icon{color:#fb923c;background:#f9731626;border-color:#f9731659}.zone-title{color:var(--text-primary);letter-spacing:.01em;font-size:13px;font-weight:700}.zone-count{color:var(--text-secondary);font-size:11px}.parking-grid{grid-template-columns:repeat(auto-fill,minmax(115px,1fr));align-content:start;gap:8px;display:grid}.hs-subzone{border-radius:var(--radius-md);background:#dc26260d;border:1.5px dashed #dc26264d;flex-direction:column;gap:8px;margin-top:auto;padding:12px;display:flex}.hs-subzone-header{color:#f87171;flex-shrink:0;align-items:center;gap:6px;display:flex}.hs-subzone-title{letter-spacing:.06em;text-transform:uppercase;flex:1;font-size:11px;font-weight:700}.hs-subzone-count{color:#f87171;text-align:center;background:#dc26262e;border-radius:10px;min-width:20px;padding:1px 7px;font-size:11px;font-weight:600}.hs-grid{grid-template-columns:repeat(auto-fill,minmax(115px,1fr))}.trailer-card{border-radius:var(--radius-md);cursor:grab;background:#ffffff0f;border:1.5px solid #ffffff1a;flex-direction:column;align-items:center;gap:5px;padding:10px 8px;transition:all .15s;display:flex;position:relative;overflow:hidden}.trailer-card:before{content:"";border-radius:3px 3px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.trailer-card:hover{border-color:#ffffff40;transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.trailer-card:active{cursor:grabbing;transform:scale(.97)}.trailer-num{color:var(--text-primary);letter-spacing:.02em;font-size:12px;font-weight:700}.trailer-type-tag{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;background:#ffffff12;border-radius:4px;max-width:100%;padding:2px 6px;font-size:9.5px;overflow:hidden}.trailer-route-badge{color:#93c5fd;white-space:normal;word-break:break-word;text-align:center;background:#2563eb40;border:1px solid #2563eb59;border-radius:4px;width:100%;padding:2px 6px;font-size:9.5px;font-weight:700;line-height:1.3}@keyframes badge-pulse{0%,to{opacity:1;box-shadow:0 0 #dc262680}50%{opacity:.85;box-shadow:0 0 0 5px #dc262600}}.messages-btn-wrap{position:relative}.btn-messages{color:var(--text-secondary);cursor:pointer;white-space:nowrap;background:#ffffff14;border:1px solid #ffffff1a;border-radius:8px;align-items:center;gap:6px;padding:5px 11px;font-size:12px;font-weight:600;transition:background .15s,color .15s;display:flex}.btn-messages:hover{color:var(--text-primary);background:#ffffff21}.btn-messages.has-unread{color:#fff;background:#dc2626;border-color:#dc2626;animation:1.4s ease-in-out infinite badge-pulse}.btn-messages.has-unread:hover{background:#b91c1c;animation:none}.btn-messages-count{text-align:center;background:#00000040;border-radius:10px;min-width:16px;padding:0 5px;font-size:10px;font-weight:700;line-height:16px}.messages-panel{background:var(--bg-panel);z-index:200;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;width:380px;max-height:520px;display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 8px 32px #0006}.messages-panel-header{border-bottom:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 16px 12px;display:flex}.messages-panel-title{color:#0f172a;letter-spacing:.02em;font-size:13px;font-weight:700}.mark-all-read-btn{color:#2563eb;cursor:pointer;background:0 0;border:none;border-radius:5px;padding:2px 6px;font-size:11px;font-weight:600;transition:background .15s}.mark-all-read-btn:hover{background:#2563eb14}.messages-panel-list{flex-direction:column;flex:1;gap:4px;padding:8px;display:flex;overflow-y:auto}.messages-panel-empty{text-align:center;color:#64748b;padding:32px 16px;font-size:12px}.msg-item{border-left:3px solid #0000;border-radius:8px;padding:10px 12px;transition:background .15s}.msg-item.unread{background:#fef2f2;border-left:3px solid #ef4444}.msg-item.unread .msg-text{color:#0f172a}.msg-item.unread .msg-trailer-badge{color:#b91c1c;background:#fee2e2}.msg-item.unread .msg-date{color:#64748b}.msg-item.read{background:#f8fafc;border-left:3px solid #e2e8f0}.msg-item.read .msg-text{color:#94a3b8}.msg-item.read .msg-trailer-badge{color:#94a3b8;background:#e2e8f0}.msg-item.read .msg-date{color:#cbd5e1}.msg-item-top{align-items:center;gap:7px;margin-bottom:5px;display:flex}.msg-trailer-badge{letter-spacing:.02em;border-radius:5px;padding:1px 7px;font-size:11px;font-weight:700}.msg-date{flex:1;font-size:10.5px}.msg-author{color:var(--blue);white-space:nowrap;background:#3b82f61a;border:1px solid #3b82f633;border-radius:4px;padding:1px 6px;font-size:10.5px;font-weight:600}.msg-mark-read-btn{color:#ef4444;cursor:pointer;background:0 0;border:1px solid #fca5a5;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;transition:background .15s,color .15s,border-color .15s;display:flex}.msg-mark-read-btn:hover{color:#b91c1c;background:#fee2e2;border-color:#ef4444}.msg-text{word-break:break-word;margin:0;font-size:12px;line-height:1.5}.empty-zone{color:var(--text-secondary);text-align:center;opacity:.6;padding:24px;font-size:12px}.yard-separator{background:#ffffff05;border-left:1px solid #ffffff0a;border-right:1px solid #ffffff0a;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:6px;width:40px;display:flex}.sep-line{background:#ffffff0f;flex:1;width:2px;max-height:80px}.sep-label{writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.1em;text-transform:uppercase;color:var(--text-secondary);opacity:.5;font-size:10px;font-weight:600;transform:rotate(180deg)}.dock-zone{background:var(--bg-dock);flex-direction:column;flex:1;gap:10px;padding:16px;display:flex;overflow:hidden}.dock-list{flex-direction:column;flex:1;gap:4px;min-height:0;display:flex}.dock-bay{border-radius:var(--radius-md);background:#ffffff08;border:1.5px solid #ffffff14;flex:1;align-items:stretch;min-height:0;transition:border-color .15s,background .15s;display:flex;overflow:hidden}.dock-bay.empty{background:#0000001f;border-color:#ffffff0d}.dock-bay:hover{border-color:#ffffff2e}.dock-bay.occupied{border-color:#ffffff1c}.dock-number{background:#00000047;border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:1px;width:50px;display:flex}.dock-bay.empty .dock-number{background:#0000002e;border-left:3px solid #ffffff1a}.dock-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);opacity:.55;font-size:8px}.dock-num{color:var(--text-primary);font-size:15px;font-weight:800;line-height:1}.dock-bay.empty .dock-num{opacity:.45}.dock-content{flex:1;align-items:stretch;min-width:0;height:100%;display:flex}.dock-trailer-card{cursor:grab;text-align:left;background:0 0;border:none;flex-direction:column;justify-content:center;gap:2px;width:100%;min-width:0;height:100%;padding:5px 12px;transition:background .15s;display:flex}.dock-trailer-top{align-items:center;gap:6px;min-width:0;display:flex}.dock-trailer-card:hover{background:#ffffff0a}.dock-trailer-card:active{cursor:grabbing}.dock-trailer-num{color:var(--text-primary);flex-shrink:0;font-size:13px;font-weight:700}.dock-trailer-status{color:var(--text-secondary);opacity:.85;flex-shrink:0;font-size:11px}.dock-trailer-route{color:#93c5fd;white-space:nowrap;background:#2563eb2e;border:1px solid #2563eb47;border-radius:4px;flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:600}.dock-empty-slot{flex-direction:column;justify-content:center;gap:2px;width:100%;min-width:0;height:100%;padding:5px 12px;display:flex}.dock-empty-available{color:var(--text-secondary);opacity:.4;align-items:center;gap:6px;font-size:11px;font-weight:500;display:flex}.dock-next-loading{color:var(--text-secondary);opacity:.85;white-space:nowrap;text-overflow:ellipsis;border-top:1px solid #ffffff0e;align-items:center;gap:5px;margin-top:1px;padding-top:2px;font-size:10px;font-weight:500;display:flex;overflow:hidden}.dock-next-loading svg{opacity:.7;color:var(--text-secondary);flex-shrink:0}.dock-bay.occupied.vide .dock-number{border-left:3px solid var(--light-blue)}.dock-bay.occupied.chargee .dock-number,.dock-bay.occupied.chargée .dock-number{border-left:3px solid var(--green)}.dock-bay.occupied.chargepretasortir .dock-number,.dock-bay.occupied.videpretasortir .dock-number{border-left:none}.dock-bay.occupied.audockchargement .dock-number{border-left:3px solid var(--amber)}.dock-bay.occupied.audockdechargement .dock-number{border-left:3px solid var(--orange)}.dock-bay.occupied.horsservice .dock-number{border-left:3px solid var(--red)}.dock-bay.occupied.chargepretasortir{border-color:#22c55e}.dock-bay.occupied.chargepretasortir .dock-number{background:#16a34a}.dock-bay.occupied.chargepretasortir .dock-label{color:#ffffffbf;opacity:1}.dock-bay.occupied.chargepretasortir .dock-num{color:#fff}.dock-bay.occupied.chargepretasortir .dock-trailer-card{background:#22c55e2e}.dock-bay.occupied.chargepretasortir .dock-trailer-num{color:#dcfce7}.dock-bay.occupied.chargepretasortir .dock-trailer-status{color:#86efac;opacity:1}.dock-bay.occupied.audockchargement .dock-trailer-status{color:var(--amber);opacity:1}.dock-bay.occupied.audockdechargement .dock-trailer-status{color:var(--orange);opacity:1}.dock-bay.occupied.videpretasortir{border-color:#06b6d4}.dock-bay.occupied.videpretasortir .dock-number{background:#0891b2}.dock-bay.occupied.videpretasortir .dock-label{color:#ffffffbf;opacity:1}.dock-bay.occupied.videpretasortir .dock-num{color:#fff}.dock-bay.occupied.videpretasortir .dock-trailer-card{background:#06b6d426}.dock-bay.occupied.videpretasortir .dock-trailer-num{color:#cffafe}.dock-bay.occupied.videpretasortir .dock-trailer-status{color:#67e8f9;opacity:1}.trailer-card.vide:before{background:var(--light-blue)}.trailer-card.chargee:before,.trailer-card.chargée:before,.trailer-card.chargepretasortir:before{background:var(--green)}.trailer-card.videpretasortir:before{background:var(--cyan)}.trailer-card.audockchargement:before{background:var(--amber)}.trailer-card.audockdechargement:before{background:var(--orange)}.trailer-card.horsservice:before{background:var(--red)}.dot.vide{background:var(--light-blue)}.dot.chargee,.dot.chargée,.dot.chargepretasortir{background:var(--green)}.dot.videpretasortir{background:var(--cyan)}.dot.audockchargement{background:var(--amber)}.dot.audockdechargement{background:var(--orange)}.dot.horsservice{background:var(--red)}.dot.todo-pending{background:var(--slate)}.dot.todo-inprogress{background:var(--amber)}.dot.todo-done{background:var(--green)}.today-todo-summary{margin-top:12px}.todo-count{color:var(--text-primary);background:#ffffff14;border-radius:10px;margin-left:auto;padding:0 6px;font-size:11px;font-weight:700;line-height:17px}.todo-progress-bar-wrap{align-items:center;gap:7px;margin-bottom:8px;display:flex}.todo-progress-bar{background:#ffffff1a;border-radius:2px;flex:1;height:4px;overflow:hidden}.todo-progress-fill{background:var(--green);border-radius:2px;height:100%;transition:width .4s}.todo-progress-pct{color:var(--green);text-align:right;min-width:24px;font-size:10px;font-weight:700}.todo-routes-section{border-top:1px solid #ffffff12;margin-top:10px;padding-top:10px}.todo-routes-label{color:var(--text-muted,#475569);text-transform:uppercase;letter-spacing:.07em;margin-bottom:7px;font-size:10px;font-weight:700}.todo-route-list{flex-direction:column;gap:5px;display:flex}.todo-route-item{align-items:center;gap:7px;display:flex}.todo-route-dot{flex-shrink:0}.todo-route-name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:12px;font-weight:600;overflow:hidden}.todo-route-door{color:#fbbf24;white-space:nowrap;background:#d977061f;border:1px solid #d9770640;border-radius:4px;flex-shrink:0;padding:1px 5px;font-size:10px;font-weight:700}.details-panel{background:var(--bg-panel);border-left:1px solid var(--border-panel);flex-direction:column;display:flex;overflow-y:auto}.panel-section{flex-direction:column;gap:0;padding:20px;display:flex}.panel-header{border-bottom:1px solid var(--border-panel);align-items:center;gap:12px;margin-bottom:20px;padding-bottom:16px;display:flex}.panel-header-context{border-radius:var(--radius-sm);border:1px solid var(--border-panel);background:#f8fafc;justify-content:space-between;margin-bottom:20px;padding:12px 14px}.phc-left{align-items:center;gap:12px;display:flex}.phc-badges{align-items:center;gap:6px;margin-top:5px;display:flex}.panel-header-badge{border-radius:var(--radius-sm);color:#fff;letter-spacing:.03em;white-space:nowrap;flex-shrink:0;justify-content:center;align-items:center;height:30px;padding:0 10px;font-size:11px;font-weight:700;display:flex}.panel-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.arrival-icon{color:#2563eb;background:#eff6ff}.dock-assign-icon{color:#d97706;background:#fff7ed}.parking-icon{color:#16a34a;background:#f0fdf4}.panel-title{color:var(--text-dark);font-size:14px;font-weight:700}.panel-sub{color:var(--text-mid);margin-top:1px;font-size:12px}.field-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-mid);margin-top:14px;margin-bottom:6px;font-size:11px;font-weight:600;display:block}.field-label:first-of-type{margin-top:0}.panel-section select,.panel-section input,.panel-section textarea,.trailer-edit-panel select,.trailer-edit-panel input,.trailer-edit-panel textarea,.mobile-drawer select,.mobile-drawer input,.mobile-drawer textarea{border-radius:var(--radius-sm);width:100%;color:var(--text-dark);background:#f8fafc;border:1.5px solid #e2e8f0;outline:none;padding:9px 11px;font-family:inherit;font-size:13px;transition:border-color .15s}.panel-section select:focus,.panel-section input:focus,.panel-section textarea:focus,.trailer-edit-panel select:focus,.trailer-edit-panel input:focus,.trailer-edit-panel textarea:focus,.mobile-drawer select:focus,.mobile-drawer input:focus,.mobile-drawer textarea:focus{background:#fff;border-color:#2563eb}.trailer-id-chip{color:var(--text-dark);background:#f1f5f9;border:1px solid #e2e8f0;border-radius:20px;align-items:center;gap:7px;margin-bottom:14px;padding:5px 12px;font-size:13px;font-weight:700;display:inline-flex}.chip-dot{border-radius:50%;width:8px;height:8px}.chip-dot.vide{background:var(--light-blue)}.chip-dot.chargee,.chip-dot.chargée,.chip-dot.chargepretasortir{background:var(--green)}.chip-dot.videpretasortir{background:var(--cyan)}.chip-dot.audockchargement{background:var(--amber)}.chip-dot.audockdechargement{background:var(--orange)}.chip-dot.horsservice{background:var(--red)}.panel-actions{gap:8px;margin-top:16px;display:flex}.btn-primary,.btn-secondary{border-radius:var(--radius-sm);cursor:pointer;border:none;flex:1;padding:10px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-secondary{color:var(--text-mid);background:#f1f5f9}.btn-secondary:hover{background:#e2e8f0}.trailer-edit-panel{flex-direction:column;height:100%;padding:0;display:flex;overflow:hidden}.tep-header{border-bottom:1px solid var(--border-panel);flex-shrink:0;padding:16px 20px 0}.tep-header-top{justify-content:space-between;align-items:flex-start;margin-bottom:6px;display:flex}.tep-num{color:var(--text-dark);letter-spacing:.01em;font-size:24px;font-weight:800;line-height:1}.tep-header-info{align-items:center;gap:7px;margin-bottom:10px;display:flex}.tep-type{color:var(--text-mid);font-size:12px;font-weight:500}.tep-sep{color:#cbd5e1;font-size:12px}.tep-status-bar{justify-content:space-between;align-items:center;gap:8px;margin:0 -20px;padding:6px 20px;font-size:12px;font-weight:600;display:flex}.tep-route-tag{background:#ffffff47;border-radius:4px;padding:1px 7px;font-size:11px;font-weight:700}.tep-header--vide{border-top:3px solid var(--light-blue)}.tep-header--chargee,.tep-header--chargée,.tep-header--chargepretasortir{border-top:3px solid var(--green)}.tep-header--videpretasortir{border-top:3px solid var(--cyan)}.tep-header--audockchargement{border-top:3px solid var(--amber)}.tep-header--audockdechargement{border-top:3px solid var(--orange)}.tep-header--horsservice{border-top:3px solid var(--red)}.status-bar--vide{color:#334155;background:#e2e8f0}.status-bar--chargee,.status-bar--chargée,.status-bar--chargepretasortir{color:#15803d;background:#dcfce7}.status-bar--videpretasortir{color:#0e7490;background:#cffafe}.status-bar--audockchargement{color:#c2410c;background:#fff7ed}.status-bar--audockdechargement{color:#c2410c;background:#fff4e6}.status-bar--horsservice{color:#b91c1c;background:#fee2e2}.tep-body{flex-direction:column;flex:1;gap:0;display:flex;overflow-y:auto}.tep-section{border-bottom:1px solid var(--border-panel);flex-direction:column;gap:8px;padding:14px 20px;display:flex}.tep-section--history{border-bottom:none;flex:1}.tep-section-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-mid);align-items:center;font-size:10.5px;font-weight:700;display:flex}.tep-status-row{align-items:stretch;gap:8px;display:flex}.tep-status-row select{flex:1;margin:0}.tep-route-picker{flex-direction:column;gap:6px;display:flex}.tep-save-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#0f172a;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s;display:flex;width:38px!important;padding:0!important}.tep-save-btn:hover{background:#1e293b}.tep-comment-form{align-items:flex-end;gap:8px;display:flex}.tep-comment-form textarea{resize:none;flex:1}.tep-send-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#2563eb;border:none;flex-shrink:0;justify-content:center;align-self:flex-end;align-items:center;width:38px;height:38px;transition:background .15s;display:flex}.tep-send-btn:hover:not(:disabled){background:#1d4ed8}.tep-send-btn:disabled{cursor:not-allowed;background:#cbd5e1}.tep-comment-count{min-width:18px;height:18px;color:var(--text-mid);vertical-align:middle;background:#e2e8f0;border-radius:9px;justify-content:center;align-items:center;margin-left:6px;padding:0 5px;font-size:10px;font-weight:700;display:inline-flex}.comments-empty-state{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:28px 0 16px;font-size:12px;display:flex}.tep-actions{border-top:1px solid var(--border-panel);background:#fff;flex-shrink:0;gap:8px;padding:14px 20px;display:flex}.tep-actions .btn-primary,.tep-actions .btn-secondary{flex:1}.tep-confirm-summary{flex-direction:column;gap:8px;display:flex}.tep-summary-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.tep-summary-label{color:var(--text-mid);font-size:12px;font-weight:500}.tep-summary-badge{letter-spacing:.02em;border-radius:5px;padding:3px 9px;font-size:11px;font-weight:700}.status-badge--chargepretasortir{color:#15803d;background:#22c55e1f;border:1px solid #22c55e40}.status-badge--videpretasortir{color:#0e7490;background:#06b6d41a;border:1px solid #06b6d440}.tep-summary-route{color:var(--blue);background:#3b82f61a;border:1px solid #3b82f633}.tep-edit-link{color:var(--blue);cursor:pointer;background:0 0;border:none;align-self:flex-start;align-items:center;gap:5px;margin-top:2px;padding:0;font-family:inherit;font-size:12px;font-weight:500;display:inline-flex}.tep-edit-link:hover{text-decoration:underline}.trailer-edit-header{border-bottom:1px solid var(--border-panel);background:#f8fafc;align-items:center;gap:10px;padding:16px 20px;display:flex}.trailer-edit-badge{border-radius:var(--radius-sm);color:#fff;letter-spacing:.02em;flex-shrink:0;justify-content:center;align-items:center;width:76px;height:30px;font-size:11px;font-weight:700;display:flex}.trailer-edit-badge.vide{background:var(--light-blue)}.trailer-edit-badge.chargee,.trailer-edit-badge.chargée,.trailer-edit-badge.chargepretasortir{background:var(--green)}.trailer-edit-badge.videpretasortir{background:var(--cyan)}.trailer-edit-badge.audockchargement{background:var(--amber)}.trailer-edit-badge.audockdechargement{background:var(--orange)}.trailer-edit-badge.horsservice{background:var(--red)}.trailer-edit-meta{flex-direction:column;flex:1;gap:3px;display:flex}.edit-meta-type{color:var(--text-mid);font-size:12px}.edit-meta-door{color:#d97706;background:#fff7ed;border:1px solid #fed7aa;border-radius:5px;width:fit-content;padding:1px 7px;font-size:11px;font-weight:700;display:inline-block}.edit-meta-parking{color:#0ea5e9;background:#f0f9ff;border:1px solid #bae6fd;border-radius:5px;width:fit-content;padding:1px 7px;font-size:11px;font-weight:600;display:inline-block}.btn-close{cursor:pointer;color:var(--text-mid);background:0 0;border:none;border-radius:6px;align-items:center;padding:5px;transition:background .15s;display:flex}.btn-close:hover{background:#e2e8f0}.edit-section{border-bottom:1px solid var(--border-panel);flex-direction:column;gap:8px;padding:16px 20px;display:flex}.edit-section-comments{flex-direction:column;flex:1;display:flex;overflow:hidden}.edit-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--text-mid);font-size:11px;font-weight:700}.btn-save-status{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#0f172a;border:none;padding:9px;font-family:inherit;font-size:12.5px;font-weight:600;transition:background .15s}.btn-save-status:hover{background:#1e293b}.btn-add-comment{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#2563eb;border:none;padding:9px;font-family:inherit;font-size:12.5px;font-weight:600;transition:background .15s}.btn-add-comment:disabled{cursor:not-allowed;background:#cbd5e1}.btn-add-comment:not(:disabled):hover{background:#1d4ed8}.comments-list{flex-direction:column;flex:1;gap:8px;display:flex;overflow-y:auto}.comment-item{border-radius:var(--radius-sm);background:#f8fafc;border:1px solid #e8edf4;padding:9px 11px}.comment-text{color:var(--text-dark);word-break:break-word;font-size:12.5px;line-height:1.5}.comment-author{color:var(--blue);margin-bottom:4px;font-size:10.5px;font-weight:600;display:block}.comment-date{color:#94a3b8;margin-top:4px;font-size:10.5px;display:block}.comment-photo-link{margin-top:7px;display:block}.comment-photo-thumb{object-fit:cover;cursor:pointer;border:1px solid #e2e8f0;border-radius:6px;max-width:100%;max-height:180px}.history-timeline{flex-direction:column;gap:0;padding-left:22px;display:flex;position:relative}.history-timeline:before{content:"";background:linear-gradient(#e2e8f0 0% 90%,#0000 100%);width:1px;position:absolute;top:6px;bottom:6px;left:7px}.history-date-sep{align-items:center;margin-bottom:2px;padding:6px 0 6px 4px;display:flex;position:relative}.history-date-sep:before{content:"";background:#cbd5e1;border:1.5px solid #fff;border-radius:50%;width:6px;height:6px;position:absolute;top:50%;left:-22px;transform:translateY(-50%)}.history-date-sep span{color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;background:#f1f5f9;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:700}.history-entry{align-items:flex-start;gap:8px;padding:0 0 10px 14px;display:flex;position:relative}.history-entry:last-child{padding-bottom:0}.history-entry-dot{background:var(--blue,#2563eb);border:2px solid #fff;border-radius:50%;flex-shrink:0;width:10px;height:10px;position:absolute;top:6px;left:-14px;box-shadow:0 0 0 1px #bfdbfe}.history-entry--comment .history-entry-body{background:#fff;border:1px solid #dbeafe;border-radius:8px;flex:1;min-width:0;padding:8px 11px;box-shadow:0 1px 3px #2563eb0f}.history-entry-header{align-items:center;gap:6px;margin-bottom:4px;display:flex}.history-entry--comment .history-entry-user{color:#1d4ed8;font-size:11px;font-weight:700}.history-entry-text{color:#334155;word-break:break-word;margin:0;font-size:12.5px;line-height:1.55}.history-entry--activity{padding-bottom:7px}.history-entry-icon{border:1.5px solid #fff;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:11px;height:11px;display:flex;position:absolute;top:5px;left:-15px}.history-entry--arrival .history-entry-icon{color:#065f46;background:#d1fae5;box-shadow:0 0 0 1px #6ee7b7}.history-entry--departure .history-entry-icon{color:#991b1b;background:#fee2e2;box-shadow:0 0 0 1px #fca5a5}.history-entry--dock .history-entry-icon{color:#1e40af;background:#dbeafe;box-shadow:0 0 0 1px #93c5fd}.history-entry--loaded .history-entry-icon{color:#92400e;background:#fef3c7;box-shadow:0 0 0 1px #fcd34d}.history-entry--status .history-entry-icon{color:#5b21b6;background:#ede9fe;box-shadow:0 0 0 1px #c4b5fd}.history-entry--default .history-entry-icon{color:#475569;background:#f1f5f9;box-shadow:0 0 0 1px #cbd5e1}.history-entry--activity .history-entry-body{background:0 0;border:none;flex:1;min-width:0;padding:0}.history-entry-event-row{flex-wrap:wrap;align-items:baseline;gap:6px;display:flex}.history-entry-badge{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;border-radius:4px;flex-shrink:0;align-items:center;gap:3px;padding:1px 6px 1px 5px;font-size:9.5px;font-weight:700;display:inline-flex}.history-badge--arrival{color:#065f46;background:#d1fae5}.history-badge--departure{color:#b91c1c;background:#fee2e2}.history-badge--dock{color:#1e40af;background:#dbeafe}.history-badge--loaded{color:#92400e;background:#fef3c7}.history-badge--status{color:#5b21b6;background:#ede9fe}.history-badge--default{color:#475569;background:#f1f5f9}.history-entry-event-text{color:#334155;word-break:break-word;font-size:12px;font-weight:500;line-height:1.45}.history-entry-meta{align-items:center;gap:5px;margin-top:2px;display:flex}.history-entry-user{color:#64748b;font-size:10.5px;font-weight:600}.history-entry-date{color:#94a3b8;margin-left:auto;font-size:10.5px}.history-entry--comment .history-entry-date{margin-left:auto}.history-entry--activity .history-entry-date{margin-left:0}.photo-capture-wrap{margin-top:8px}.photo-capture-btn{color:var(--blue);cursor:pointer;background:#2563eb12;border:1px dashed #2563eb59;border-radius:7px;align-items:center;gap:7px;padding:7px 13px;font-size:12.5px;font-weight:500;transition:background .15s,border-color .15s;display:inline-flex}.photo-capture-btn:hover{background:#2563eb21;border-color:#2563eb8c}.photo-preview-row{align-items:flex-start;gap:8px;display:flex}.photo-preview-thumb{object-fit:cover;border:1px solid #e2e8f0;border-radius:6px;max-width:120px;max-height:90px}.photo-remove-btn{color:#ef4444;cursor:pointer;background:#ef444414;border:1px solid #ef444440;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;transition:background .15s;display:flex}.photo-remove-btn:hover{background:#ef44442e}.charge-modal-comment-section{margin-bottom:14px}.charge-modal-textarea{background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-main);resize:none;box-sizing:border-box;margin-bottom:8px;padding:9px 11px;font-size:13px}.charge-modal-textarea:focus{border-color:var(--blue);outline:none}.comments-empty{color:#94a3b8;text-align:center;padding:16px 0;font-size:12px}.parking-charge-confirm{border-radius:var(--radius-md);background:#f8fafc;border:1.5px solid #e2e8f0;flex-direction:column;gap:10px;margin-bottom:4px;padding:14px 16px;display:flex}.btn-edit-pcc{border-radius:var(--radius-md);color:#64748b;cursor:pointer;background:0 0;border:1.5px dashed #cbd5e1;justify-content:center;align-items:center;gap:6px;width:100%;margin-bottom:4px;padding:7px 14px;font-size:12px;font-weight:600;transition:border-color .15s,color .15s,background .15s;display:flex}.btn-edit-pcc:hover{color:#2563eb;background:#eff6ff;border-color:#2563eb}.pcc-row{justify-content:space-between;align-items:center;display:flex}.pcc-label{color:var(--text-mid);font-size:12px;font-weight:600}.pcc-value{border-radius:6px;padding:3px 10px;font-size:12px;font-weight:700}.chargee-badge{color:#15803d;background:#dcfce7;border:1px solid #86efac}.route-badge{color:#d97706;background:#fff7ed;border:1px solid #fed7aa}.panel-empty{color:var(--text-mid);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:32px;display:flex}.panel-empty-icon{color:#94a3b8;background:#f1f5f9;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.panel-empty p{color:#94a3b8;text-align:center;font-size:13px;line-height:1.6}.charge-modal{z-index:510;background:#1e293b;border:1px solid #ffffff1a;border-bottom:none;border-radius:18px 18px 0 0;width:100%;max-width:480px;position:fixed;bottom:0;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 -8px 40px #0006}@media (width>=768px){.charge-modal{border-bottom:1px solid #ffffff1a;border-radius:16px;max-width:400px;top:50%;bottom:auto;left:50%;transform:translate(-50%,-50%)}}.charge-modal-header{color:#f1f5f9;border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.charge-modal-title{color:var(--green);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.charge-modal-body{color:#f1f5f9;flex-direction:column;gap:12px;padding:18px 20px 20px;display:flex}.charge-modal-body .field-label{color:#94a3b8}.charge-modal-desc{color:#94a3b8;margin:0;font-size:13px;line-height:1.6}.charge-modal-desc strong{color:#f1f5f9}.charge-modal-select{color:#f1f5f9;background:#0f172a;border:1px solid #ffffff1f;border-radius:8px;width:100%;padding:10px 12px;font-size:14px}.charge-modal-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.schedule-view{background:var(--bg-yard);flex-direction:column;flex:1;display:flex;overflow:hidden}.schedule-calendar{background:var(--bg-header);border-bottom:1px solid #ffffff12;padding:16px 24px 0}.cal-nav{align-items:center;gap:10px;margin-bottom:14px;display:flex}.cal-nav-btn{color:var(--text-secondary);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s,color .15s;display:flex}.cal-nav-btn:hover{color:var(--text-primary);background:#ffffff1f}.cal-month-label{color:var(--text-primary);min-width:160px;font-size:14px;font-weight:700}.cal-today-btn{color:#60a5fa;cursor:pointer;background:#2563eb2e;border:1px solid #2563eb59;border-radius:6px;padding:3px 10px;font-size:11.5px;font-weight:600;transition:background .15s}.cal-today-btn:hover{background:#2563eb47}.cal-days{gap:4px;display:flex}.cal-day{cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px 4px 10px;transition:border-color .15s;display:flex;position:relative}.cal-day:hover .cal-day-name,.cal-day:hover .cal-day-num{color:var(--text-primary)}.cal-day-name{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:10px;font-weight:700;transition:color .15s}.cal-day-num{color:var(--text-secondary);font-size:12px;font-weight:600;transition:color .15s}.cal-day.today .cal-day-name,.cal-day.today .cal-day-num{color:#60a5fa}.cal-day.selected{border-bottom-color:#2563eb}.cal-day.selected .cal-day-name,.cal-day.selected .cal-day-num{color:var(--text-primary)}.cal-day.today.selected{border-bottom-color:#60a5fa}.cal-day-badge{color:#fff;text-align:center;background:#d97706;border-radius:10px;min-width:16px;padding:0 5px;font-size:9.5px;font-weight:800;line-height:16px;position:absolute;top:4px;right:calc(50% - 14px)}.schedule-body{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.schedule-day-header{justify-content:space-between;align-items:flex-end;display:flex}.schedule-day-title{flex-direction:column;gap:2px;display:flex}.sdt-date{text-transform:uppercase;letter-spacing:.08em;color:#60a5fa;font-size:11px;font-weight:700}.sdt-full{color:var(--text-primary);text-transform:capitalize;font-size:18px;font-weight:700}.btn-add-entry{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;transition:background .15s;display:flex}.btn-add-entry:hover{background:#1d4ed8}.schedule-summary{border-radius:var(--radius-md);background:#ffffff0a;border:1px solid #ffffff14;align-items:center;gap:20px;padding:12px 16px;display:flex}.summary-counts{align-items:center;gap:8px;display:flex}.summary-pill{border-radius:20px;padding:3px 10px;font-size:11.5px;font-weight:700}.pending-pill{color:#94a3b8;background:#64748b33}.inprogress-pill{color:#fbbf24;background:#d9770633}.done-pill{color:#4ade80;background:#16a34a33}.summary-progress{flex:1;align-items:center;gap:10px;display:flex}.summary-bar{background:#ffffff1a;border-radius:3px;flex:1;height:6px;overflow:hidden}.summary-bar-fill{background:linear-gradient(90deg,#16a34a,#4ade80);border-radius:3px;height:100%;transition:width .4s}.summary-pct{color:#4ade80;text-align:right;min-width:30px;font-size:12px;font-weight:700}.entry-list{flex-direction:column;gap:8px;display:flex}.entry-card{border-radius:var(--radius-md);background:#ffffff0a;border:1.5px solid #ffffff14;align-items:center;gap:0;transition:border-color .15s,background .15s;display:flex;overflow:hidden}.entry-card:hover{background:#ffffff0f;border-color:#ffffff29}.entry-card.entry-done{opacity:.65}.entry-card.entry-done:hover{opacity:.85}.entry-status-toggle{cursor:pointer;background:0 0;border:none;border-right:1px solid #ffffff0f;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:100%;min-height:64px;transition:background .15s;display:flex}.entry-status-toggle:hover{background:#ffffff0d}.entry-status-toggle.status-pending{color:#64748b}.entry-status-toggle.status-in_progress{color:#fbbf24}.entry-status-toggle.status-done{color:#4ade80}.entry-body{cursor:pointer;flex:1;min-width:0;padding:12px 14px}.entry-main{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.entry-route{color:var(--text-primary);font-size:14px;font-weight:700}.entry-trailer{color:#93c5fd;background:#2563eb33;border:1px solid #2563eb4d;border-radius:5px;padding:1px 7px;font-size:12px;font-weight:600}.entry-door{color:#fbbf24;background:#d9770626;border:1px solid #d977064d;border-radius:5px;padding:1px 7px;font-size:12px;font-weight:600}.entry-notes{color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;margin-top:4px;font-size:12px}.entry-unassigned{color:#94a3b88c;margin-top:3px;font-size:11.5px;font-style:italic}.entry-completed-at{color:#4ade80;opacity:.8;margin-top:4px;font-size:11px;font-style:italic}.entry-edit-btn{width:28px;height:28px;color:var(--text-mid);cursor:pointer;opacity:0;background:0 0;border:1px solid #ffffff1a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-right:8px;transition:opacity .15s,background .15s,color .15s;display:flex}.entry-card:hover .entry-edit-btn{opacity:1}.entry-edit-btn:hover{color:var(--text);background:#ffffff14}.entry-delete-btn{width:28px;height:28px;color:var(--text-mid);cursor:pointer;opacity:0;background:0 0;border:1px solid #ffffff1a;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;margin-right:4px;transition:opacity .15s,background .15s,color .15s;display:flex}.entry-card:hover .entry-delete-btn{opacity:1}.entry-delete-btn:hover{color:#ef4444;background:#ef444426;border-color:#ef44444d}.entry-status-label{text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;padding:0 16px;font-size:11px;font-weight:700}.status-label-pending{color:#64748b}.status-label-in_progress{color:#fbbf24}.status-label-done{color:#4ade80}.schedule-empty{color:var(--text-secondary);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;padding:60px 0;display:flex}.schedule-empty p{color:#64748b;font-size:13.5px}.btn-add-entry-empty{color:#60a5fa;cursor:pointer;background:#2563eb26;border:1.5px solid #2563eb4d;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s}.btn-add-entry-empty:hover{background:#2563eb40}.schedule-panel-overlay{z-index:100;background:#0000008c;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.schedule-panel{border-radius:var(--radius-lg);background:#fff;flex-direction:column;width:420px;max-width:calc(100vw - 32px);animation:.2s slideUp;display:flex;overflow:hidden;box-shadow:0 24px 80px #0006}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.sp-header{border-bottom:1px solid var(--border-panel);justify-content:space-between;align-items:center;padding:18px 20px 16px;display:flex}.sp-title{color:var(--text-dark);font-size:15px;font-weight:700}.sp-body{flex-direction:column;gap:4px;padding:20px;display:flex}.sp-footer{border-top:1px solid var(--border-panel);background:#f8fafc;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.sp-footer-right{align-items:center;gap:8px;display:flex}.btn-delete{color:#dc2626;cursor:pointer;background:0 0;border:none;padding:6px 2px;font-size:13px;font-weight:600;transition:opacity .15s}.btn-delete:hover{opacity:.7}.schedule-main-layout{flex:1;display:flex;overflow:hidden}.route-week-panel{background:#ffffff05;border-right:1px solid #ffffff12;flex-direction:column;flex-shrink:0;gap:12px;width:240px;padding:20px 14px;display:flex;overflow-y:auto}.rwp-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-secondary);border-bottom:1px solid #ffffff12;padding-bottom:8px;font-size:10px;font-weight:700}.rwp-empty{color:var(--text-secondary);opacity:.7;padding:4px 0;font-size:12px;line-height:1.6}.rwp-list{flex-direction:column;gap:6px;display:flex}.rwp-row{border-radius:var(--radius-sm);background:#ffffff0a;border:1px solid #ffffff14;flex-direction:column;gap:8px;padding:8px 10px;transition:border-color .15s;display:flex}.rwp-row:hover{border-color:#ffffff24}.rwp-row-skipped{opacity:.7;background:#64748b14;border-color:#64748b33}.rwp-route-info{align-items:center;gap:8px;display:flex}.rwp-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.rwp-dot-on{background:#4ade80}.rwp-dot-off{background:#64748b}.rwp-route-text{flex-direction:column;gap:2px;display:flex}.rwp-route-name{color:var(--text-primary);font-size:13px;font-weight:700}.rwp-route-door{color:#fbbf24;background:#d977061f;border:1px solid #d9770640;border-radius:4px;width:fit-content;padding:1px 5px;font-size:10.5px;font-weight:600;display:inline-block}.rwp-row-skipped .rwp-route-name{color:var(--text-secondary);text-decoration:line-through}.rwp-btn-skip{color:#f87171;cursor:pointer;text-align:center;background:#dc26261a;border:1px solid #dc262640;border-radius:6px;width:100%;padding:5px 8px;font-family:inherit;font-size:11px;font-weight:600;transition:background .15s}.rwp-btn-skip:hover:not(:disabled){background:#dc262633}.rwp-btn-skip:disabled{opacity:.5;cursor:not-allowed}.rwp-btn-restore{color:#4ade80;cursor:pointer;text-align:center;background:#16a34a1a;border:1px solid #16a34a40;border-radius:6px;width:100%;padding:5px 8px;font-family:inherit;font-size:11px;font-weight:600;transition:background .15s}.rwp-btn-restore:hover:not(:disabled){background:#16a34a33}.rwp-btn-restore:disabled{opacity:.5;cursor:not-allowed}.sp-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin-top:4px;padding:6px 10px;font-size:12px;font-weight:500}.sp-completed-at{color:#4ade80;background:#4ade8014;border:1px solid #4ade8033;border-radius:6px;align-items:center;gap:6px;margin-top:4px;padding:7px 10px;font-size:12px;display:flex}.route-config-view{background:var(--bg-yard);flex-direction:column;flex:1;display:flex;overflow:hidden}.rc-header{background:var(--bg-header);border-bottom:1px solid #ffffff12;flex-shrink:0;padding:24px 32px}.rc-title{color:var(--text-primary);margin-bottom:4px;font-size:18px;font-weight:700}.rc-subtitle{color:var(--text-secondary);font-size:13px}.rc-body{flex-direction:column;flex:1;gap:24px;max-width:680px;padding:28px 32px;display:flex;overflow-y:auto}.rc-add-card{border-radius:var(--radius-md);background:#ffffff0a;border:1px solid #ffffff1a;padding:20px}.rc-add-title{color:var(--text-primary);margin-bottom:14px;font-size:13px;font-weight:700}.rc-add-row{gap:10px;display:flex}.rc-input{border-radius:var(--radius-sm);color:var(--text-primary);background:#ffffff12;border:1.5px solid #ffffff1f;outline:none;flex:1;padding:9px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.rc-input:focus{background:#ffffff1a;border-color:#2563eb}.rc-input::placeholder{color:var(--text-secondary);opacity:.6}.btn-rc-add{border-radius:var(--radius-sm);color:#fff;cursor:pointer;white-space:nowrap;background:#2563eb;border:none;padding:9px 18px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s}.btn-rc-add:hover:not(:disabled){background:#1d4ed8}.btn-rc-add:disabled{color:#64748b;cursor:not-allowed;background:#334155}.rc-error{color:#f87171;margin-top:8px;font-size:12px}.rc-list-section{flex-direction:column;gap:8px;display:flex}.rc-list-title{text-transform:uppercase;letter-spacing:.09em;color:var(--text-secondary);margin-bottom:4px;font-size:11px;font-weight:700}.rc-empty{color:var(--text-secondary);padding:16px 0;font-size:13px}.rc-list{flex-direction:column;gap:6px;display:flex}.rc-row{border-radius:var(--radius-md);background:#ffffff0a;border:1.5px solid #ffffff14;align-items:center;gap:12px;padding:12px 16px;transition:border-color .15s;display:flex}.rc-row:hover{border-color:#ffffff26}.rc-row-inactive{opacity:.55}.rc-status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.rc-dot-active{background:#4ade80}.rc-dot-inactive{background:#475569}.rc-route-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.rc-route-name{color:var(--text-primary);font-size:14px;font-weight:700}.rc-door-badge{color:#fbbf24;white-space:nowrap;background:#d977061f;border:1px solid #d9770640;border-radius:5px;padding:2px 7px;font-size:11px;font-weight:600}.rc-edit-fields{flex:1;gap:8px;min-width:0;display:flex}.rc-edit-input{color:var(--text-primary);background:#ffffff1a;border:1.5px solid #2563eb;border-radius:6px;outline:none;flex:1;padding:5px 9px;font-family:inherit;font-size:13px;font-weight:700}.rc-edit-door-select{color:var(--text-primary);cursor:pointer;background:#ffffff12;border:1.5px solid #ffffff26;border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:12px}.rc-door-inline select,.rc-door-select{color:var(--text-secondary);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:11.5px;transition:border-color .15s,color .15s}.rc-door-select:hover,.rc-door-inline select:hover{color:#fbbf24;border-color:#d9770680}.rc-add-days{flex-wrap:wrap;align-items:center;gap:10px;margin-top:10px;display:flex}.rc-add-days-label{color:var(--text-secondary);white-space:nowrap;font-size:12px}.rc-day-toggles{gap:5px;display:flex}.rc-day-btn{color:var(--text-secondary);cursor:pointer;background:#ffffff0d;border:1.5px solid #ffffff1a;border-radius:6px;padding:4px 9px;font-family:inherit;font-size:11.5px;font-weight:600;transition:all .15s}.rc-day-btn:hover{color:#93c5fd;border-color:#2563eb80}.rc-day-btn-on{color:#93c5fd;background:#2563eb33;border-color:#2563eb}.rc-days-inline{gap:3px;margin-right:4px;display:flex}.rc-day-pill{color:var(--text-secondary);cursor:pointer;opacity:.5;background:#ffffff0a;border:1px solid #ffffff14;border-radius:5px;padding:3px 7px;font-family:inherit;font-size:10.5px;font-weight:600;transition:all .15s}.rc-day-pill:hover{opacity:.85;border-color:#2563eb66}.rc-day-pill-on{color:#93c5fd;opacity:1;background:#2563eb2e;border-color:#2563eb99}.rc-edit-block{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.rc-edit-days{align-items:center;gap:8px;display:flex}.rc-edit-days-label{color:var(--text-secondary);white-space:nowrap;font-size:11.5px}.rc-row-badge{margin-right:4px}.rc-badge{white-space:nowrap;border-radius:20px;padding:2px 9px;font-size:11px;font-weight:600}.rc-badge-active{color:#4ade80;background:#16a34a26;border:1px solid #16a34a4d}.rc-badge-inactive{color:#64748b;background:#47556940;border:1px solid #47556966}.rc-row-actions{gap:6px;display:flex}.rc-btn-edit,.rc-btn-deactivate,.rc-btn-activate,.rc-btn-save,.rc-btn-cancel{cursor:pointer;border:none;border-radius:6px;padding:5px 11px;font-family:inherit;font-size:12px;font-weight:600;transition:background .15s,opacity .15s}.rc-btn-edit{color:var(--text-secondary);background:#ffffff12;border:1px solid #ffffff1a}.rc-btn-edit:hover{color:var(--text-primary);background:#ffffff1f}.rc-btn-deactivate{color:#f87171;background:#dc26261a;border:1px solid #dc262633}.rc-btn-deactivate:hover{background:#dc262633}.rc-btn-activate{color:#4ade80;background:#16a34a1a;border:1px solid #16a34a33}.rc-btn-activate:hover{background:#16a34a33}.rc-btn-save{color:#fff;background:#2563eb}.rc-btn-save:hover{background:#1d4ed8}.rc-btn-cancel{color:var(--text-secondary);background:#ffffff12;border:1px solid #ffffff1a}.rc-btn-cancel:hover{background:#ffffff1f}.rc-btn-delete{color:#f87171;cursor:pointer;background:#dc262614;border:1px solid #dc262640;border-radius:6px;justify-content:center;align-items:center;padding:5px 8px;font-family:inherit;transition:all .15s;display:flex}.rc-btn-delete:hover{background:#dc262633;border-color:#dc262680}.rc-btn-delete-confirm{cursor:pointer;color:#fff;background:#dc2626;border:none;border-radius:6px;padding:5px 11px;font-family:inherit;font-size:12px;font-weight:600;transition:background .15s}.rc-btn-delete-confirm:hover{background:#b91c1c}.rc-delete-confirm-text{color:#f87171;white-space:nowrap;font-size:12px;font-weight:600}.rc-info-box{border-radius:var(--radius-md);color:#93c5fd;background:#2563eb14;border:1px solid #2563eb33;align-items:flex-start;gap:10px;padding:14px 16px;display:flex}.rc-info-box svg{flex-shrink:0;margin-top:1px}.rc-info-box p{color:#93c5fd;font-size:12.5px;line-height:1.6}.rc-info-box strong{color:var(--text-primary)}.rc-page{background:var(--bg-yard);flex-direction:column;flex:1;gap:24px;padding:28px 32px;display:flex;overflow-y:auto}.rc-page-title{color:var(--text-primary);margin-bottom:4px;font-size:20px;font-weight:700}.rc-page-sub{color:var(--text-secondary);font-size:13px}.rc-add-card{border-radius:var(--radius-md);background:#ffffff0a;border:1.5px solid #ffffff1a;flex-direction:column;gap:16px;padding:20px 24px;display:flex}.rc-add-card-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:700}.rc-add-input{border-radius:var(--radius-sm);width:100%;color:var(--text-primary);background:#ffffff12;border:1.5px solid #ffffff1f;outline:none;padding:9px 13px;font-family:inherit;font-size:14px;transition:border-color .15s}.rc-add-input:focus{background:#ffffff1a;border-color:#2563eb}.rc-add-days-row{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.rc-add-btn{color:#fff;border-radius:var(--radius-sm);cursor:pointer;background:#2563eb;border:none;align-self:flex-start;padding:9px 20px;font-family:inherit;font-size:13px;font-weight:600;transition:background .15s}.rc-add-btn:hover:not(:disabled){background:#1d4ed8}.rc-add-btn:disabled{opacity:.45;cursor:not-allowed}.rc-error-msg{color:#f87171;font-size:12px;font-weight:500}.rc-section-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:700}.rc-cards{flex-direction:column;gap:12px;display:flex}.rc-card{border-radius:var(--radius-md);background:#ffffff0a;border:1.5px solid #ffffff17;transition:border-color .15s;overflow:hidden}.rc-card:hover{border-color:#ffffff29}.rc-card-inactive{opacity:.6}.rc-card-head{border-bottom:1px solid #ffffff12;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.rc-card-head-left{flex-wrap:wrap;align-items:center;gap:10px;min-width:0;display:flex}.rc-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.rc-dot-on{background:#4ade80}.rc-dot-off{background:#475569}.rc-card-name{color:var(--text-primary);white-space:nowrap;font-size:15px;font-weight:700}.rc-inline-name-input{color:var(--text-primary);background:#ffffff1a;border:1.5px solid #2563eb;border-radius:6px;outline:none;width:120px;padding:5px 10px;font-family:inherit;font-size:14px;font-weight:700}.rc-status-chip{white-space:nowrap;border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}.rc-status-active{color:#4ade80;background:#16a34a26}.rc-status-inactive{color:#64748b;background:#47556933}.rc-card-head-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.rc-card-body{flex-wrap:wrap;gap:32px;padding:16px 18px;display:flex}.rc-field-group{flex-direction:column;gap:8px;display:flex}.rc-field-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.07em;font-size:11px;font-weight:700}.rc-day-group{gap:5px;display:flex}.rc-day-toggle{color:var(--text-secondary);cursor:pointer;background:#ffffff0d;border:1.5px solid #ffffff1a;border-radius:6px;padding:5px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.rc-day-toggle:hover{color:#93c5fd;border-color:#2563eb66}.rc-day-toggle-on{color:#93c5fd;background:#2563eb33;border-color:#2563eb}.rc-select{border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;background:#ffffff12;border:1.5px solid #ffffff1f;outline:none;min-width:180px;padding:7px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.rc-select:hover,.rc-select:focus{border-color:#d9770680}.rc-select option{color:var(--text-primary);background:#1e293b}.rc-btn-primary{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:600;transition:background .15s}.rc-btn-primary:hover{background:#1d4ed8}.rc-btn-ghost{color:var(--text-secondary);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s}.rc-btn-ghost:hover{color:var(--text-primary);background:#ffffff1c}.rc-btn-danger{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;transition:background .15s}.rc-btn-danger:hover{background:#b91c1c}.rc-btn-icon-danger{color:#f87171;cursor:pointer;background:#dc262614;border:1px solid #dc262640;border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .15s;display:flex}.rc-btn-icon-danger:hover{background:#dc262633;border-color:#dc262680}.rc-confirm-text{color:#f87171;white-space:nowrap;font-size:12px;font-weight:600}.rc-loading,.rc-empty-state{color:var(--text-secondary);text-align:center;padding:24px 0;font-size:13px}.mobile-header-title{display:none}.modal-overlay{z-index:500;background:#0000008c;position:fixed;inset:0}.mobile-overlay,.mobile-bottom-nav,.mobile-zone-tabs{display:none}.mobile-hidden{display:none!important}@media (width<=1024px){.sidebar{width:180px;padding:16px 10px}.logo-title{font-size:12px}.logo-sub{font-size:9px}.content{grid-template-columns:1fr clamp(260px,22vw,320px)}.parking-zone{width:44%}.parking-grid,.hs-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}}@media (width<=768px){body{overscroll-behavior:none;touch-action:pan-x pan-y;overflow:hidden}select,input,textarea{font-size:16px!important}.sidebar{display:none}.app{flex-direction:column;height:100dvh}.main{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px));flex:1;overflow:hidden}.header{height:calc(52px + env(safe-area-inset-top,0px));padding:env(safe-area-inset-top,0px) 16px 0;justify-content:center}.header-right{display:none}.mobile-header-title{flex-direction:column;align-items:center;gap:1px;display:flex}.mobile-header-brand{color:var(--text-primary);letter-spacing:.02em;font-size:16px;font-weight:700}.mobile-header-sub{color:var(--text-secondary);letter-spacing:.06em;text-transform:uppercase;font-size:10px;font-weight:500}.dock-next-loading-mobile{color:var(--text-secondary);white-space:normal;word-wrap:break-word;background:#ffa50014;border-left:3px solid #f59e0b;border-radius:4px;align-items:center;gap:6px;margin-top:4px;padding:5px 8px;font-size:11px;font-weight:400;line-height:1.4;display:flex}.dock-next-loading-mobile svg{opacity:.8;color:#f59e0b;flex-shrink:0}.dock-next-loading-mobile strong{color:inherit;font-weight:400}.dock-list{gap:10px}.mobile-planning-view{background:var(--bg-app);flex-direction:column;flex:1;padding-bottom:90px;display:flex;overflow-y:auto}.mobile-planning-header{border-bottom:1px solid #ffffff12;align-items:baseline;gap:8px;padding:18px 16px 12px;display:flex}.mobile-planning-title{color:var(--text-primary);letter-spacing:-.01em;font-size:18px;font-weight:700}.mobile-planning-sub{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:500}.mobile-planning-days{flex-direction:column;gap:0;padding:12px 12px 0;display:flex}.mobile-planning-day{background:#ffffff08;border:1px solid #ffffff12;border-radius:12px;margin-bottom:10px;overflow:hidden}.mobile-planning-day.is-today{background:#3b82f612;border-color:#3b82f659}.mpd-header{border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:11px 14px 10px;display:flex}.mobile-planning-day.is-today .mpd-header{border-bottom-color:#3b82f633}.mpd-header-left{align-items:baseline;gap:8px;display:flex}.mpd-dayname{color:var(--text-primary);letter-spacing:-.01em;font-size:14px;font-weight:700}.mobile-planning-day.is-today .mpd-dayname{color:#60a5fa}.mpd-date{color:var(--text-secondary);font-size:11px;font-weight:400}.mpd-count{color:#60a5fa;letter-spacing:.01em;background:#3b82f626;border-radius:20px;padding:2px 9px;font-size:11px;font-weight:600}.mpd-count-empty{color:var(--text-secondary);background:#ffffff0d}.mpd-empty{color:var(--text-secondary);opacity:.5;padding:10px 14px 12px;font-size:12px;font-style:italic}.mpd-routes{flex-direction:column;gap:1px;padding:6px 8px 8px;display:flex}.mpd-route-row{border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:10px 8px;transition:background .15s;display:flex}.mpd-route-row:active{background:#ffffff0a}.mpd-route-left{align-items:center;gap:9px;display:flex}.mpd-van-icon{color:var(--text-secondary);opacity:.7;flex-shrink:0}.mobile-planning-day.is-today .mpd-van-icon{color:#60a5fa;opacity:1}.mpd-route-name{color:var(--text-primary);letter-spacing:-.01em;font-size:14px;font-weight:600}.mpd-door{color:#f59e0b;white-space:nowrap;letter-spacing:.01em;background:#f59e0b1f;border:1px solid #f59e0b40;border-radius:6px;padding:3px 10px;font-size:12px;font-weight:600}.mpd-door-unknown{color:var(--text-secondary);opacity:.6;background:#ffffff0d;border-color:#ffffff1a}.mobile-bottom-nav{height:calc(64px + env(safe-area-inset-bottom,0px));background:var(--bg-sidebar);z-index:200;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0px);border-top:1px solid #ffffff14;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 4px;font-family:inherit;font-size:10px;font-weight:600;transition:color .15s;display:flex}.mobile-nav-item.active{color:#60a5fa}.mobile-nav-arrival{color:#60a5fa;background:#2563eb1f;border:1px solid #2563eb33;border-radius:10px;margin:8px 2px}.mobile-nav-departure{color:#f87171;background:#dc26261a;border:1px solid #dc262633;border-radius:10px;margin:8px 2px}.mobile-zone-tabs{background:var(--bg-sidebar);border-bottom:1px solid #ffffff12;flex-shrink:0;gap:8px;padding:8px 12px;display:flex}.mobile-zone-tab{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:#ffffff0a;border:1.5px solid #ffffff14;flex:1;justify-content:center;align-items:center;gap:6px;padding:8px 10px;font-family:inherit;font-size:12px;font-weight:600;transition:all .15s;display:flex}.mobile-zone-tab.active{color:#60a5fa;background:#2563eb26;border-color:#2563eb59}.mobile-zone-tab-count{color:var(--text-primary);background:#ffffff1a;border-radius:10px;padding:1px 6px;font-size:11px;font-weight:700}.mobile-zone-tab.active .mobile-zone-tab-count{color:#93c5fd;background:#2563eb40}.content{flex-direction:column;display:flex;overflow:hidden}.details-panel{display:none}.yard{flex:1;overflow:hidden}.parking-zone{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;border-bottom:none;border-right:none;flex:1;width:100%;padding:12px;overflow-y:auto}.dock-zone{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;flex:1;width:100%;padding:12px;overflow-y:auto}.parking-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.hs-subzone{gap:8px;padding:10px}.hs-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}.trailer-card{cursor:pointer;min-height:76px;padding:12px 10px 0}.trailer-num{font-size:13px}.parking-status-band{color:#fff;text-align:center;white-space:nowrap;text-overflow:ellipsis;border-radius:0 0 var(--radius-md) var(--radius-md);background:var(--light-blue);width:calc(100% + 20px);margin:auto -10px 0;padding:5px 8px;font-size:9.5px;font-weight:700;display:block;overflow:hidden}.trailer-card.chargee .parking-status-band,.trailer-card.chargée .parking-status-band,.trailer-card.chargepretasortir .parking-status-band{background:var(--green)}.trailer-card.videpretasortir .parking-status-band{background:var(--cyan)}.trailer-card.horsservice .parking-status-band{background:var(--red)}.trailer-card.audockchargement .parking-status-band{background:var(--amber)}.trailer-card.audockdechargement .parking-status-band{background:var(--orange)}.dock-bay{min-height:60px}.dock-trailer-card{cursor:pointer;padding:10px 14px}.mobile-overlay{z-index:300;background:#0000008c;animation:.2s fadeIn;display:block;position:fixed;inset:0}.mobile-drawer{z-index:400;max-height:85dvh;padding-bottom:env(safe-area-inset-bottom,0px);background:#fff;border-radius:20px 20px 0 0;flex-direction:column;animation:.25s cubic-bezier(.32,.72,0,1) slideUpDrawer;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -8px 40px #00000040}@keyframes slideUpDrawer{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-drawer-handle{background:#cbd5e1;border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.mdh-header{flex-shrink:0}.mdh-header .tep-status-bar{margin:0 -20px;padding:7px 20px}.mdh-header--vide{border-top:3px solid var(--light-blue)}.mdh-header--chargee,.mdh-header--chargée,.mdh-header--chargepretasortir{border-top:3px solid var(--green)}.mdh-header--videpretasortir{border-top:3px solid var(--cyan)}.mdh-header--audockchargement{border-top:3px solid var(--amber)}.mdh-header--audockdechargement{border-top:3px solid var(--orange)}.mdh-header--horsservice{border-top:3px solid var(--red)}.mobile-drawer-body{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;flex:1;overflow-y:auto}.mobile-drawer-body .edit-section{border-bottom:1px solid var(--border-panel)}.mobile-drawer-body .edit-section-comments{flex:none;overflow:visible}.mobile-drawer-body .mdw-history{min-height:0;max-height:220px}.mobile-drawer-body .mdw-history .comments-list{max-height:150px;overflow-y:auto}.mdw-choice-list{flex-direction:column;gap:0;display:flex}.mdw-choice-btn{border:none;border-bottom:1px solid var(--border-panel);cursor:pointer;text-align:left;background:#fff;align-items:center;gap:14px;width:100%;padding:18px 20px;transition:background .12s;display:flex}.mdw-choice-btn:active{background:#f8fafc}.mdw-choice-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.mdw-choice-icon--move{color:var(--blue);background:#eff6ff}.mdw-choice-icon--status{color:var(--green);background:#f0fdf4}.mdw-choice-body{flex-direction:column;flex:1;gap:2px;display:flex}.mdw-choice-label{color:var(--text-dark);font-size:14px;font-weight:600}.mdw-choice-desc{color:var(--text-mid);font-size:12px;line-height:1.4}.mdw-choice-arrow{color:#cbd5e1;flex-shrink:0}.mdw-back-btn{color:var(--blue);cursor:pointer;background:0 0;border:none;align-items:center;gap:5px;margin-bottom:4px;padding:0;font-family:inherit;font-size:12.5px;font-weight:500;display:inline-flex}.mdw-actions{padding:14px 20px;padding-bottom:calc(14px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--border-panel);background:#fff;flex-shrink:0;gap:10px;display:flex}.mdw-actions .btn-primary,.mdw-actions .btn-secondary{border-radius:10px;flex:1;padding:13px;font-size:14px}.panel-section.mobile-arrival-modal{z-index:300;background:#0000008c;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.mobile-departure-list{flex-direction:column;gap:8px;display:flex}.mobile-departure-item{border-radius:var(--radius-sm);cursor:pointer;background:#f8fafc;border:1.5px solid #e2e8f0;align-items:center;gap:10px;width:100%;padding:13px 14px;font-family:inherit;transition:border-color .15s,background .15s;display:flex}.mobile-departure-item:active{background:#fef2f2;border-color:#fca5a5}.mobile-dep-num{color:var(--text-dark);text-align:left;flex:1;font-size:14px;font-weight:700}.mobile-dep-loc{color:var(--text-mid);white-space:nowrap;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:5px;padding:2px 8px;font-size:12px}.schedule-calendar{padding:12px 12px 0}.cal-nav{gap:8px;margin-bottom:10px}.cal-month-label{font-size:13px}.cal-days{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:2px;padding-bottom:0;overflow-x:auto}.cal-days::-webkit-scrollbar{display:none}.cal-day{flex-shrink:0;min-width:44px;padding:6px 4px 8px}.cal-day-name{font-size:9px}.cal-day-num{font-size:11px}.schedule-main-layout{flex-direction:column;overflow-y:auto}.route-week-panel.rwp-mobile{border-bottom:1px solid #ffffff12;border-right:none;flex-shrink:0;width:100%;padding:0;overflow:visible}.rwp-toggle{cursor:pointer;width:100%;color:var(--text-secondary);background:0 0;border:none;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.route-week-panel.rwp-mobile .rwp-list,.route-week-panel.rwp-mobile .rwp-empty{padding:0 16px 12px}.rwp-row{flex-wrap:wrap;gap:6px}.rwp-btn-skip,.rwp-btn-restore{padding:4px 8px;font-size:11px}.schedule-body{flex:none;gap:12px;padding:14px 12px;overflow-y:visible}.sdt-full{font-size:15px}.schedule-summary{flex-direction:column;gap:8px;padding:10px 12px}.summary-counts{flex-wrap:wrap;gap:6px}.summary-pill{padding:3px 10px;font-size:11px}.entry-card{gap:10px;padding:10px 12px}.entry-status-label{padding:2px 7px;font-size:10px}.entry-route{font-size:14px}.schedule-panel-overlay{align-items:flex-end;padding:0}.schedule-panel{border-radius:18px 18px 0 0;width:100%;max-height:92vh}}.login-root{background:var(--bg-app);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--bg-sidebar);border:1px solid #ffffff14;border-radius:16px;flex-direction:column;align-items:center;gap:0;width:100%;max-width:380px;padding:40px 36px 36px;display:flex}.login-logo{width:60px;height:60px;color:var(--blue);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:14px;justify-content:center;align-items:center;margin-bottom:20px;display:flex}.login-title{color:var(--text-primary);letter-spacing:-.3px;margin:0 0 6px;font-size:20px;font-weight:600}.login-subtitle{color:var(--text-secondary);margin:0 0 28px;font-size:13px}.login-form{flex-direction:column;gap:16px;width:100%;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-label{color:var(--text-secondary);letter-spacing:.3px;text-transform:uppercase;font-size:12px;font-weight:500}.login-input{width:100%;color:var(--text-primary);box-sizing:border-box;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .15s}.login-input:focus{border-color:var(--blue)}.login-input::placeholder{color:var(--text-secondary);opacity:.5}.login-error{color:#ef4444;background:#ef444414;border:1px solid #ef444433;border-radius:7px;margin:0;padding:8px 12px;font-size:13px}.login-btn{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:4px;padding:11px;font-size:14px;font-weight:600;transition:background .15s,opacity .15s}.login-btn:hover:not(:disabled){background:#2563eb}.login-btn:disabled{opacity:.5;cursor:not-allowed}.sidebar-user{background:var(--surface2);border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:8px;margin:12px 12px 0;padding:10px 12px;display:flex}.sidebar-user-info{min-width:0;color:var(--text-mid);flex:1;align-items:center;gap:8px;display:flex}.sidebar-user-text{flex-direction:column;min-width:0;display:flex}.sidebar-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.sidebar-user-role{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.sidebar-logout-btn{border:1px solid var(--border);width:30px;height:30px;color:var(--text-mid);cursor:pointer;background:0 0;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s,border-color .15s;display:flex}.sidebar-logout-btn:hover{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.um-root{max-width:1000px;padding:24px 28px}.um-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.um-title{color:var(--text);letter-spacing:-.3px;margin:0;font-size:18px;font-weight:600}.um-tabs{background:var(--surface2);border:1px solid var(--border);border-radius:8px;gap:4px;padding:3px;display:flex}.um-tab{color:var(--text-mid);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.um-tab:hover{color:var(--text)}.um-tab-active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000026}.um-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}.um-panel-toolbar{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:14px 16px;display:flex}.um-btn-add{background:var(--blue);color:#fff;cursor:pointer;border:none;border-radius:7px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s;display:flex}.um-btn-add:hover{background:#2563eb}.um-search{background:var(--input-bg);border:1px solid var(--border);color:var(--text);border-radius:7px;outline:none;flex:1;padding:7px 11px;font-size:13px}.um-search:focus{border-color:var(--blue)}.um-btn-refresh{background:var(--surface2);border:1px solid var(--border);width:32px;height:32px;color:var(--text-mid);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;transition:background .15s;display:flex}.um-btn-refresh:hover{background:var(--hover)}.um-table-wrap{overflow-x:auto}.um-table{border-collapse:collapse;width:100%;font-size:13px}.um-table th{text-align:left;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;background:var(--surface2);border-bottom:1px solid var(--border);padding:10px 16px;font-size:11px;font-weight:600}.um-table td{color:var(--text);vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:11px 16px}.um-table tr:last-child td{border-bottom:none}.um-table tr:hover td{background:var(--hover)}.um-row-inactive td{opacity:.5}.um-cell-username{align-items:center;gap:6px;font-weight:500;display:flex}.um-you-badge{color:var(--blue);letter-spacing:.3px;background:#3b82f61f;border:1px solid #3b82f640;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600}.um-role-badge{letter-spacing:.3px;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.um-role-jmf_admin{color:#dc2626;background:#dc26261a;border:1px solid #dc262640}.um-role-chauffeur{color:#fb923c;background:#fb923c1f;border:1px solid #fb923c40}.um-role-dispatch_jmf{color:var(--blue);background:#3b82f61f;border:1px solid #3b82f640}.um-role-bain_magique{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e40}.um-status-badge{border-radius:5px;padding:2px 8px;font-size:11px;font-weight:600}.um-status-active{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33}.um-status-inactive{color:var(--text-dim);border:1px solid var(--border);background:#ffffff0d}.um-cell-date{color:var(--text-mid);white-space:nowrap;font-size:12px}.um-cell-actions{align-items:center;gap:6px;display:flex}.um-btn-action{background:var(--surface2);border:1px solid var(--border);color:var(--text-mid);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:5px;padding:5px 10px;font-size:12px;transition:background .15s,color .15s;display:flex}.um-btn-action:hover{background:var(--hover);color:var(--text)}.um-btn-delete:hover{color:#ef4444;background:#ef44441a;border-color:#ef444440}.um-btn-delete-confirm{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:7px;padding:7px 14px;font-size:13px;font-weight:600;transition:background .15s,opacity .15s}.um-btn-delete-confirm:hover:not(:disabled){background:#dc2626}.um-btn-delete-confirm:disabled{opacity:.4;cursor:not-allowed}.um-empty{text-align:center;color:var(--text-dim);padding:40px;font-size:13px}.um-action-type{background:var(--surface2);border:1px solid var(--border);color:var(--text-mid);border-radius:5px;padding:2px 7px;font-size:12px;display:inline-block}.um-cell-details{color:var(--text-mid);text-overflow:ellipsis;white-space:nowrap;max-width:260px;font-size:12px;overflow:hidden}.um-overlay{z-index:1000;background:#0000008c;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.um-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:420px;overflow:hidden}.um-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.um-modal-title{color:var(--text);font-size:15px;font-weight:600}.um-modal-body{flex-direction:column;gap:12px;padding:20px;display:flex}.um-reset-desc{color:var(--text-mid);margin:0;font-size:13px}.um-reset-desc strong{color:var(--text)}
