@charset "UTF-8";:root{--bg: #f7f8fa;--bg-elevated: #ffffff;--bg-subtle: #f1f3f6;--bg-hover: #eef1f5;--bg-active: #e6eaf0;--surface: var(--bg-elevated);--border: #e3e6eb;--border-strong: #cdd2da;--border-focus: #2563eb;--text: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--text-muted: #94a3b8;--text-inverse: #ffffff;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-soft: #eff4ff;--accent-soft-strong: #dbe6ff;--accent-text: #1e40af;--success: #15803d;--success-soft: #ecfdf5;--success-border: #bbf7d0;--warning: #b45309;--warning-soft: #fffbeb;--warning-border: #fde68a;--danger: #b91c1c;--danger-soft: #fef2f2;--danger-border: #fecaca;--info: #1e40af;--info-soft: #eff6ff;--info-border: #bfdbfe;--neutral: #475569;--neutral-soft: #f1f5f9;--neutral-border: #cbd5e1;--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--s-8: 32px;--s-10: 40px;--s-12: 48px;--r-1: 3px;--r-2: 6px;--r-3: 8px;--r-4: 12px;--radius: var(--r-3);--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow: 0 1px 3px rgba(15, 23, 42, .06), 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 4px 12px rgba(15, 23, 42, .08), 0 2px 4px rgba(15, 23, 42, .04);--shadow-lg: 0 20px 40px rgba(15, 23, 42, .12), 0 8px 16px rgba(15, 23, 42, .06);--font-sans: -apple-system, BlinkMacSystemFont, "Inter", "SF Pro Text", "Segoe UI", system-ui, sans-serif;--font-mono: "SF Mono", "JetBrains Mono", "Roboto Mono", ui-monospace, Menlo, monospace;--row-h: 40px;--row-pad-y: 10px;--row-pad-x: 14px;--card-pad: 16px;--font-base: 13px;--font-sm: 12px;--font-xs: 11px;--font-lg: 14px;--sidebar-w: 240px;--sidebar-w-collapsed: 56px;--topbar-h: 56px}[data-density=compact]{--row-h: 32px;--row-pad-y: 6px;--row-pad-x: 10px;--card-pad: 12px;--font-base: 12px;--font-sm: 11px;--font-xs: 10px;--font-lg: 13px}[data-density=comfortable]{--row-h: 48px;--row-pad-y: 14px;--row-pad-x: 16px;--card-pad: 20px;--font-base: 14px;--font-sm: 13px;--font-xs: 12px;--font-lg: 16px}[data-theme=warm]{--bg: #faf8f5;--bg-elevated: #ffffff;--bg-subtle: #f3f0ea;--bg-hover: #ede9e1;--bg-active: #e3ddd1;--border: #e6e0d4;--accent: #b45309;--accent-hover: #92400e;--accent-soft: #fef3e3;--accent-soft-strong: #fde9c8;--accent-text: #78350f}[data-theme=violet]{--accent: #6d28d9;--accent-hover: #5b21b6;--accent-soft: #f3edff;--accent-soft-strong: #e4d6ff;--accent-text: #5b21b6}[data-theme=emerald]{--accent: #047857;--accent-hover: #065f46;--accent-soft: #ecfdf5;--accent-soft-strong: #d1fae5;--accent-text: #065f46}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-sans);font-size:var(--font-base);line-height:1.45;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;height:100%}#root{min-height:100vh}button{font-family:inherit;font-size:inherit;cursor:pointer;border:0;background:transparent;color:inherit;padding:0}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px;border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideIn{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.app,.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;transition:grid-template-columns .2s ease}.app.collapsed,.app[data-collapsed=true],.app-shell.collapsed,.app-shell[data-collapsed=true]{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.main,.main-area{display:flex;flex-direction:column;min-width:0;overflow:hidden}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden}.sidebar__brand{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border);height:var(--topbar-h);flex-shrink:0}.sidebar__logo{width:28px;height:28px;border-radius:var(--r-2);background:linear-gradient(135deg,var(--accent) 0%,var(--accent-hover) 100%);display:grid;place-items:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}.sidebar__brand-text{display:flex;flex-direction:column;line-height:1.2}.sidebar__brand-name{font-weight:600;font-size:13px}.sidebar__brand-sub{font-size:11px;color:var(--text-tertiary)}.sidebar__nav{padding:var(--s-2);flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.sidebar__group-label{font-size:11px;text-transform:uppercase;letter-spacing:0;color:var(--text-muted);padding:var(--s-3) var(--s-2) var(--s-1);font-weight:600;margin-top:var(--s-2)}.sidebar__item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-2);font-size:13px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;text-decoration:none;transition:background .1s,color .1s}.sidebar__item:hover{background:var(--bg-hover);color:var(--text);text-decoration:none}.sidebar__item.active,.sidebar__item.sidebar__item--active{background:var(--accent-soft);color:var(--accent-text);font-weight:500}.sidebar__item.active:hover,.sidebar__item.sidebar__item--active:hover{background:var(--accent-soft-strong)}.sidebar__item.active .sidebar__badge,.sidebar__item.sidebar__item--active .sidebar__badge{background:var(--accent);color:#fff}.sidebar__icon{width:16px;height:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .1s}.sidebar__item:hover .sidebar__icon,.sidebar__item.active .sidebar__icon,.sidebar__item.sidebar__item--active .sidebar__icon{color:inherit}.sidebar__label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__badge{margin-left:auto;min-width:18px;height:18px;padding:0 5px;background:var(--bg-active);color:var(--text-secondary);font-size:11px;font-weight:600;border-radius:9px;display:flex;align-items:center;justify-content:center;text-align:center}.sidebar__badge--danger,.sidebar__item.active .sidebar__badge--danger,.sidebar__item.sidebar__item--active .sidebar__badge--danger{background:var(--danger);color:var(--text-inverse)}.sidebar__footer{border-top:1px solid var(--border);padding:var(--s-3) var(--s-2);display:flex;flex-direction:column;gap:2px}.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);background:var(--bg-elevated);display:flex;align-items:center;padding:0 var(--s-6);gap:var(--s-3);position:sticky;top:0;z-index:30;flex-shrink:0}.topbar__title{font-size:var(--font-lg);font-weight:600}.topbar__sub{font-size:var(--font-sm);color:var(--text-tertiary);margin-top:1px}.topbar__spacer{flex:1}.page{flex:1;overflow-y:auto;padding:var(--s-6);display:flex;flex-direction:column;gap:var(--s-5);min-width:0;max-width:100%}.page-header{display:flex;align-items:center;gap:var(--s-3);flex-wrap:wrap}.page-header__title{font-size:var(--font-lg);font-weight:600}.page-header__spacer{flex:1}.page-title{font-size:20px;font-weight:600;margin:0;letter-spacing:0}.page-sub{font-size:13px;color:var(--text-tertiary);margin-top:4px}.card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-3);box-shadow:var(--shadow-sm);overflow:hidden}.card__header{padding:14px var(--card-pad);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px}.card__title{font-size:13px;font-weight:600;flex:1}.card__sub{font-size:11px;color:var(--text-tertiary)}.card__body{padding:var(--card-pad)}.card__footer{padding:10px var(--card-pad);border-top:1px solid var(--border);background:var(--bg-subtle);display:flex;align-items:center;gap:var(--s-3)}.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--s-3)}.kpi{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-3);padding:14px var(--card-pad)}.kpi__label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:0;font-weight:500}.kpi__value{font-size:24px;font-weight:600;margin-top:4px;letter-spacing:0}.kpi__delta{font-size:11px;color:var(--text-tertiary);margin-top:4px}.kpi__delta--up{color:var(--success)}.kpi__delta--down{color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:32px;padding:0 12px;border-radius:var(--r-2);font-size:13px;font-weight:500;background:var(--bg-elevated);color:var(--text);border:1px solid var(--border);cursor:pointer;white-space:nowrap;text-decoration:none;font-family:var(--font-sans);transition:background .1s,border-color .1s,color .1s}.btn:hover{background:var(--bg-hover)}.btn:active{background:var(--bg-active)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn svg{width:14px;height:14px;stroke-width:1.8}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn--ghost{background:transparent;border-color:transparent;color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.btn--danger{color:var(--danger);border-color:var(--danger-border);background:var(--bg-elevated)}.btn--danger:hover:not(:disabled){background:var(--danger-soft)}.btn--sm{height:26px;padding:0 8px;font-size:12px}.btn--lg{height:38px;padding:0 16px;font-size:14px}.btn--icon{width:32px;padding:0;background:transparent;border-color:transparent;color:var(--text-secondary)}.btn--icon:hover:not(:disabled){background:var(--bg-hover)}.btn--sm.btn--icon{width:26px}.table__actions{text-align:right;width:1%;white-space:nowrap}.action-menu{position:relative;display:inline-flex;justify-content:flex-end}.action-menu__trigger{width:30px;height:30px;border-color:var(--accent-soft-strong);background:var(--accent-soft);color:var(--accent-text);box-shadow:inset 0 0 0 1px #2563eb0f,var(--shadow-sm)}.action-menu__trigger svg{width:16px;height:16px;stroke-width:2.4}.action-menu__trigger:hover:not(:disabled){border-color:var(--info-border);background:var(--accent-soft-strong);color:var(--accent);transform:translateY(-1px)}.action-menu__trigger[aria-expanded=true]{border-color:var(--accent);background:var(--accent);color:var(--text-inverse);box-shadow:0 8px 18px #2563eb2e}.action-menu__panel{position:absolute;top:calc(100% + 4px);right:0;z-index:500;min-width:220px;padding:4px;border:1px solid var(--border);border-radius:var(--r-2);background:var(--bg-elevated);box-shadow:var(--shadow-md)}.action-menu__item{width:100%;min-height:30px;padding:0 10px;border:0;border-radius:var(--r-1);background:transparent;color:var(--text);cursor:pointer;display:flex;align-items:center;text-align:left;font-family:var(--font-sans);font-size:var(--font-sm);white-space:nowrap}.action-menu__item:hover:not(:disabled){background:var(--bg-hover)}.action-menu__item:disabled{cursor:not-allowed;opacity:.55}.action-menu__item--danger{color:var(--danger)}.action-menu__item--danger:hover:not(:disabled){background:var(--danger-soft)}.pickup-page--list{min-height:0}.pickup-drafts-card{flex:1 0 auto;min-height:0;overflow:visible;display:flex;flex-direction:column}.pickup-drafts-card .table{width:100%}.approvals-page{height:calc(100vh - var(--topbar-h));overflow:hidden}.approvals-page>.empty{flex:1 1 auto}.approvals-table-card{flex:1 1 auto;overflow:auto}.shipment-form-page{width:100%;max-width:1400px;margin-left:auto;margin-right:auto;align-self:stretch;padding-top:var(--s-4);padding-bottom:var(--s-4);gap:var(--s-3)}.shipment-form-page>div:first-child[style*=margin-bottom]{margin-bottom:var(--s-3)!important}.shipment-form-page .card[style*=margin-bottom]{margin-bottom:var(--s-3)!important}.shipment-form-page .card[style*="padding:var(--s-4)"]{padding:10px 16px!important}.shipment-form-page .card__header{min-height:40px;padding:10px 14px}.shipment-form-page .card__body{padding:12px 14px}.shipment-form-page .card__body[style*="gap:var(--s-4)"],.shipment-form-page .card__body[style*="gap:var(--s-5)"],.shipment-form-page [style*="gap:var(--s-4)"]{gap:var(--s-3)!important}.shipment-form-page [style*="gap:var(--s-5)"]{gap:var(--s-4)!important}.shipment-form-page .field{gap:4px;margin-bottom:0}.shipment-form-page .label{margin-bottom:2px}.shipment-form-page .input,.shipment-form-page .select{height:30px}.shipment-form-page .textarea{min-height:50px;padding-top:6px;padding-bottom:6px}.shipment-form-page .section-h{margin-bottom:6px}.shipment-form-page h1.section-h{font-size:18px}.shipment-form-page .tabs .tab,.shipment-form-page .tab{padding:7px 12px}.shipment-form-page [style*="width:80px"]{width:68px!important}.shipment-form-page [style*="width:32px; height:32px"]{width:26px!important;height:26px!important;font-size:12px!important}.shipment-form-page [style*="margin-top:15px"]{margin-top:12px!important}.shipment-form-page [style*="padding:var(--s-3) var(--s-4)"]{padding:8px 12px!important}.shipment-form-page [style*="padding:var(--s-4);"]{padding:12px!important}.shipment-form-page form>div:last-child[style*="padding:var(--s-3)"]{padding:var(--s-2) 0 var(--s-3)!important}.shipment-form-page .shipment-stepper{min-height:72px;overflow:visible;padding:10px 16px 14px!important}.shipment-form-page .shipment-stepper>div{min-height:48px}.shipment-form-page--route{overflow:hidden}.shipment-form-page--route form{display:flex;flex:1;min-height:0;flex-direction:column}.shipment-form-page--route .shipment-stepper,.shipment-form-page--route form>div:last-child{flex-shrink:0}.shipment-route-card{display:flex;flex:1;min-height:0;overflow:hidden;flex-direction:column}.shipment-route-scroll{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain}.card__body.shipment-route-scroll{flex:1 1 auto;min-height:0;max-height:100%;overflow-x:hidden;overflow-y:auto}.shipment-form-page--route-view{height:calc(100vh - var(--topbar-h));min-height:0;max-height:calc(100vh - var(--topbar-h));overflow:hidden}.shipment-form-page--route-view .shipment-detail-card{display:flex;flex:1;min-height:0;overflow:hidden;flex-direction:column}.shipment-form-page--route-view .tabs{flex-shrink:0}app-shipment-detail .shipment-detail-card>.tabs{min-height:44px;overflow-x:auto;overflow-y:hidden}app-shipment-detail .transport-card__tabs{display:inline-flex;align-items:center;gap:2px;max-width:100%;margin-bottom:var(--s-3);padding:2px;border:1px solid var(--border);border-radius:var(--r-2);background:var(--bg-subtle);overflow-x:auto}app-shipment-detail .transport-card__tab{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:28px;padding:0 10px;border:0;border-radius:var(--r-1);background:transparent;color:var(--text-secondary);font:inherit;font-size:var(--font-sm);white-space:nowrap;cursor:pointer}app-shipment-detail .transport-card__tab:hover{color:var(--text);background:var(--bg-elevated)}app-shipment-detail .transport-card__tab--active{color:var(--text);background:var(--bg-elevated);box-shadow:var(--shadow-sm);font-weight:600}app-shipment-detail .transport-card__tab-count{min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:var(--bg-subtle);color:var(--text-secondary);font-size:11px;line-height:18px;text-align:center}app-shipment-detail .transport-card__tab--active .transport-card__tab-count{background:var(--accent-soft);color:var(--accent)}app-shipment-detail .transport-card__tab-panel{min-width:0}app-shipment-detail .transport-card__tab-panel .route-leg-documents{margin-top:0;padding-top:0;border-top:0}app-shipment-detail .shipment-allocations-table{table-layout:fixed}app-shipment-detail .shipment-allocations-table th,app-shipment-detail .shipment-allocations-table td{vertical-align:middle}app-shipment-detail .shipment-allocations-table th:nth-child(2),app-shipment-detail .shipment-allocations-table td:nth-child(2){white-space:normal}.badge{display:inline-flex;align-items:center;gap:4px;height:20px;padding:0 8px;border-radius:10px;font-size:11px;font-weight:500;background:var(--neutral-soft);color:var(--neutral);border:1px solid var(--neutral-border);white-space:nowrap}.badge--success{background:var(--success-soft);color:var(--success);border-color:var(--success-border)}.badge--warning{background:var(--warning-soft);color:var(--warning);border-color:var(--warning-border)}.badge--danger{background:var(--danger-soft);color:var(--danger);border-color:var(--danger-border)}.badge--info{background:var(--info-soft);color:var(--info);border-color:var(--info-border)}.badge--accent{background:var(--accent-soft);color:var(--accent-text);border-color:var(--accent-soft-strong)}.badge--neutral{background:var(--neutral-soft);color:var(--neutral);border-color:var(--neutral-border)}.badge--solid{background:var(--text);color:#fff;border-color:var(--text)}.badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field__hint{font-size:11px;color:var(--text-tertiary);margin-top:2px}.field__error{font-size:11px;color:var(--danger);margin-top:2px}.hint{font-size:11px;color:var(--text-muted)}.error-msg{font-size:11px;color:var(--danger)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field-row--1{grid-template-columns:1fr}.field-row--3{grid-template-columns:1fr 1fr 1fr}.field-row--4{grid-template-columns:1fr 1fr 1fr 1fr}.label{display:block;font-size:11px;font-weight:500;color:var(--text-secondary);margin-bottom:4px;text-transform:uppercase;letter-spacing:0}.label.required:after{content:" *";color:var(--danger)}.label--req:after{content:" *";color:var(--danger)}.input,.select,.textarea{width:100%;height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--r-2);background:var(--bg-elevated);font-size:13px;font-family:var(--font-sans);color:var(--text);outline:none;transition:border-color .1s,box-shadow .1s}.input:focus,.select:focus,.textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1f}.input.ng-invalid.ng-touched,.select.ng-invalid.ng-touched,.textarea.ng-invalid.ng-touched{border-color:var(--danger);box-shadow:0 0 0 3px #b91c1c1a}.input::placeholder,.select::placeholder,.textarea::placeholder{color:var(--text-muted)}.textarea{padding:8px 10px;height:auto;min-height:64px;resize:vertical;line-height:1.4}.select{appearance:none;cursor:pointer}.dropdown-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:200;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-3);box-shadow:var(--shadow-md);max-height:220px;overflow-y:auto}.dropdown-panel__empty{padding:var(--s-3);color:var(--text-tertiary);font-size:var(--font-sm)}.dropdown-panel .list-row.is-disabled{cursor:not-allowed;opacity:.72;background:var(--bg-subtle)}.dropdown-panel .list-row.is-disabled:hover{background:var(--bg-subtle)}.search-wrap{position:relative;display:inline-flex;align-items:center;width:100%}.search-wrap .search-icon,.search-wrap svg{position:absolute;left:8px;width:14px;height:14px;color:var(--text-muted);pointer-events:none}.search-wrap .input{padding-left:28px}.checkbox,.radio{width:14px;height:14px;accent-color:var(--accent)}.toggle-group{display:inline-flex;border:1px solid var(--border);border-radius:var(--r-2);overflow:hidden;background:var(--bg-elevated)}.toggle-group button{padding:6px 12px;font-size:12px;border-right:1px solid var(--border);color:var(--text-secondary)}.toggle-group button:last-child{border-right:0}.toggle-group button.is-active{background:var(--accent-soft);color:var(--accent-text);font-weight:500}.required-field-focus{animation:pulse .6s ease 2;border-color:var(--accent)!important;box-shadow:0 0 0 3px #2563eb33!important}.table{width:100%;border-collapse:collapse;font-size:var(--font-base)}.table th{text-align:left;padding:var(--row-pad-y) var(--row-pad-x);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;color:var(--text-tertiary);letter-spacing:0;border-bottom:1px solid var(--border);background:var(--bg-subtle);white-space:nowrap}.table td{padding:var(--row-pad-y) var(--row-pad-x);border-bottom:1px solid var(--border);vertical-align:middle}.table tbody tr{cursor:pointer;transition:background .1s}.table tbody tr:hover,.table tbody tr:hover td{background:var(--bg-hover)}.table tbody tr.is-selected,.table tbody tr.is-selected td{background:var(--accent-soft)}.table tbody tr:last-child td{border-bottom:0}.num{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.mono{font-family:var(--font-mono);font-size:.92em}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);overflow-x:auto}.tab{padding:10px 14px;font-size:13px;color:var(--text-tertiary);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none;font-family:var(--font-sans);transition:color .1s,border-color .1s}.tab:hover{color:var(--text)}.tab.active,.tab.is-active{color:var(--accent-text);border-bottom-color:var(--accent);font-weight:500}.tab__count{margin-left:6px;background:var(--bg-active);color:var(--text-secondary);padding:0 6px;border-radius:8px;font-size:10px;font-weight:600;vertical-align:middle;min-width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}.tab.active .tab__count,.tab.is-active .tab__count{background:var(--accent-soft-strong);color:var(--accent-text)}.modal-backdrop{position:fixed;inset:0;background:#0f172a73;display:grid;place-items:center;z-index:1000;padding:32px;animation:fadeIn .15s ease}.modal{background:var(--bg-elevated);border-radius:var(--r-4);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden}.modal--lg{max-width:760px}.modal--xl{max-width:1080px}.modal__header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.modal__title{font-size:15px;font-weight:600;flex:1}.modal__body{padding:20px;overflow-y:auto;flex:1}.modal__footer{padding:12px 20px;border-top:1px solid var(--border);background:var(--bg-subtle);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0}.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:2000;width:360px;max-width:calc(100vw - 40px)}.toast{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-3);padding:12px 14px;box-shadow:var(--shadow-md);display:flex;gap:10px;animation:slideIn .2s ease-out;font-size:13px;border-left:3px solid var(--neutral)}.toast--success{border-left-color:var(--success)}.toast--warning{border-left-color:var(--warning)}.toast--error{border-left-color:var(--danger)}.toast--info{border-left-color:var(--accent)}.toast__icon{flex-shrink:0;width:18px;height:18px;margin-top:1px}.toast--success .toast__icon{color:var(--success)}.toast--warning .toast__icon{color:var(--warning)}.toast--error .toast__icon{color:var(--danger)}.toast--info .toast__icon{color:var(--accent)}.toast__body{flex:1;min-width:0}.toast__title{font-weight:600;font-size:13px}.toast__text{color:var(--text-secondary);margin-top:2px;font-size:12px}.toast__close{color:var(--text-muted);font-size:16px;line-height:1}.toast__close:hover{color:var(--text)}.spinner{width:14px;height:14px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.global-spinner{position:fixed;top:12px;right:12px;z-index:3000;background:var(--bg-elevated);border:1px solid var(--border);border-radius:999px;padding:6px 12px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);box-shadow:var(--shadow)}.live-pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--text-tertiary);padding:4px 8px;border-radius:4px;background:var(--bg-subtle)}.live-pill__dot{width:6px;height:6px;border-radius:50%;background:var(--success);box-shadow:0 0 0 3px #15803d26;animation:pulse 1.8s infinite}.live-pill--offline .live-pill__dot{background:var(--text-muted);box-shadow:0 0 0 3px #94a3b833;animation:none}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.toolbar__spacer{flex:1}.empty{text-align:center;padding:40px 20px;color:var(--text-tertiary);font-size:13px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s-3)}.empty__title{font-weight:600;color:var(--text);margin-bottom:4px;font-size:var(--font-lg)}.route{display:flex;align-items:center;gap:0;width:100%;min-width:0}.route__node{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;position:relative;z-index:1}.route__dot{width:22px;height:22px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--border-strong);display:grid;place-items:center;font-size:10px;color:var(--text-tertiary);flex-shrink:0}.route__dot--done{background:var(--success);border-color:var(--success);color:#fff}.route__dot--active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 3px var(--accent-soft)}.route__dot--pending{background:var(--bg-elevated);border-color:var(--border-strong)}.route__label{font-size:11px;color:var(--text-secondary);white-space:nowrap;text-align:center;font-weight:500}.route__sub{font-size:10px;color:var(--text-muted);white-space:nowrap}.route__line{flex:1;height:2px;background:var(--border-strong);position:relative;min-width:30px;margin:10px -1px 0;align-self:flex-start}.route__line--done{background:var(--success)}.route__line--active{background:linear-gradient(90deg,var(--success) 50%,var(--border-strong) 50%)}.route--compact .route__dot{width:16px;height:16px;font-size:9px}.route--compact .route__line{margin-top:7px;min-width:20px}.route--compact .route__label{font-size:10px}.stepper{display:flex;align-items:center;gap:0;margin-bottom:24px}.stepper__item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary)}.stepper__item.is-active{color:var(--text)}.stepper__item.is-active .stepper__num{background:var(--accent);color:#fff}.stepper__item.is-done .stepper__num{background:var(--success);color:#fff}.stepper__num{width:24px;height:24px;border-radius:50%;background:var(--bg-active);display:grid;place-items:center;font-size:11px;font-weight:600;color:var(--text-secondary)}.stepper__connector{width:32px;height:1px;background:var(--border-strong);margin:0 8px}.progress{height:6px;background:var(--bg-active);border-radius:4px;overflow:hidden}.progress__bar{height:100%;background:var(--accent);border-radius:4px;transition:width .3s ease}.progress__bar--success{background:var(--success)}.progress__bar--warning{background:var(--warning)}.two-pane{display:grid;grid-template-columns:380px 1fr;gap:16px;align-items:stretch;height:calc(100vh - var(--topbar-h) - 48px)}.two-pane__list{overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-3);display:flex;flex-direction:column}.two-pane__detail{overflow-y:auto;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--r-3);padding:var(--s-5)}.list-row{padding:12px 14px;border-bottom:1px solid var(--border);cursor:pointer;display:flex;flex-direction:column;gap:6px;transition:background .1s}.list-row:hover{background:var(--bg-hover)}.list-row.is-active{background:var(--accent-soft);border-left:3px solid var(--accent);padding-left:11px}.list-row:last-child{border-bottom:0}.divider{height:1px;background:var(--border);margin:16px 0}.section-h{font-size:12px;text-transform:uppercase;letter-spacing:0;color:var(--text-tertiary);font-weight:600;margin-bottom:10px}h1.section-h{font-size:20px;line-height:1.2;color:var(--text);text-transform:none;margin-bottom:0}.avatar{width:28px;height:28px;border-radius:50%;background:var(--bg-active);color:var(--text-secondary);display:grid;place-items:center;font-weight:600;font-size:11px;flex-shrink:0}.avatar-stack{display:flex}.avatar-stack .avatar{margin-left:-6px;border:2px solid var(--bg-elevated)}.avatar-stack .avatar:first-child{margin-left:0}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1;min-width:0}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--s-2)}.gap-3{gap:var(--s-3)}.gap-4{gap:var(--s-4)}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.text-xs{font-size:var(--font-xs)}.text-sm{font-size:var(--font-sm)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.muted{color:var(--text-tertiary)}.text-right{text-align:right}.fw-500{font-weight:500}.fw-600{font-weight:600}.tabular{font-variant-numeric:tabular-nums}.hidden{display:none!important}:root{--bg: #f4f7fa;--bg-elevated: #ffffff;--bg-subtle: #eef3f7;--bg-hover: #e8eef4;--bg-active: #dfe8f0;--surface: #ffffff;--surface-soft: #f8fafc;--surface-tint: #fbfcf8;--border: #dce3eb;--border-strong: #c3ceda;--border-focus: #1f6feb;--text: #101828;--text-secondary: #405064;--text-tertiary: #667085;--text-muted: #98a2b3;--accent: #1f6feb;--accent-hover: #185abc;--accent-soft: #eaf2ff;--accent-soft-strong: #cfe1ff;--accent-text: #174ea6;--success: #16834a;--warning: #b7791f;--danger: #c2412d;--info: #2762a8;--focus-ring: rgba(31, 111, 235, .16);--shadow-sm: 0 1px 2px rgba(16, 24, 40, .05);--shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 8px 20px rgba(16, 24, 40, .04);--shadow-md: 0 8px 24px rgba(16, 24, 40, .08), 0 2px 5px rgba(16, 24, 40, .05);--shadow-lg: 0 24px 60px rgba(16, 24, 40, .14), 0 8px 18px rgba(16, 24, 40, .08);--topbar-h: 64px}html,body{background:linear-gradient(180deg,#f8fafc 0%,var(--bg) 52%,#f2f5f8 100%)}body{min-width:320px}button,a,input,select,textarea{-webkit-tap-highlight-color:transparent}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:0 0 0 3px var(--focus-ring)}.auth-screen{min-height:100vh;display:grid;place-items:center;padding:clamp(20px,4vw,48px);background:linear-gradient(135deg,#edf4fb,#f9fbfc 48%,#fbf8f0)}.auth-shell{width:min(100%,420px)}.auth-brand{display:flex;align-items:center;justify-content:center;gap:var(--s-3);margin-bottom:var(--s-8)}.auth-logo,.sidebar__logo{background:linear-gradient(135deg,#1f6feb,#174ea6);box-shadow:inset 0 1px #ffffff47,0 10px 24px #1f6feb38}.auth-logo{width:42px;height:42px;border-radius:var(--r-3);display:grid;place-items:center;color:#fff}.auth-brand__name{font-size:15px;font-weight:700}.auth-brand__sub{color:var(--text-tertiary);font-size:var(--font-sm)}.auth-card{border-color:#c3cedacc;box-shadow:0 24px 70px #1018281f,0 3px 8px #1018280a}.auth-card__intro{padding:26px 28px 20px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#ffffffeb,#f8fafcf5)}.auth-card__eyebrow{color:var(--accent-text);font-size:var(--font-xs);font-weight:700;margin-bottom:var(--s-2);text-transform:uppercase;letter-spacing:0}.auth-card__intro h1{margin:0;font-size:22px;line-height:1.18;letter-spacing:0}.auth-card__intro p{margin:var(--s-2) 0 0;color:var(--text-secondary);font-size:var(--font-sm)}.auth-card__body{display:flex;flex-direction:column;gap:var(--s-4);padding:24px 28px 28px}.auth-code-note{display:flex;align-items:center;gap:var(--s-2);padding:10px 12px;border:1px solid var(--info-border);border-radius:var(--r-3);color:var(--info);background:var(--info-soft);font-size:var(--font-sm)}.auth-code-note__icon{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;background:#fff;flex-shrink:0}.auth-code-input{height:42px;text-align:center;font-size:18px;font-weight:700;font-variant-numeric:tabular-nums}.auth-footer{margin-top:var(--s-4);text-align:center;color:var(--text-muted);font-size:var(--font-xs)}.app-shell{background:var(--bg)}.main-area{background:linear-gradient(180deg,#f8fafc 0%,var(--bg) 360px)}.sidebar{background:#fffffff5;border-right-color:#dce3ebe6;box-shadow:inset -1px 0 #ffffffbf}.sidebar__brand{padding-inline:14px}.sidebar__brand-name{color:var(--text);font-weight:700}.sidebar__nav{padding:var(--s-3) var(--s-2);gap:var(--s-1)}.sidebar__item{min-height:34px;position:relative;border:1px solid transparent;transition:background .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.sidebar__item:hover{border-color:#dce3ebcc}.sidebar__item.active,.sidebar__item.sidebar__item--active{border-color:#cfe1fff2;box-shadow:inset 3px 0 0 var(--accent)}.sidebar__footer{background:linear-gradient(180deg,#f8fafc4d,#f8fafcd9)}.topbar{height:var(--topbar-h);background:#ffffffe6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom-color:#dce3ebe6;box-shadow:0 1px #ffffffb8}.topbar__heading{min-width:0;display:flex;flex-direction:column;gap:2px}.topbar__title{font-size:15px;line-height:1.2;font-weight:700}.topbar__sub{max-width:min(58vw,640px);overflow:hidden;color:var(--text-tertiary);text-overflow:ellipsis;white-space:nowrap}.page{padding:clamp(18px,2.2vw,32px);gap:var(--s-5)}.page-header{align-items:flex-end;padding-bottom:var(--s-1)}.page-header__title{font-size:20px;line-height:1.2;font-weight:700}.card{border-color:#dce3ebeb;box-shadow:var(--shadow-sm)}.card__header{min-height:50px;background:linear-gradient(180deg,#fffffff5,#f8fafcc7)}.card__title{color:var(--text);font-weight:700}.kpis{gap:var(--s-4)}.kpi{position:relative;min-height:104px;padding:16px 18px;overflow:hidden;background:linear-gradient(180deg,#fffffffa,#f9fbfceb);border-color:#dce3ebeb;box-shadow:var(--shadow-sm)}.kpi:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent),#25a55f 48%,#d69e2e 100%)}.kpi__label{letter-spacing:0}.kpi__value{font-size:28px;line-height:1.05}.btn{min-width:0;transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease,transform .14s ease}.btn:hover:not(:disabled){box-shadow:var(--shadow-sm)}.btn--primary{box-shadow:0 8px 18px #1f6feb38}.btn--primary:hover:not(:disabled){transform:translateY(-1px)}.btn--success{background:var(--success);border-color:var(--success);color:#fff}.btn--success:hover:not(:disabled){background:#106b3b;border-color:#106b3b}.input,.select,.textarea{background:#fff;border-color:var(--border)}.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}.input:focus,.select:focus,.textarea:focus{box-shadow:0 0 0 3px var(--focus-ring)}.table{border-collapse:separate;border-spacing:0}.table th{background:#f7f9fc;color:var(--text-tertiary);letter-spacing:0}.table td{background:var(--bg-elevated)}.table tbody tr:hover td{background:#f6f9fc}.badge{font-weight:700}.empty{min-height:180px;border-radius:var(--r-3);color:var(--text-tertiary)}.empty svg{color:var(--text-muted)}.list-row{background:var(--bg-elevated)}.list-row:hover{background:#f6f9fc}.avatar{background:linear-gradient(135deg,var(--accent-soft),#f3f8ef);color:var(--accent-text);border:1px solid rgba(207,225,255,.9)}.live-pill{border:1px solid rgba(220,227,235,.9);background:#f8fafce6;font-weight:700}.overview-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.7fr);gap:var(--s-5);align-items:start}.overview-card{min-width:0}.overview-card--wide{grid-column:1/-1}.filter-card{padding:0;overflow:visible}.shipment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--s-4)}.shipment-card{cursor:pointer;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.shipment-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px)}.shipment-card__header{gap:var(--s-3)}.shipment-card__mode{width:30px;height:30px;border-radius:var(--r-2);display:grid;place-items:center;flex-shrink:0;font-size:12px;font-weight:800;color:var(--accent-text);background:var(--accent-soft);border:1px solid var(--accent-soft-strong)}.shipment-card__mode--road{color:#12633d;background:#ecfdf3;border-color:#bdeacb}.shipment-card__mode--air{color:#174ea6;background:#eaf2ff;border-color:#cfe1ff}.shipment-card__mode--sea{color:#0f5f78;background:#e7f7fb;border-color:#bce9f4}.shipment-card__mode--default{color:var(--neutral);background:var(--neutral-soft);border-color:var(--neutral-border)}.shipment-card__body{display:flex;flex-direction:column;gap:var(--s-3)}.shipment-card__dates{display:grid;grid-template-columns:1fr 1fr;gap:var(--s-2);padding:var(--s-3);border:1px solid var(--border);border-radius:var(--r-3);background:var(--surface-soft)}.spinner--light{width:14px;height:14px;border-color:#ffffff57;border-top-color:#fff}.carriers-page{gap:var(--s-5)}.carrier-metrics,.shipment-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--s-3)}.metric-card,.shipment-stat{min-width:0;min-height:86px;padding:14px 16px;border:1px solid rgba(220,227,235,.94);border-radius:var(--r-3);background:linear-gradient(180deg,#fffffffa,#f8fafceb);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;justify-content:space-between;gap:var(--s-2)}.metric-card__label,.shipment-stat span{color:var(--text-tertiary);font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:0}.metric-card strong,.shipment-stat strong{color:var(--text);font-size:24px;line-height:1;font-weight:800}.metric-card__chips{display:flex;flex-wrap:wrap;gap:6px}.mode-chip{display:inline-flex;align-items:center;min-height:22px;padding:3px 8px;border-radius:999px;border:1px solid var(--neutral-border);background:var(--neutral-soft);color:var(--neutral);font-size:11px;line-height:1.2;font-weight:700;white-space:nowrap}.mode-chip--road{color:#12633d;background:#ecfdf3;border-color:#bdeacb}.mode-chip--air{color:#174ea6;background:#eaf2ff;border-color:#cfe1ff}.mode-chip--sea{color:#0f5f78;background:#e7f7fb;border-color:#bce9f4}.mode-chip--default{color:var(--neutral);background:var(--neutral-soft);border-color:var(--neutral-border)}.mode-chip--ready{color:var(--success);background:var(--success-soft);border-color:var(--success-border)}.carrier-layout{display:grid;grid-template-columns:minmax(420px,.95fr) minmax(360px,.75fr);gap:var(--s-5);align-items:start}.carrier-directory,.carrier-detail{min-width:0;border:1px solid rgba(220,227,235,.94);border-radius:var(--r-3);background:var(--bg-elevated);box-shadow:var(--shadow-sm)}.carrier-directory{overflow:hidden}.carrier-directory__toolbar{padding:var(--s-4);border-bottom:1px solid var(--border);background:linear-gradient(180deg,#fff,var(--surface-soft));display:grid;grid-template-columns:minmax(240px,1fr) auto;gap:var(--s-3);align-items:center}.carrier-search{min-width:0}.carrier-mode-tabs{display:flex;gap:6px;overflow-x:auto;justify-content:flex-end}.carrier-mode-tab{min-height:32px;padding:0 10px;border:1px solid var(--border);border-radius:var(--r-2);background:#fff;color:var(--text-secondary);display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;white-space:nowrap}.carrier-mode-tab:hover{border-color:var(--border-strong);background:var(--bg-hover)}.carrier-mode-tab.is-active{color:var(--accent-text);background:var(--accent-soft);border-color:var(--accent-soft-strong)}.carrier-mode-tab span{min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#ffffffb8;display:inline-flex;align-items:center;justify-content:center}.carrier-list{max-height:calc(100vh - 350px);min-height:360px;overflow-y:auto;padding:var(--s-2);display:flex;flex-direction:column;gap:var(--s-2)}.carrier-row{width:100%;min-width:0;padding:12px;border:1px solid transparent;border-radius:var(--r-3);background:transparent;display:grid;grid-template-columns:42px minmax(0,1fr) auto;gap:var(--s-3);align-items:center;text-align:left}.carrier-row:hover{background:#f6f9fc;border-color:var(--border)}.carrier-row.is-active{background:var(--accent-soft);border-color:var(--accent-soft-strong);box-shadow:inset 3px 0 0 var(--accent)}.carrier-row__avatar,.carrier-detail__avatar{width:42px;height:42px;border-radius:var(--r-2);border:1px solid rgba(207,225,255,.94);background:linear-gradient(135deg,var(--accent-soft),#edf8ef);color:var(--accent-text);display:grid;place-items:center;font-weight:800}.carrier-row__main{min-width:0;display:flex;flex-direction:column;gap:4px}.carrier-row__title,.carrier-row__meta{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.carrier-row__title{font-weight:800;color:var(--text)}.carrier-row__meta{color:var(--text-tertiary);font-size:var(--font-sm)}.carrier-row__chips{display:flex;gap:5px;flex-wrap:wrap}.carrier-row__score{min-width:34px;height:30px;padding:0 8px;border-radius:var(--r-2);background:var(--surface-soft);color:var(--text-secondary);border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;font-weight:800;font-variant-numeric:tabular-nums}.carrier-list-state{min-height:260px;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;gap:var(--s-2)}.carrier-list-state--inline{min-height:auto;justify-content:flex-start;padding:var(--s-2) 0}.carrier-empty svg,.shipment-empty svg,.carrier-detail__empty svg{width:48px;height:48px}.carrier-detail{position:sticky;top:calc(var(--topbar-h) + var(--s-5));max-height:calc(100vh - var(--topbar-h) - 56px);overflow-y:auto;padding:var(--s-5)}.carrier-detail__empty{min-height:360px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s-3);color:var(--text-muted)}.carrier-detail__header{min-width:0;display:grid;grid-template-columns:52px minmax(0,1fr) auto;gap:var(--s-3);align-items:center}.carrier-detail__avatar{width:52px;height:52px;font-size:18px}.carrier-detail__identity{min-width:0}.carrier-detail__identity h2{margin:0;font-size:18px;line-height:1.2;overflow-wrap:anywhere}.carrier-detail__identity span{display:block;margin-top:4px;color:var(--text-tertiary);font-size:var(--font-sm)}.carrier-detail__actions{display:flex;gap:var(--s-2);margin-top:var(--s-4);flex-wrap:wrap}.carrier-detail__section{padding-top:var(--s-5);margin-top:var(--s-5);border-top:1px solid var(--border)}.carrier-facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--s-3)}.carrier-fact{min-width:0;padding:var(--s-3);border:1px solid var(--border);border-radius:var(--r-2);background:var(--surface-soft);display:flex;flex-direction:column;gap:8px}.carrier-fact span,.carrier-contact span,.carrier-note span{color:var(--text-tertiary);font-size:var(--font-xs);font-weight:700;text-transform:uppercase;letter-spacing:0}.carrier-fact strong{min-width:0;color:var(--text);font-size:var(--font-sm);display:flex;gap:5px;flex-wrap:wrap;overflow-wrap:anywhere}.carrier-contact-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--s-2)}.carrier-contact{min-width:0;padding:var(--s-3);border:1px solid var(--border);border-radius:var(--r-2);background:#fff;display:flex;flex-direction:column;gap:5px;text-decoration:none}.carrier-contact:hover{border-color:var(--border-strong);background:#f9fbfd;text-decoration:none}.carrier-contact strong{min-width:0;color:var(--text);font-size:var(--font-sm);font-weight:700;overflow-wrap:anywhere}.carrier-note{padding:var(--s-3) 0;color:var(--text-secondary);white-space:pre-wrap;overflow-wrap:anywhere}.carrier-note+.carrier-note{border-top:1px solid var(--border)}.carrier-note span{display:block;margin-bottom:6px}.carrier-comments{display:flex;flex-direction:column;gap:var(--s-2)}.carrier-comment{margin:0;padding:var(--s-3);border:1px solid var(--border);border-radius:var(--r-2);background:var(--surface-soft)}.carrier-comment__meta{display:flex;align-items:center;gap:var(--s-2);flex-wrap:wrap;margin-bottom:6px}.carrier-comment__meta strong{font-size:var(--font-xs)}.carrier-comment__meta span{color:var(--text-muted);font-size:var(--font-xs)}.carrier-comment p{margin:0;white-space:pre-wrap;overflow-wrap:anywhere}.carrier-comments-empty{padding:var(--s-2) 0 var(--s-3)}.carrier-comment-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--s-2);align-items:end;margin-top:var(--s-3)}.carrier-modal{max-height:92vh}.carrier-modal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--s-3)}.carrier-modal-grid__wide{grid-column:1/-1}.mode-checks{display:flex;flex-wrap:wrap;gap:var(--s-2)}.mode-check{min-height:34px;padding:0 10px;border:1px solid var(--border);border-radius:var(--r-2);background:var(--surface-soft);display:inline-flex;align-items:center;gap:8px;font-weight:700}.carrier-phone-list{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-2)}.carrier-phone-row{display:grid;grid-template-columns:150px minmax(0,1fr) auto;gap:var(--s-2);align-items:center}.shipments-list-view{gap:var(--s-4);color:#111827}.shipments-list-header{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s-4)}.shipments-list-header h1{margin:0;color:#111827;font-size:20px;line-height:1.2;font-weight:700}.shipments-count{margin-top:4px;color:#64748b;font-size:var(--font-sm);line-height:1.2}.shipments-list-actions{display:flex;align-items:center;gap:var(--s-2)}.shipments-export-btn,.shipments-new-btn{height:32px;padding-inline:12px;font-size:13px;border-radius:var(--r-2)}.shipments-export-btn{background:#fff;border-color:#e1e7ef;color:#1f2937}.shipments-new-btn{padding-inline:16px}.shipments-list-toolbar{display:grid;grid-template-columns:minmax(240px,420px) minmax(132px,160px) minmax(160px,220px) 1fr auto;gap:var(--s-2);align-items:center}.shipments-list-search .input,.shipments-mode-select,.shipments-status-select{height:32px;border-color:#dfe5ed;border-radius:var(--r-2);color:#111827;font-size:var(--font-sm)}.shipments-list-search .input{padding-left:32px}.shipments-mode-select,.shipments-status-select{padding-right:30px;background-image:linear-gradient(45deg,transparent 50%,#52647c 50%),linear-gradient(135deg,#52647c 50%,transparent 50%);background-position:calc(100% - 14px) 13px,calc(100% - 9px) 13px;background-repeat:no-repeat;background-size:5px 5px}.shipments-list-search .search-icon{left:11px;width:15px;height:15px;color:#8da0bb}.shipments-more-btn{grid-column:5;height:32px;padding-inline:8px;color:#1f2937;font-size:var(--font-sm);font-weight:600}.shipments-more-btn svg{width:14px;height:14px}.shipments-more-btn.is-active{background:var(--accent-soft);color:var(--accent-text)}.shipments-extra-filters{margin-top:-6px;padding:8px 10px;border:1px solid #dfe5ed;border-radius:var(--r-2);background:#fff;display:flex;align-items:center;gap:var(--s-3);flex-wrap:wrap}.shipments-extra-filters label{display:inline-flex;align-items:center;gap:6px;color:#475569;font-size:var(--font-sm);font-weight:500}.shipment-error{display:flex;align-items:center;justify-content:space-between;gap:var(--s-3);color:var(--danger)}.shipment-list-panel{overflow:hidden;border:1px solid #dfe5ed;border-radius:var(--r-2);background:#fff}.shipment-list-panel--empty{min-height:160px;color:#64748b;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s-3)}.shipment-list-row{width:100%;min-height:116px;padding:16px 18px;border-bottom:1px solid #dfe5ed;background:#fff;display:grid;grid-template-columns:minmax(260px,.85fr) minmax(520px,1.45fr) minmax(180px,.32fr);gap:var(--s-5);align-items:center;text-align:left;transition:background .14s ease}.shipment-list-row:hover{background:#f9fbfd}.shipment-list-row:last-child{border-bottom:0}.shipment-row-info{min-width:0}.shipment-row-meta{min-width:0;display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:6px}.shipment-number{color:#64748b;font-size:var(--font-sm);font-weight:600;font-family:var(--font-mono)}.shipment-mode-pill,.shipment-status-pill{min-height:22px;padding:2px 8px;border-radius:999px;border:1px solid #dfe5ed;display:inline-flex;align-items:center;gap:5px;font-size:12px;line-height:1.2;font-weight:600}.shipment-mode-pill svg{width:13px;height:13px}.shipment-mode--road,.shipment-mode--default,.shipment-mode--sea,.shipment-mode--air{color:#52647c;background:#f3f6f9}.shipment-status-pill span{width:6px;height:6px;border-radius:50%;background:currentColor}.shipment-status--moving{color:#2554b8;background:#eef5ff;border-color:#cfe0ff}.shipment-status--approval{color:#b76512;background:#fff8e6;border-color:#f9d77a}.shipment-status--arrived{color:#15934e;background:#ecfdf3;border-color:#bdf3cb}.shipment-status--planned{color:#2554b8;background:#eef5ff;border-color:#cfe0ff}.shipment-status--draft{color:#52647c;background:#f3f6f9;border-color:#dfe5ed}.shipment-status--danger{color:#b42318;background:#fff1f0;border-color:#ffccc7}.shipment-row-title{color:#111827;font-size:var(--font-lg);line-height:1.25;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shipment-row-route{margin-top:4px;color:#718199;font-size:var(--font-sm);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shipment-progress{--progress: 0%;--stage-count: 4;position:relative;min-width:0;padding:14px 8px}.shipment-progress__track{position:absolute;left:16px;right:16px;top:50%;height:2px;border-radius:999px;background:#cfd7e3;transform:translateY(-50%)}.shipment-progress__fill{display:block;width:var(--progress);height:100%;border-radius:inherit;background:#16834a}.shipment-progress__steps{position:relative;z-index:1;display:grid;grid-template-columns:repeat(var(--stage-count),minmax(0,1fr));align-items:center}.shipment-progress__node{justify-self:center;width:20px;height:20px;border-radius:50%;border:2px solid #cbd5e1;background:#fff;color:#8a9ab0;display:grid;place-items:center;font-size:11px;line-height:1;font-weight:800}.shipment-progress__node.is-done{border-color:#16834a;background:#16834a;color:#fff}.shipment-progress__node.is-current{border-color:#dbe8ff;background:#2563eb;color:#fff;box-shadow:0 0 0 3px #e8f0ff}.shipment-route-status{--stage-count: 4;position:relative;min-width:0;padding:6px 0}.shipment-route-status__rail{position:absolute;left:18px;right:18px;top:27px;height:2px;border-radius:999px;background:#d7dee9}.shipment-route-status__steps{position:relative;z-index:1;display:grid;grid-template-columns:repeat(var(--stage-count),minmax(168px,1fr));gap:12px;min-width:0;overflow-x:auto;padding:0 2px 7px;scrollbar-width:thin;scrollbar-color:#cbd5e1 transparent}.shipment-route-status__steps::-webkit-scrollbar{height:6px}.shipment-route-status__steps::-webkit-scrollbar-thumb{border-radius:999px;background:#cbd5e1}.shipment-route-status__step{--route-color: #64748b;--route-bg: #f8fafc;--route-border: #dfe5ed;min-width:0;display:grid;grid-template-columns:34px minmax(0,1fr);align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--route-border);border-left:4px solid var(--route-color);border-radius:10px;background:var(--route-bg);color:#111827}.shipment-route-status__marker{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;background:var(--route-color);font-size:13px;line-height:1;font-weight:800}.shipment-route-status__body{min-width:0;display:flex;flex-direction:column;gap:4px}.shipment-route-status__name,.shipment-route-status__label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shipment-route-status__name{color:#334155;font-size:13px;line-height:1.15;font-weight:700}.shipment-route-status__label{color:#64748b;font-size:12px;line-height:1.15;font-weight:600}.shipment-route-status--missing{--route-color: #b42318;--route-bg: #fff7f7;--route-border: #ffd1cc}.shipment-route-status--waiting{--route-color: #ca8a04;--route-bg: #fffbeb;--route-border: #fde68a}.shipment-route-status--transit{--route-color: #ea580c;--route-bg: #fff7ed;--route-border: #fed7aa}.shipment-route-status--customs{--route-color: #0284c7;--route-bg: #f0f9ff;--route-border: #bae6fd}.shipment-route-status--unloaded{--route-color: #16a34a;--route-bg: #f0fdf4;--route-border: #bbf7d0}.shipment-route-status--recipient,.shipment-route-status--unknown{--route-color: #64748b;--route-bg: #f8fafc;--route-border: #dfe5ed}.shipment-row-finance{min-width:0;text-align:right;display:flex;flex-direction:column;gap:4px}.shipment-row-finance strong{color:#111827;font-size:var(--font-lg);line-height:1.1;font-weight:700}.shipment-row-finance span{color:#64748b;font-size:var(--font-sm);line-height:1.25}.shipment-row-carrier{color:#2452b8!important;font-weight:600}.shipment-row-carrier--muted{color:#94a3b8!important}@media(max-width:1100px){.topbar__sub{display:none}.carrier-metrics,.shipment-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.carrier-layout{grid-template-columns:1fr}.carrier-detail{position:static;max-height:none}.shipments-list-toolbar{grid-template-columns:minmax(260px,1fr) auto minmax(180px,240px)}.shipments-more-btn{grid-column:1/-1;justify-self:end}.shipment-list-row{grid-template-columns:minmax(260px,.9fr) minmax(420px,1.2fr)}.shipment-row-finance{grid-column:1/-1;text-align:left;display:grid;grid-template-columns:auto auto minmax(0,1fr);align-items:center}}@media(max-width:860px){:root{--topbar-h: 58px}.app-shell,.app-shell.collapsed{grid-template-columns:var(--sidebar-w-collapsed) 1fr}.sidebar__brand{justify-content:center;padding-inline:var(--s-2)}.sidebar__brand-text,.sidebar__label,.sidebar__badge,.sidebar__group-label{display:none}.sidebar__item{justify-content:center;padding-inline:0}.topbar{padding-inline:var(--s-4);gap:var(--s-2)}.topbar .live-pill,.topbar .avatar+.text-sm{display:none}.page{padding:var(--s-4)}.field-row,.field-row--3,.field-row--4{grid-template-columns:1fr}.two-pane{grid-template-columns:1fr;height:auto}.overview-grid,.shipment-grid,.carrier-directory__toolbar,.shipment-toolbar__body{grid-template-columns:1fr}.shipments-list-header{align-items:flex-start;flex-direction:column}.shipments-list-actions{width:100%}.shipments-list-actions .btn{flex:1}.shipments-list-toolbar{grid-template-columns:1fr}.shipments-more-btn{grid-column:auto;justify-self:stretch}.shipment-list-row{grid-template-columns:1fr;gap:var(--s-3);padding:14px}.shipment-progress{padding-inline:0}.shipment-row-finance{grid-column:auto;grid-template-columns:1fr;gap:5px}.carrier-mode-tabs{justify-content:flex-start}.carrier-list{max-height:none}.carrier-facts,.carrier-contact-grid,.carrier-modal-grid{grid-template-columns:1fr}}@media(max-width:560px){.auth-screen{padding:var(--s-4)}.auth-card__intro,.auth-card__body{padding-inline:var(--s-5)}.toast-stack{right:var(--s-3);bottom:var(--s-3);max-width:calc(100vw - 24px)}.page-header{align-items:flex-start}.kpis,.carrier-metrics,.shipment-summary{grid-template-columns:1fr}.carrier-row{grid-template-columns:36px minmax(0,1fr)}.carrier-row__score{display:none}.carrier-detail__header{grid-template-columns:44px minmax(0,1fr) auto}.carrier-detail__avatar{width:44px;height:44px}.carrier-comment-form,.carrier-phone-row,.shipment-card__dates{grid-template-columns:1fr}.shipment-card__line{grid-template-columns:1fr;gap:3px}.shipments-list-header h1{font-size:20px}.shipments-count,.shipments-export-btn,.shipments-new-btn,.shipments-list-search .input,.shipments-mode-select,.shipments-status-select{font-size:var(--font-sm)}.shipment-row-title{font-size:var(--font-lg)}.shipment-row-route,.shipment-row-finance span,.shipment-mode-pill,.shipment-status-pill{font-size:var(--font-sm)}}
