:root{--navy:#fff;--accent:#108a5e;--surface:#fff;--surface2:#f0f4ff;--border:#dde3f0;--border2:#b8c4dd;--text:#1a1d3b;--muted:#6b7a99;--green:#16a34a;--amber:#f70;--red:#ec1c24;--blue:#2e3192;--mono:"JetBrains Mono", monospace;--sans:"Plus Jakarta Sans", sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;background:#f0f4ff;min-height:100vh;font-size:16px;overflow-x:hidden}.dash-header-left{align-items:center;gap:1rem;display:flex}.dash-header-back{color:#ffffffb3;font-family:var(--mono);border:1px solid #ffffff40;border-radius:5px;padding:.3rem .65rem;font-size:.8rem;line-height:1;text-decoration:none;transition:all .15s}.dash-header-back:hover{color:var(--accent);border-color:var(--accent)}.dash-header-logo-block{flex-direction:column;gap:.05rem;display:flex}.dash-header-logo{font-family:var(--mono);letter-spacing:.2em;color:#fff;font-size:.95rem;font-weight:600;line-height:1}.dash-header-logo-sub{font-family:var(--mono);letter-spacing:.14em;color:#ffffff8c;text-transform:uppercase;font-size:.55rem}.dash-header-divider{background:#fff3;width:1px;height:24px}.dash-header-page{flex-direction:column;gap:.05rem;display:flex}.dash-header-page-label{font-family:var(--mono);letter-spacing:.16em;color:var(--accent);text-transform:uppercase;font-size:.55rem;font-weight:600}.dash-header-page-title{color:#fff;letter-spacing:-.01em;font-size:.88rem;font-weight:600}.dash-header-user{font-family:var(--mono);color:#ffffffb3;text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:.72rem;overflow:hidden}.dash-header-btn{color:#ffffffb3;height:32px;font-family:var(--mono);letter-spacing:.06em;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #ffffff40;border-radius:5px;padding:0 .85rem;font-size:.72rem;transition:all .15s}.dash-header-btn:hover{color:#fff;border-color:var(--accent)}.dash-footer{border-top:1px solid var(--border);background:#2e31920a;flex-shrink:0;justify-content:space-between;align-items:center;padding:.85rem 2rem;display:flex}.dash-footer-left,.dash-footer-right{font-family:var(--mono);color:var(--muted);letter-spacing:.06em;font-size:.65rem}.auth-gate{z-index:999;background:#f0f4ff;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.auth-box{text-align:center;border:1px solid var(--border2);background:#fff;border-radius:12px;flex-direction:column;align-items:center;gap:.75rem;min-width:280px;padding:2.5rem;display:flex;box-shadow:0 4px 24px #2e319214}.auth-logo{font-family:var(--mono);letter-spacing:.2em;color:#2e3192;font-size:1.1rem;font-weight:600}.auth-box h2{color:var(--text);font-size:1rem;font-weight:600}.auth-box p{color:var(--muted);font-size:.85rem}.btn-back{font-family:var(--mono);color:var(--accent);margin-top:.5rem;font-size:.78rem;text-decoration:none}.btn-back:hover{text-decoration:underline}.loading-bar{z-index:999;background:linear-gradient(90deg,#108a5e,#0fca80,#108a5e) 0 0/200% 100%;height:2px;animation:1.2s linear infinite loadingSlide;position:fixed;top:0;left:0;right:0}@keyframes loadingSlide{0%{background-position:200% 0}to{background-position:-200% 0}}.error-banner{color:var(--red);font-family:var(--mono);background:#ec1c2414;border-bottom:1px solid #ec1c2433;padding:.6rem 2rem;font-size:.78rem}.skel-cell{background:linear-gradient(90deg, var(--surface2) 25%, var(--border) 50%, var(--surface2) 75%);background-size:200% 100%;border-radius:4px;width:80%;height:12px;animation:1.2s infinite skel-shimmer}@keyframes skel-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.hidden{display:none!important}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:#0a0f1a}::-webkit-scrollbar-thumb{background:#ff7700b5;border-radius:3px}.shell{flex:1;display:flex;overflow:hidden}header{z-index:40;background:#2e3192;border-bottom:1px solid #1e2270;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 20px;display:flex;position:sticky;top:0}header .logo{color:#fff}header .hdr-btn{color:#ffffffb3;border-color:#ffffff40}header .hdr-btn:hover{color:#fff;border-color:var(--accent)}header .header-meta{color:#fff9}header #currentUser{color:#fffc}header .hamburger-btn{color:#ffffffb3}header .hamburger-btn:hover{color:#fff}header a[href=\/].dash-header-back{color:#ffffffb3!important;border-color:#ffffff40!important}header a[href=\/].dash-header-back:hover{color:var(--accent)!important;border-color:var(--accent)!important}header .search-wrap input{color:#fff;background:#ffffff1f;border-color:#fff3}header .search-wrap input::placeholder{color:#ffffff80}header .search-wrap input:focus{border-color:var(--accent)}header .search-icon{color:#ffffff80}header span[style*="color:var(--muted)"],header span[style*="color: var(--muted)"]{color:#ffffff8c!important}header span[style*="color:var(--text)"],header span[style*="color: var(--text)"]{color:#fff!important}header span[style*="color:var(--accent)"],header span[style*="color: var(--accent)"]{color:#f70!important}header div[style*="background:var(--border2)"],header div[style*="background: var(--border2)"]{background:#fff3!important}.logo{font-family:var(--mono);letter-spacing:.18em;color:#fff;align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.logo-badge{font-size:1.1rem}.header-right{align-items:center;gap:10px;display:flex}.hdr-btn{color:#ffffffb3;height:30px;font-size:.72rem;font-family:var(--mono);letter-spacing:.06em;cursor:pointer;background:0 0;border:1px solid #ffffff40;border-radius:5px;padding:0 12px;transition:all .15s}.hdr-btn:hover{color:#fff;border-color:var(--accent)}.header-meta{font-family:var(--mono);color:#fff9;letter-spacing:.04em;align-items:center;gap:8px;font-size:.7rem;display:flex}.search-wrap{position:relative}.search-icon{color:#ffffff80;font-size:.9rem;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-wrap input{color:#fff;width:260px;height:32px;font-family:var(--mono);background:#ffffff1f;border:1px solid #fff3;border-radius:6px;outline:none;padding:0 12px 0 30px;font-size:.72rem;transition:border-color .15s}.search-wrap input:focus{border-color:var(--accent)}.search-wrap input::placeholder{color:#ffffff80}aside{border-right:1px solid var(--border);background:#fff;flex-direction:column;flex-shrink:0;width:220px;transition:width .25s,opacity .25s;display:flex;overflow-y:auto}aside.collapsed{opacity:0;border-right:none;width:0;overflow:hidden}.aside-section{border-bottom:1px solid var(--border);padding:14px 14px 8px}.aside-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:6px;font-size:.55rem}.aside-item{cursor:pointer;color:var(--muted);border-radius:5px;justify-content:space-between;align-items:center;margin-bottom:2px;padding:6px 8px;font-size:.78rem;transition:all .12s;display:flex}.aside-item:hover{color:var(--text);background:#f0f4ff}.aside-item.active{color:#2e3192;background:#2e319214}.aside-item-left{align-items:center;gap:6px;display:flex}.aside-count{font-family:var(--mono);color:var(--muted);font-size:.65rem}.hamburger-btn{color:#ffffffb3;cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px 6px;font-size:1.1rem;transition:color .15s;display:flex}.hamburger-btn:hover{color:#fff}.drawer-overlay{z-index:30;background:#1a1d3b80;display:none;position:fixed;inset:0}main{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.kpi-bar{border-bottom:1px solid var(--border);background:#fff;flex-shrink:0;grid-template-columns:repeat(6,1fr);display:grid}.kpi{border-right:1px solid var(--border);padding:12px 18px}.kpi:last-child{border-right:none}.kpi-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:4px;font-size:.55rem}.kpi-value{font-family:var(--mono);color:#2e3192;font-size:1.6rem;font-weight:700;line-height:1}.kpi-value.accent{color:var(--accent)}.kpi-value.amber{color:var(--amber)}.kpi-value.green{color:var(--green)}.kpi-sub{font-family:var(--mono);color:var(--muted);margin-top:3px;font-size:.58rem}.toolbar{border-bottom:1px solid var(--border);background:#fff;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:8px 14px;display:flex}.toolbar-right{margin-left:auto}.filter-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.chip-sep{background:var(--border2);width:1px;height:20px;margin:0 4px}.chip{border:1px solid var(--border2);color:var(--muted);font-family:var(--mono);cursor:pointer;letter-spacing:.04em;white-space:nowrap;background:#fff;border-radius:999px;padding:4px 12px;font-size:.7rem;transition:all .12s}.chip:hover{color:#2e3192;border-color:#2e3192}.chip.active{color:#fff;background:#2e3192;border-color:#2e3192;font-weight:600}.sort-sel{border:1px solid var(--border2);height:30px;color:var(--text);font-family:var(--mono);cursor:pointer;background:#f0f4ff;border-radius:6px;outline:none;padding:0 10px;font-size:.7rem}.table-wrap{background:#fff;flex:1;min-height:0;overflow:scroll auto}.table-wrap::-webkit-scrollbar{width:0;height:0}.table-wrap::-webkit-scrollbar-track{background:#0a0f1a}.table-wrap::-webkit-scrollbar-thumb{background:#ff7700b5;border-radius:3px}.table-wrap::-webkit-scrollbar-corner{background:#0a0f1a}.table-wrap table{min-width:max-content}#sticky-hscroll::-webkit-scrollbar{height:14px}#sticky-hscroll::-webkit-scrollbar-track{background:#0a0f1a}#sticky-hscroll::-webkit-scrollbar-thumb{background:#ff7700b5;border-radius:3px}table{border-collapse:collapse;width:100%;font-size:.75rem}thead{z-index:10;position:sticky;top:0}th{color:#fff;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;text-align:left;white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;background:#2e3192;border-bottom:1px solid #1e2270;padding:8px 10px;font-size:.6rem;font-weight:600}th:hover{color:var(--accent)}.sort-arr{opacity:.6;margin-left:3px}td{border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap;color:var(--text);padding:7px 10px}tr:hover td,tr.selected td{background:#eef1ff}tr.pending-row td{background:#ff77000a}.row-expand td{padding:0}.row-expand{display:none}.row-expand.open{display:table-row}.badge{font-family:var(--mono);letter-spacing:.06em;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:.62rem;font-weight:600;display:inline-flex}.badge-dot{background:currentColor;border-radius:50%;width:5px;height:5px}.b-done{color:var(--green);background:#16a34a1a}.b-sailed{color:var(--accent);background:#ff77001a}.b-pending{color:var(--amber);background:#ff77001a;animation:2s ease-in-out infinite pulse-badge}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.5}}.bl-tag{font-family:var(--mono);border-radius:3px;padding:1px 6px;font-size:.62rem;font-weight:600;display:inline-block}.bl-swb{color:var(--green);background:#16a34a1a}.bl-obl{color:var(--accent);background:#ff77001a}.ctr-40hc{color:var(--accent)}.ctr-20gp{color:var(--muted)}.ctr-lcl{color:var(--green)}.accent-text{color:var(--accent);font-family:var(--mono);font-weight:600}.mono{font-family:var(--mono)}.muted{color:var(--muted)}.tt-wrap{align-items:center;gap:5px;display:flex}.tt-bar{background:var(--border2);border-radius:2px;width:40px;height:4px;overflow:hidden}.tt-fill{background:var(--accent);border-radius:2px;height:100%}.tt-fill.amber{background:var(--amber)}.tt-fill.long{background:var(--red)}.row-count{font-family:var(--mono);color:var(--muted);border-top:1px solid var(--border);background:#fff;padding:8px 18px;font-size:.65rem}.empty{text-align:center;color:var(--muted);padding:60px 20px;font-size:.85rem}.detail-panel{border-left:1px solid var(--border);z-index:30;background:#fff;flex-direction:column;flex-shrink:0;width:320px;transition:all .2s;display:flex;position:fixed;top:56px;bottom:0;right:0;overflow-y:auto}.detail-panel.closed{border:none;width:0;padding:0;overflow:hidden}.dp-header{border-bottom:1px solid var(--border);color:var(--text);background:#f0f4ff;padding:16px 18px 12px}.dp-io{font-family:var(--mono);color:var(--muted);margin-bottom:2px;font-size:.65rem}.dp-shipper{font-size:.95rem;font-weight:700}.dp-dest{font-family:var(--mono);color:var(--muted);margin-top:3px;font-size:.7rem}.dp-close{float:right;color:var(--muted);cursor:pointer;background:0 0;border:none;margin-top:-2px;font-size:1.1rem}.dp-body{flex-direction:column;gap:16px;padding:16px 18px;display:flex}.dp-section-title{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);border-bottom:1px solid var(--border);margin-bottom:8px;padding-bottom:6px;font-size:.6rem}.dp-row{justify-content:space-between;align-items:baseline;margin-bottom:6px;display:flex}.dp-key{color:var(--muted);font-size:.75rem}.dp-val{font-family:var(--mono);color:var(--text);text-align:right;text-overflow:ellipsis;white-space:nowrap;max-width:170px;font-size:.74rem;overflow:hidden}.dp-val.highlight{color:var(--accent)}.dp-val.green{color:var(--green)}.dp-val.amber{color:var(--amber)}.vessel-pill{color:var(--text);font-family:var(--mono);border:1px solid var(--border2);background:#f0f4ff;border-radius:8px;margin-bottom:14px;padding:8px 12px;font-size:.7rem}.timeline{flex-direction:column;display:flex}.tl-step{gap:12px;padding-bottom:14px;display:flex}.tl-step:last-child{padding-bottom:0}.tl-left{flex-direction:column;align-items:center;display:flex}.tl-dot2{border-radius:50%;flex-shrink:0;width:9px;height:9px;margin-top:2px}.tl-line2{background:var(--border);flex:1;width:1px;margin-top:4px}.tl-right{flex:1}.tl-step-label{color:var(--text);font-size:.78rem;font-weight:600}.tl-step-date{font-family:var(--mono);color:var(--muted);margin-top:1px;font-size:.65rem}.tl-done{background:var(--green)}.tl-active{background:var(--accent)}.tl-future{background:var(--border2)}.ef{flex-direction:column;gap:2px;display:flex}.ef-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-size:.55rem}.ef-val{font-family:var(--mono);color:var(--text);font-size:.74rem}.ship-card{border:1px solid var(--border);background:#fff;border-radius:10px;flex-direction:row;transition:border-color .2s,transform .15s;animation:.3s both cardIn;display:flex;overflow:hidden}.ship-card:hover{border-color:#2e3192;transform:translateY(-2px);box-shadow:0 2px 12px #2e319214}@keyframes cardIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.card-stripe{flex-shrink:0;width:4px}.ship-card.urgency-ok .card-stripe{background:var(--green)}.ship-card.urgency-done .card-stripe{background:var(--green);opacity:.4}.ship-card.urgency-warn .card-stripe{background:var(--amber)}.ship-card.urgency-critical .card-stripe{background:var(--red);animation:1s ease-in-out infinite alternate pulseStripe}.ship-card.urgency-overdue .card-stripe{background:var(--red);opacity:.55}@keyframes pulseStripe{0%{opacity:1}to{opacity:.3}}.card-inner{flex-direction:column;flex:1;gap:.85rem;min-width:0;padding:1.25rem;display:flex}.card-header{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.card-header-left{align-items:center;gap:.5rem;display:flex}.card-ri{font-family:var(--mono);color:var(--text);font-size:1rem;font-weight:600}.card-mode{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);border:1px solid var(--border2);text-transform:uppercase;background:#f0f4ff;border-radius:4px;padding:.22rem .55rem;font-size:.72rem}.card-mode.fcl{color:var(--accent);background:#ff770014;border-color:#f703}.card-mode.lcl{color:var(--green);background:#16a34a14;border-color:#16a34a33}.card-mode.air{color:#7c3aed;background:#a78bfa14;border-color:#a78bfa33}.card-edi-badge{font-family:var(--mono);letter-spacing:.08em;white-space:nowrap;border:1px solid;border-radius:5px;flex-shrink:0;align-items:center;gap:.3rem;padding:.3rem .75rem;font-size:.75rem;font-weight:600;display:flex}.card-edi-badge.ok,.card-edi-badge.done{color:var(--green);background:#16a34a14;border-color:#16a34a33}.card-edi-badge.warn{color:var(--amber);background:#ff770014;border-color:#f703}.card-edi-badge.critical{color:var(--red);background:#ec1c2414;border-color:#ec1c2433;animation:1.2s ease-in-out infinite alternate badgePulse}.card-edi-badge.overdue{color:#dc2626;background:#ec1c240f;border-color:#ec1c2426}@keyframes badgePulse{0%{opacity:1}to{opacity:.5}}.card-shipper{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:1.15rem;font-weight:600;overflow:hidden}.card-meta-row{flex-wrap:wrap;gap:.4rem;display:flex}.meta-chip{border:1px solid var(--border2);color:var(--text);background:#f0f4ff;border-radius:5px;align-items:baseline;gap:.4rem;max-width:100%;padding:.3rem .65rem;font-size:.88rem;display:flex;overflow:hidden}.meta-chip.mono{font-family:var(--mono);font-size:.82rem}.meta-chip-lbl{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;flex-shrink:0;font-size:.68rem}.voyage{color:var(--muted);font-size:.72rem}.card-dates-row{border:1px solid var(--border);background:#f0f4ff;border-radius:7px;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.55rem .75rem;display:flex}.date-block{flex-direction:column;gap:.1rem;display:flex}.date-lbl{color:var(--muted);letter-spacing:.1em;text-transform:uppercase;font-size:.68rem}.date-val{font-family:var(--mono);color:var(--text);white-space:nowrap;font-size:.92rem}.date-block.highlight .date-val{color:var(--accent);font-weight:600}.date-arrow{color:var(--muted);flex-shrink:0;font-size:.8rem}.card-cutoff-bar{border:1px solid var(--border2);background:#f0f4ff;border-radius:7px;flex-direction:column;gap:.5rem;padding:.75rem 1rem;display:flex}.cutoff-section{align-items:center;gap:.5rem;display:flex}.cutoff-label{font-family:var(--mono);letter-spacing:.1em;color:var(--muted);text-transform:uppercase;flex-shrink:0;width:90px;font-size:.72rem}.cutoff-datetime{font-family:var(--mono);color:var(--muted);flex:1;font-size:.85rem}.cutoff-countdown{font-family:var(--mono);text-align:right;white-space:nowrap;flex-shrink:0;min-width:110px;font-size:.95rem;font-weight:600}.cutoff-countdown.ok{color:var(--green)}.cutoff-countdown.done{color:var(--green);opacity:.55}.cutoff-countdown.warn{color:var(--amber)}.cutoff-countdown.critical{color:var(--red);animation:1.2s step-start infinite blink}.cutoff-countdown.overdue{color:#dc2626}@keyframes blink{50%{opacity:.25}}.card-notes{color:var(--muted);border-left:2px solid var(--border2);padding-left:.75rem;font-size:.88rem;font-style:italic;line-height:1.5}.card-actions{justify-content:flex-end;display:flex}.btn-edit{border:1px solid var(--border2);color:var(--muted);cursor:pointer;font-size:.85rem;font-family:var(--sans);background:0 0;border-radius:5px;padding:.45rem 1rem;transition:all .15s}.btn-edit:hover{color:var(--text);border-color:var(--accent)}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1a1d3b80;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border2);background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:460px;margin:1rem;animation:.2s modalIn;display:flex;overflow:hidden;box-shadow:0 8px 32px #1a1d3b26}@keyframes modalIn{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-header{background:#2e3192;justify-content:space-between;align-items:center;padding:1rem 1.25rem .85rem;display:flex}.modal-title{font-size:.95rem;font-weight:600;font-family:var(--mono);color:#fff}.modal-close{color:#ffffffb3;cursor:pointer;background:0 0;border:none;font-size:1rem;line-height:1;transition:color .15s}.modal-close:hover{color:#fff}.modal-body{flex-direction:column;gap:1rem;padding:1.1rem 1.25rem;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.6rem;padding:.85rem 1.25rem;display:flex}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-group label{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem}.label-hint{color:var(--border2);text-transform:none;letter-spacing:0;font-size:.68rem}.form-group input[type=text],.form-group textarea{border:1px solid var(--border2);color:var(--text);font-family:var(--sans);resize:vertical;background:#f0f4ff;border-radius:6px;outline:none;padding:.5rem .75rem;font-size:.88rem;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}.form-group input:disabled{opacity:.4;cursor:not-allowed}.checkbox-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.6rem;display:flex;color:var(--text)!important;text-transform:none!important;letter-spacing:0!important;font-size:.88rem!important}.checkbox-label input[type=checkbox]{display:none}.checkbox-custom{border:1px solid var(--border2);background:#f0f4ff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:all .15s;display:flex}.checkbox-label input:checked+.checkbox-custom{background:var(--green);border-color:var(--green)}.checkbox-label input:checked+.checkbox-custom:after{content:"✓";color:#fff;font-size:.75rem;font-weight:700}.btn-cancel{border:1px solid var(--border2);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:.46rem 1rem;font-size:.84rem;transition:all .15s}.btn-cancel:hover{color:var(--text);border-color:var(--text)}.btn-save{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.46rem 1.3rem;font-size:.84rem;font-weight:600;transition:opacity .15s}.btn-save:hover{opacity:.88}.btn-save:disabled{opacity:.5;cursor:not-allowed}.si-kpi-strip{background:var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.kpi-card{background:#fff;flex-direction:column;gap:.25rem;padding:1.1rem 2rem;display:flex}.kpi-val{font-family:var(--mono);color:#2e3192;font-size:2rem;font-weight:600;line-height:1}.kpi-lbl{color:var(--muted);letter-spacing:.05em;text-transform:uppercase;font-size:.75rem}.kpi-warn{color:var(--amber)}.kpi-danger{color:var(--red)}.kpi-ok{color:var(--green)}.notes-history{font-family:var(--mono);color:var(--muted);border:1px solid var(--border);white-space:pre-wrap;word-break:break-word;background:#f0f4ff;border-radius:6px;max-height:120px;margin-bottom:.5rem;padding:.6rem .75rem;font-size:.72rem;line-height:1.6;overflow-y:auto}.cutoff-overdue-age{font-family:var(--mono);color:var(--red);opacity:.7;border-top:1px solid #ec1c2426;margin-top:.25rem;padding-top:.25rem;font-size:.72rem}.shortcuts-help{border:1px solid var(--border2);z-index:100;background:#fff;border-radius:10px;min-width:220px;padding:1rem 1.25rem;animation:.2s modalIn;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 8px 32px #2e31921f}.shortcuts-title{font-family:var(--mono);letter-spacing:.12em;color:var(--accent);text-transform:uppercase;margin-bottom:.75rem;font-size:.7rem}.shortcut-row{color:var(--muted);align-items:center;gap:.75rem;padding:.2rem 0;font-size:.82rem;display:flex}kbd{font-family:var(--mono);border:1px solid var(--border2);color:var(--text);text-align:center;background:#f0f4ff;border-radius:4px;min-width:28px;padding:.15rem .45rem;font-size:.72rem}.glass-card{-webkit-backdrop-filter:blur(20px);background:#ffffff47;border:1px solid #fff9;border-radius:20px;box-shadow:inset 0 1px #ffffffb3,0 8px 32px #00000014}@media (width<=768px){header{padding:0 12px}.logo-badge,.search-wrap,#refreshBtn{display:none}.kpi-bar{grid-template-columns:1fr 1fr}.kpi{padding:8px 10px}.kpi-value{font-size:1.4rem}.toolbar{flex-direction:column;gap:6px;padding:8px 12px}.filter-row{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:2px;overflow-x:auto}.toolbar-right,.sort-sel{width:100%}.chip-sep,.table-wrap{display:none}.mobile-cards{flex-direction:column;gap:8px;padding:10px 12px;display:flex}.m-card{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;padding:12px 14px;transition:border-color .15s}.m-card:active{border-color:var(--accent)}.m-card.pending-card{background:#ff77000a;border-color:#f703}.m-card-top{justify-content:space-between;align-items:flex-start;margin-bottom:6px;display:flex}.m-card-io{font-family:var(--mono);color:var(--accent);font-size:.65rem;font-weight:600}.m-card-shipper{margin-bottom:2px;font-size:.88rem;font-weight:700}.m-card-dest{color:var(--muted);margin-bottom:8px;font-size:.75rem}.m-card-row{flex-wrap:wrap;gap:12px;margin-bottom:4px;display:flex}.m-card-field{flex-direction:column;gap:1px;display:flex}.m-card-label{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:.55rem}.m-card-val{font-family:var(--mono);color:var(--text);font-size:.72rem;font-weight:500}.detail-panel{z-index:200;inset:0;border-left:none!important;width:100%!important;position:fixed!important}.detail-panel.closed{transform:translate(100%);width:100%!important}.row-count{padding:8px 12px}.si-kpi-strip{grid-template-columns:repeat(2,1fr)}.si-kpi-strip .kpi-card{padding:.75rem 1rem}.kpi-val{font-size:1.5rem}.shortcuts-help{border-radius:12px 12px 0 0;bottom:0;left:0;right:0}.modal{border-radius:12px 12px 0 0;max-width:100%;margin:0;position:fixed;bottom:0}.modal-backdrop{align-items:flex-end}.dash-header{padding:0 1rem}.dash-header-page-title{font-size:.78rem}.dash-footer{text-align:center;flex-direction:column;gap:.25rem;padding:.75rem 1rem}}.dash-header{z-index:100;background:#0d1117;border-bottom:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:center;height:52px;padding:0 20px;display:flex;position:sticky;top:0}.dash-breadcrumb{align-items:center;gap:2px;display:flex}.dash-bc-home{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:#ffffff73;border-radius:5px;padding:4px 8px;font-size:11px;font-weight:500;text-decoration:none;transition:background .12s,color .12s}.dash-bc-home:hover{color:#ffffffd9;background:#ffffff0f}.dash-bc-sep{color:#ffffff2e;padding:0 2px;font-size:13px}.dash-bc-current{color:#fff;cursor:pointer;border-radius:5px;padding:4px 8px;font-size:14px;font-weight:600;transition:background .12s}.dash-bc-current:hover{background:#ffffff0f}.dash-header-right{align-items:center;gap:6px;display:flex}.dash-header-sep{background:#ffffff14;width:1px;height:20px;margin:0 2px}.dash-btn-action{cursor:pointer;font-size:12px;font-weight:600;font-family:var(--sans);color:#fff;background:#ff6b00;border:none;border-radius:999px;align-items:center;gap:5px;padding:6px 14px;transition:opacity .12s;display:flex}.dash-btn-action:hover{opacity:.85}.dash-btn-refresh{cursor:pointer;font-size:11px;font-weight:500;font-family:var(--mono);color:#ffffff61;background:0 0;border:1px solid #ffffff14;border-radius:6px;align-items:center;gap:4px;padding:5px 10px;transition:background .12s,color .12s;display:flex}.dash-btn-refresh:hover{color:#ffffffb3;background:#ffffff0d}.dash-theme-toggle{cursor:pointer;background:0 0;border:none;border-radius:999px;align-items:center;gap:1px;padding:3px;display:flex}.dash-toggle-pill{color:#fff6;border-radius:999px;justify-content:center;align-items:center;width:28px;height:24px;font-size:13px;transition:background .15s;display:flex}.dash-toggle-pill.active{color:#ffffffe6;background:#ffffff1a}.dash-icon-wrap{position:relative}.dash-btn-icon{cursor:pointer;color:#ffffff73;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:background .12s,color .12s;display:flex}.dash-btn-icon:hover{color:#ffffffd9;background:#ffffff0f}.dash-notif-badge{color:#fff;width:14px;height:14px;font-size:8px;font-weight:700;font-family:var(--mono);pointer-events:none;background:#ec1c24;border:1.5px solid #0d1117;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:-2px;right:-2px}.dash-chat-dot{pointer-events:none;background:#00bfff;border:2px solid #0d1117;border-radius:50%;width:10px;height:10px;position:absolute;top:-1px;right:-1px}.dash-user-pill{cursor:pointer;background:#ffffff0d;border-radius:999px;align-items:center;gap:6px;padding:3px 10px 3px 4px;display:flex}.dash-avatar{color:#fff;width:26px;height:26px;font-size:10px;font-weight:600;font-family:var(--mono);background:linear-gradient(135deg,#a78bfa,#9333ea);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.dash-user-email{font-size:11px;font-weight:500;font-family:var(--mono);color:#ffffff8c}body:not(.dark-mode) .dash-header{-webkit-backdrop-filter:blur(20px);background:#fbfbfdf2;border-bottom:.5px solid #d2d2d7}body:not(.dark-mode) .dash-bc-home{color:#86868b}body:not(.dark-mode) .dash-bc-home:hover{color:#1d1d1f;background:#f5f5f7}body:not(.dark-mode) .dash-bc-sep{color:#d2d2d7}body:not(.dark-mode) .dash-bc-current{color:#1d1d1f}body:not(.dark-mode) .dash-bc-current:hover{background:#f5f5f7}body:not(.dark-mode) .dash-header-sep{background:#e4e4e8}body:not(.dark-mode) .dash-btn-action{color:#fff;background:#1d1d1f}body:not(.dark-mode) .dash-btn-refresh{color:#86868b;border-color:#d2d2d7}body:not(.dark-mode) .dash-btn-refresh:hover{color:#1d1d1f;background:#f5f5f7}body:not(.dark-mode) .dash-toggle-pill{color:#86868b}body:not(.dark-mode) .dash-toggle-pill.active{color:#1d1d1f;background:#f5f5f7}body:not(.dark-mode) .dash-btn-icon{color:#86868b}body:not(.dark-mode) .dash-btn-icon:hover{color:#1d1d1f;background:#f5f5f7}body:not(.dark-mode) .dash-notif-badge,body:not(.dark-mode) .dash-chat-dot{border-color:#fbfbfd}body:not(.dark-mode) .dash-user-pill{background:#f5f5f7}body:not(.dark-mode) .dash-user-email{color:#1d1d1f}.notif-bell-active{animation:2s ease-in-out infinite notif-glow}@keyframes notif-glow{0%,to{color:inherit}50%{color:#ec1c24;filter:drop-shadow(0 0 4px #ec1c2499)}}.notif-dropdown{z-index:9999;background:#1a1f2e;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;width:320px;max-height:420px;display:flex;position:absolute;top:calc(100% + 8px);right:-8px;overflow:hidden;box-shadow:0 8px 32px #0006}body:not(.dark-mode) .notif-dropdown{background:#fff;border-color:#d2d2d7;box-shadow:0 8px 32px #0000001f}.notif-empty{text-align:center;color:#fff6;font-size:13px;font-family:var(--sans);padding:24px 16px}body:not(.dark-mode) .notif-empty{color:var(--muted)}.notif-list{flex:1;max-height:360px;list-style:none;overflow-y:auto}.notif-item{border-bottom:1px solid #ffffff0f;align-items:flex-start;gap:10px;padding:10px 14px;transition:background .15s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#ffffff0a}body:not(.dark-mode) .notif-item{border-bottom-color:var(--border)}body:not(.dark-mode) .notif-item:hover{background:#f5f5f7}.notif-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.notif-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.notif-ri{font-size:12px;font-weight:600;font-family:var(--mono);color:#ffffffe6}body:not(.dark-mode) .notif-ri{color:var(--text)}.notif-label{text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:600}.notif-msg{color:#ffffff73;white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}body:not(.dark-mode) .notif-msg{color:var(--muted)}.notif-dismiss{color:#ffffff40;cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;margin-top:2px;padding:2px 4px;font-size:11px;transition:color .15s,background .15s}.notif-dismiss:hover{color:#ec1c24;background:#ec1c241a}body:not(.dark-mode) .notif-dismiss{color:var(--muted)}body:not(.dark-mode) .notif-dismiss:hover{color:#ec1c24;background:#ec1c2414}.notif-footer{border-top:1px solid #ffffff14;justify-content:flex-end;padding:8px 14px;display:flex}body:not(.dark-mode) .notif-footer{border-top-color:var(--border)}.notif-dismiss-all{color:#ffffff59;cursor:pointer;font-size:11px;font-family:var(--sans);background:0 0;border:none;border-radius:4px;padding:4px 8px;transition:color .15s,background .15s}.notif-dismiss-all:hover{color:#ec1c24;background:#ec1c241a}body:not(.dark-mode) .notif-dismiss-all{color:var(--muted)}body:not(.dark-mode) .notif-dismiss-all:hover{color:#ec1c24}
