.wl-shell{background:#0d1b2e;justify-content:center;align-items:center;height:100vh;min-height:100vh;padding:2rem 1rem;font-family:Inter,sans-serif;display:flex;overflow-y:auto}.wl-center{flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:420px;display:flex}.wl-above{flex-direction:column;align-items:center;gap:.875rem;display:flex}.wl-logo{object-fit:contain;filter:brightness(0)invert();width:auto;height:58px}.wl-title{color:#fff;letter-spacing:-.01em;text-align:center;margin:0;font-size:1.1rem;font-weight:600}.wl-card{background:#152136;border:1px solid #ffffff14;border-radius:16px;width:100%;overflow:hidden}.wl-sso-banner{color:#4ade80;background:#22c55e1a;border-bottom:1px solid #22c55e26;align-items:center;gap:.625rem;padding:.75rem 1.75rem;font-size:.8375rem;font-weight:500;display:flex}.wl-spin{flex-shrink:0;animation:.9s linear infinite wl-rotate}@keyframes wl-rotate{to{transform:rotate(360deg)}}.wl-card-body{flex-direction:column;gap:1.25rem;padding:2rem 1.75rem;display:flex}.wl-subtitle{color:#94a3b8;text-align:center;margin:0;font-size:.9rem}.wl-ms-btn{cursor:pointer;color:#e2e8f0;background:#ffffff0d;border:1px solid #ffffff1f;border-radius:10px;align-items:center;gap:.75rem;width:100%;padding:.8rem 1.125rem;font-size:.9rem;font-weight:500;transition:background .15s,border-color .15s;display:flex}.wl-ms-btn:hover:not(:disabled){background:#ffffff17;border-color:#ffffff38}.wl-ms-btn:disabled{opacity:.55;cursor:not-allowed}.wl-ms-logo{flex-shrink:0;grid-template-columns:1fr 1fr;gap:2px;width:18px;height:18px;display:grid}.wl-ms-logo span:first-child{background:#f25022}.wl-ms-logo span:nth-child(2){background:#7fba00}.wl-ms-logo span:nth-child(3){background:#00a4ef}.wl-ms-logo span:nth-child(4){background:#ffb900}.wl-ms-label{text-align:center;flex:1}.wl-ms-arrow{opacity:.45;flex-shrink:0;margin-left:auto}.wl-divider{color:#475569;align-items:center;gap:.75rem;font-size:.78rem;display:flex}.wl-divider:before,.wl-divider:after{content:"";background:#ffffff14;flex:1;height:1px}.wl-form{flex-direction:column;gap:1rem;display:flex}.wl-field-wrap{flex-direction:column;gap:.4rem;display:flex}.wl-label{color:#cbd5e1;font-size:.8375rem;font-weight:500}.wl-field{background:#1e2d42;border:1px solid #ffffff1a;border-radius:9px;align-items:center;transition:border-color .15s;display:flex;position:relative}.wl-field:focus-within{border-color:#22c55e}.wl-fld-ico{color:#475569;pointer-events:none;flex-shrink:0;position:absolute;left:.875rem}.wl-field input{color:#e2e8f0;background:0 0;border:none;outline:none;flex:1;width:100%;padding:.8rem .875rem .8rem 2.5rem;font-family:inherit;font-size:.9rem}.wl-field input::placeholder{color:#475569}.wl-field input:disabled{opacity:.5}.wl-eye{cursor:pointer;color:#475569;background:0 0;border:none;align-items:center;padding:.25rem;transition:color .15s;display:flex;position:absolute;right:.75rem}.wl-eye:hover{color:#94a3b8}.wl-err{color:#fca5a5;background:#ef44441f;border:1px solid #ef444440;border-radius:8px;padding:.625rem .875rem;font-size:.8125rem}.wl-submit{color:#fff;cursor:pointer;background:#22c55e;border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.25rem;padding:.875rem;font-size:.9375rem;font-weight:600;transition:background .15s,transform .1s;display:flex}.wl-submit:hover:not(:disabled){background:#16a34a;transform:translateY(-1px)}.wl-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.dr-popup-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:500;background:#0f172a85;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.dr-popup{text-align:center;background:#fff;border-radius:24px;width:100%;max-width:380px;padding:2.75rem 2.5rem 2.25rem;position:relative;box-shadow:0 32px 80px #00000038,0 0 0 1px #0000000a}.dr-popup-icon{border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.5rem;display:flex}.dr-popup.success .dr-popup-icon{color:#16a34a;background:#f0fdf4}.dr-popup.error .dr-popup-icon{color:#dc2626;background:#fef2f2}.dr-popup h3{color:#0f172a;letter-spacing:-.03em;margin-bottom:.625rem;font-size:1.375rem;font-weight:800}.dr-popup p{color:#64748b;margin-bottom:1.75rem;font-size:.9rem;line-height:1.6}.dr-popup-btn{cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;padding:.75rem 2.5rem;font-family:inherit;font-size:.9375rem;font-weight:700;transition:all .15s;display:inline-flex}.dr-popup.success .dr-popup-btn{color:#fff;background:#16a34a;box-shadow:0 4px 14px #16a34a4d}.dr-popup.success .dr-popup-btn:hover{background:#15803d;transform:translateY(-1px)}.dr-popup.error .dr-popup-btn{color:#fff;background:#0f172a;box-shadow:0 4px 14px #0f172a33}.dr-popup.error .dr-popup-btn:hover{background:#1e293b;transform:translateY(-1px)}.dr-popup-close{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .15s;display:flex;position:absolute;top:1rem;right:1rem}.dr-popup-close:hover{color:#0f172a;background:#e2e8f0}.dr-shell{background:#f1f5f9;height:100vh;font-family:Inter,sans-serif;display:flex;overflow:hidden}.dr-sidebar{z-index:100;background:#0f172a;flex-direction:column;flex-shrink:0;justify-content:space-between;width:256px;min-width:256px;height:100vh;display:flex;overflow:hidden auto}.dr-sidebar-top{flex-direction:column;gap:1.75rem;padding:1.5rem 1rem 1rem;display:flex}.dr-brand{border-bottom:1px solid #ffffff12;align-items:center;gap:.875rem;padding:.5rem .5rem .75rem;display:flex}.dr-brand svg{color:#38bdf8;flex-shrink:0}.dr-brand-title{color:#f1f5f9;letter-spacing:-.01em;font-size:1rem;font-weight:700;line-height:1.2;display:block}.dr-brand-sub{color:#64748b;margin-top:.15rem;font-size:.75rem;display:block}.dr-nav{flex-direction:column;gap:.2rem;display:flex}.dr-nav-item{color:#64748b;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:.75rem;width:100%;padding:.7rem .875rem;font-size:.8375rem;font-weight:500;transition:all .15s;display:flex}.dr-nav-item:hover{color:#cbd5e1;background:#ffffff0f}.dr-nav-item.active{color:#38bdf8;background:#38bdf81a}.dr-nav-item.active svg{color:#38bdf8}.dr-nav-item svg{color:inherit;flex-shrink:0}.dr-chevron{margin-left:auto}.dr-sidebar-bottom{border-top:1px solid #ffffff12;flex-direction:column;gap:.625rem;padding:1rem;display:flex}.dr-user-card{background:#ffffff0a;border:1px solid #ffffff0f;border-radius:12px;align-items:center;gap:.75rem;padding:.875rem;display:flex}.dr-user-avatar{color:#fff;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9375rem;font-weight:700;display:flex}.dr-user-info{overflow:hidden}.dr-user-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.dr-user-role{color:#475569;margin-top:.1rem;font-size:.75rem}.dr-logout-btn{color:#f87171;cursor:pointer;background:0 0;border:1px solid #ef444433;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.6rem;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.dr-logout-btn:hover{background:#ef444414;border-color:#ef444466}.dr-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow-y:auto}.dr-header{z-index:50;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f8fafcf2;border-bottom:1px solid #e8edf3;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.dr-header-title{color:#0f172a;letter-spacing:-.025em;font-size:1.1875rem;font-weight:700}.dr-header-sub{color:#94a3b8;margin-top:.15rem;font-size:.8125rem;display:block}.dr-save-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#0f172a;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:.5rem;padding:.6875rem 1.375rem;font-size:.9rem;font-weight:600;transition:all .15s;display:flex}.dr-save-btn:hover:not(:disabled){background:#1e293b;transform:translateY(-1px);box-shadow:0 6px 16px #0f172a33}.dr-save-btn:disabled{opacity:.55;cursor:not-allowed}.dr-save-btn.lg{border-radius:12px;padding:.875rem 2rem;font-size:1rem}.dr-spinner{border:2px solid #ffffff40;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:17px;height:17px;animation:.7s linear infinite drSpin;display:inline-block}@keyframes drSpin{to{transform:rotate(360deg)}}.dr-status{align-items:center;gap:.75rem;padding:.875rem 2rem;font-size:.9rem;font-weight:500;display:flex;overflow:hidden}.dr-status.success{color:#15803d;background:#f0fdf4;border-bottom:1px solid #bbf7d0}.dr-status.error{color:#dc2626;background:#fef2f2;border-bottom:1px solid #fecaca}.dr-form{flex-direction:column;gap:1rem;padding:1.25rem 1.5rem 3rem;display:flex}.dr-section{background:#fff;border:1px solid #e8edf3;border-radius:12px;padding:1.25rem 1.5rem;scroll-margin-top:72px;transition:box-shadow .2s,border-color .2s}.dr-section:hover{border-color:#dde3ec;box-shadow:0 2px 12px #0000000d}.dr-sec-hd{border-bottom:1px solid #f1f5f9;align-items:center;gap:.625rem;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.dr-sec-hd svg{color:#3b82f6;box-sizing:content-box;background:#eff6ff;border-radius:6px;flex-shrink:0;padding:5px}.dr-sec-hd h2{color:#0f172a;letter-spacing:-.01em;font-size:.875rem;font-weight:700}.dr-g3{grid-template-columns:repeat(3,1fr);gap:.875rem;display:grid}.dr-g2{grid-template-columns:repeat(2,1fr);gap:.875rem;display:grid}.dr-g1{grid-template-columns:1fr;gap:.875rem;display:grid}@media (width<=900px){.dr-g3{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.dr-g3,.dr-g2{grid-template-columns:1fr}.dr-sidebar{display:none}}.dr-field{flex-direction:column;gap:.3rem;display:flex}.dr-label{color:#64748b;letter-spacing:.04em;text-transform:uppercase;font-size:.72rem;font-weight:600}.dr-input-wrap{align-items:center;display:flex;position:relative}.dr-input-ico{color:#94a3b8;pointer-events:none;z-index:1;flex-shrink:0;position:absolute;left:.65rem}.dr-input{color:#0f172a;background:#f8fafc;border:1.5px solid #e8edf3;border-radius:7px;outline:none;width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.8375rem;transition:border-color .15s,box-shadow .15s,background .15s}.dr-input.has-icon{padding-left:2.125rem}.dr-input:hover{border-color:#cbd5e1}.dr-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f614}.dr-input:focus~.dr-input-ico,.dr-input-wrap:focus-within .dr-input-ico{color:#3b82f6}.dr-input::placeholder{color:#c0cad6;font-size:.8125rem}.dr-input[type=datetime-local]{padding-right:.5rem}.dr-textarea{color:#0f172a;resize:vertical;background:#f8fafc;border:1.5px solid #e8edf3;border-radius:7px;outline:none;width:100%;padding:.625rem .75rem;font-family:inherit;font-size:.8375rem;line-height:1.65;transition:border-color .15s,box-shadow .15s}.dr-textarea:hover{border-color:#cbd5e1}.dr-textarea:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f614}.dr-tbl-wrap{border:1px solid #e2e8f0;border-radius:10px;overflow-x:auto}.dr-tbl{border-collapse:collapse;width:100%;font-size:.875rem}.dr-tbl th{color:#475569;text-transform:uppercase;letter-spacing:.04em;text-align:left;white-space:nowrap;background:#f8fafc;border-bottom:1.5px solid #e2e8f0;padding:.75rem .875rem;font-size:.775rem;font-weight:600}.dr-tbl td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.45rem .5rem}.dr-tbl tr:last-child td{border-bottom:none}.th-type{min-width:170px}.td-type{color:#334155;white-space:nowrap;font-size:.875rem;font-weight:600;padding-left:.875rem!important}.cargo-tbl th,.cargo-tbl td{text-align:center}.dr-tbl-input{color:#0f172a;text-align:center;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:6px;outline:none;width:100%;min-width:80px;padding:.5rem .625rem;font-family:inherit;font-size:.875rem;transition:all .15s}.dr-tbl-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dr-tbl-input::placeholder{color:#cbd5e1}.dr-form-footer{justify-content:flex-end;padding-top:.5rem;display:flex}.dr-nav-top{color:#94a3b8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:.75rem;width:100%;padding:.75rem .875rem;font-size:.875rem;font-weight:600;transition:all .15s;display:flex}.dr-nav-top:hover{color:#e2e8f0;background:#ffffff0f}.dr-nav-top.active{color:#38bdf8;background:#38bdf81f}.dr-nav-top.mt-2{margin-top:.5rem}.top-chevron{color:inherit;opacity:.5;margin-left:auto;transition:transform .2s}.top-chevron.open{opacity:1;transform:rotate(90deg)}.dr-nav-item.sub{color:#475569;border-radius:8px;padding-left:2.25rem;font-size:.8125rem;font-weight:500}.dr-nav-item.sub:hover{color:#94a3b8;background:#ffffff0a}.dr-nav-item.sub.active{color:#7dd3fc;background:#38bdf814}.dr-nav-item.sub.active svg{color:#7dd3fc}.um-add-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#2563eb;border:none;border-radius:10px;flex-shrink:0;align-items:center;gap:.5rem;padding:.6875rem 1.375rem;font-size:.9rem;font-weight:600;transition:all .15s;display:flex}.um-add-btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 6px 16px #2563eb4d}.um-body{flex-direction:column;gap:1.5rem;padding:1.75rem 2rem 3rem;display:flex}.um-stats{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}.um-stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:box-shadow .2s;display:flex}.um-stat-card:hover{box-shadow:0 4px 12px #00000012}.um-stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.um-stat-value{color:#0f172a;letter-spacing:-.03em;font-size:1.75rem;font-weight:800;line-height:1}.um-stat-label{color:#94a3b8;margin-top:.25rem;font-size:.8125rem;font-weight:500}.um-tabs{background:#f1f5f9;border-radius:10px;gap:.25rem;width:fit-content;padding:.3rem;display:flex}.um-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5625rem 1.25rem;font-size:.875rem;font-weight:600;transition:all .15s;display:flex}.um-tab:hover{color:#334155}.um-tab.active{color:#0f172a;background:#fff;box-shadow:0 1px 4px #00000014}.um-toolbar{align-items:center;gap:1rem;display:flex}.um-search{color:#94a3b8;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;flex:1;align-items:center;gap:.625rem;padding:.625rem 1rem;transition:border-color .15s;display:flex}.um-search:focus-within{color:#475569;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.um-search input{color:#0f172a;background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:.9rem}.um-search input::placeholder{color:#cbd5e1}.um-filter-wrap{align-items:center;display:flex;position:relative}.um-filter{appearance:none;color:#475569;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;outline:none;padding:.625rem 2.25rem .625rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:border-color .15s}.um-filter:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.um-filter-icon{color:#94a3b8;pointer-events:none;position:absolute;right:.75rem}.um-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.um-table{border-collapse:collapse;width:100%;font-size:.875rem}.um-table thead tr{background:#f8fafc;border-bottom:1.5px solid #e2e8f0}.um-table th{text-align:left;color:#64748b;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;padding:.875rem 1.25rem;font-size:.775rem;font-weight:700}.um-table td{vertical-align:middle;color:#334155;border-bottom:1px solid #f8fafc;padding:1rem 1.25rem}.um-table tbody tr:last-child td{border-bottom:none}.um-table tbody tr:hover td{background:#fafafa}.um-user-cell{align-items:center;gap:.875rem;display:flex}.um-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:.9375rem;font-weight:700;display:flex}.um-full-name{color:#0f172a;font-size:.9rem;font-weight:600}.um-email{color:#94a3b8;margin-top:.1rem;font-size:.8125rem}.um-username{color:#64748b;font-family:monospace;font-size:.875rem}.um-date{color:#94a3b8;white-space:nowrap;font-size:.8125rem}.um-role-badge{letter-spacing:.02em;border:1px solid;border-radius:99px;padding:.25rem .75rem;font-size:.775rem;font-weight:700;display:inline-block}.um-status-badge{border-radius:99px;align-items:center;gap:.35rem;padding:.3rem .75rem;font-size:.775rem;font-weight:600;display:inline-flex}.um-status-badge.active{color:#16a34a;background:#f0fdf4}.um-status-badge.inactive{color:#dc2626;background:#fef2f2}.um-actions{align-items:center;gap:.5rem;display:flex}.um-act{cursor:pointer;border:1.5px solid;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.um-act.edit{color:#2563eb;background:#eff6ff;border-color:#bfdbfe}.um-act.edit:hover{background:#dbeafe}.um-act.delete{color:#dc2626;background:#fef2f2;border-color:#fecaca}.um-act.delete:hover{background:#fee2e2}.um-empty{text-align:center;color:#94a3b8;padding:3rem;font-size:.9rem}.um-roles-wrap{flex-direction:column;gap:1.5rem;display:flex}.um-role-cards{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}.um-role-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:1.5rem;transition:box-shadow .2s}.um-role-card:hover{box-shadow:0 4px 12px #0000000f}.um-role-card-hd{align-items:center;gap:.875rem;margin-bottom:.875rem;display:flex}.um-role-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.um-role-card-hd h3{font-size:1rem;font-weight:700}.um-role-card-hd p{color:#94a3b8;margin-top:.15rem;font-size:.8rem}.um-role-desc{color:#64748b;font-size:.8375rem;line-height:1.6}.um-perm-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.um-perm-title{color:#0f172a;padding:1.25rem 1.5rem .25rem;font-size:.9375rem;font-weight:700}.um-perm-subtitle{color:#94a3b8;border-bottom:1px solid #f1f5f9;padding:0 1.5rem 1rem;font-size:.8125rem}.um-perm-tbl-wrap{overflow-x:auto}.um-perm-label{color:#1e293b;font-size:.875rem;font-weight:600}.um-perm-desc{color:#94a3b8;margin-top:2px;font-size:.775rem}.um-toggle-locked{opacity:.45;cursor:not-allowed!important}.um-perm-tbl tfoot td{background:#f8fafc;border-top:1px solid #e2e8f0;padding:.875rem 1.5rem}.um-perm-save-btn{color:#fff;cursor:pointer;background:#3b82f6;border:1px solid #3b82f6;border-radius:6px;padding:.3rem 1rem;font-size:.8125rem;font-weight:600;transition:background .15s}.um-perm-save-btn:hover:not(:disabled){background:#2563eb}.um-perm-save-btn:disabled{opacity:.55;cursor:not-allowed}.um-perm-tbl{border-collapse:collapse;width:100%;font-size:.875rem}.um-perm-tbl th{text-align:left;color:#64748b;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:.75rem 1.5rem;font-size:.8125rem;font-weight:700}.um-perm-tbl td{color:#334155;border-bottom:1px solid #f8fafc;padding:.875rem 1.5rem;font-size:.875rem}.um-perm-tbl tbody tr:last-child td{border-bottom:none}.um-perm-tbl tbody tr:hover td{background:#fafafa}.um-perm-cell{text-align:center}.um-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0f172a8c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.um-modal{background:#fff;border-radius:20px;width:100%;max-width:540px;overflow:hidden;box-shadow:0 24px 64px #0000002e}.um-modal.sm{text-align:center;max-width:400px;padding:2.5rem 2rem}.um-modal-hd{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;padding:1.5rem 1.75rem 1.25rem;display:flex}.um-modal-hd-left{align-items:center;gap:1rem;display:flex}.um-modal-icon{color:#2563eb;background:#eff6ff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.um-modal-hd h2{color:#0f172a;font-size:1rem;font-weight:700}.um-modal-hd>div>div>p{color:#94a3b8;margin-top:.15rem;font-size:.8125rem}.um-modal-close{color:#64748b;cursor:pointer;background:#f1f5f9;border:none;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.um-modal-close:hover{color:#0f172a;background:#e2e8f0}.um-modal-body{padding:1.5rem 1.75rem}.um-modal-grid{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.um-mfield{flex-direction:column;gap:.4rem;display:flex}.um-mfield label{color:#475569;align-items:center;gap:.4rem;font-size:.8rem;font-weight:600;display:flex}.um-optional{color:#94a3b8;font-weight:400}.um-mfield input,.um-mfield select{color:#0f172a;background:#f8fafc;border:1.5px solid #e2e8f0;border-radius:8px;outline:none;width:100%;padding:.65rem .875rem;font-family:inherit;font-size:.9rem;transition:all .15s}.um-mfield input:focus,.um-mfield select:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.um-pw-wrap{position:relative}.um-pw-wrap input{padding-right:2.75rem}.um-pw-toggle{color:#94a3b8;cursor:pointer;background:0 0;border:none;align-items:center;padding:0;transition:color .15s;display:flex;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.um-pw-toggle:hover{color:#475569}.um-toggle-row{align-items:center;gap:.75rem;margin-top:.25rem;display:flex}.um-toggle{cursor:pointer;border:none;border-radius:99px;flex-shrink:0;width:44px;height:24px;padding:0;transition:background .2s;position:relative}.um-toggle.on{background:#22c55e}.um-toggle.off{background:#e2e8f0}.um-toggle-knob{background:#fff;border-radius:50%;width:18px;height:18px;transition:left .2s;display:block;position:absolute;top:3px;box-shadow:0 1px 3px #00000026}.um-toggle.on .um-toggle-knob{left:23px}.um-toggle.off .um-toggle-knob{left:3px}.um-toggle-label{color:#94a3b8;font-size:.875rem;font-weight:600}.um-toggle-label.active{color:#16a34a}.um-modal-ft{border-top:1px solid #f1f5f9;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.75rem;display:flex}.um-modal.sm .um-modal-ft{border-top:none;justify-content:center;padding-top:0}.um-btn-cancel{color:#475569;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:.65rem 1.25rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .15s}.um-btn-cancel:hover{background:#f8fafc;border-color:#cbd5e1}.um-btn-save{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:.65rem 1.5rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .15s}.um-btn-save:hover:not(:disabled){background:#1d4ed8;box-shadow:0 4px 12px #2563eb4d}.um-btn-save:disabled{opacity:.55;cursor:not-allowed}.um-btn-delete{color:#fff;cursor:pointer;background:#dc2626;border:none;border-radius:8px;padding:.65rem 1.5rem;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .15s}.um-btn-delete:hover{background:#b91c1c}.um-del-icon{color:#dc2626;background:#fef2f2;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;margin:0 auto 1.25rem;display:flex}.um-del-title{color:#0f172a;margin-bottom:.75rem;font-size:1.125rem;font-weight:700}.um-del-msg{color:#64748b;margin-bottom:1.75rem;font-size:.9rem;line-height:1.6}.um-toast{z-index:300;border-radius:12px;align-items:center;gap:.625rem;padding:.875rem 1.25rem;font-size:.9rem;font-weight:600;display:flex;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 8px 24px #00000024}.um-toast.success{color:#fff;background:#0f172a}.um-toast.error{color:#fff;background:#dc2626}@media (width<=900px){.um-stats{grid-template-columns:repeat(2,1fr)}.um-role-cards,.um-modal-grid{grid-template-columns:1fr}}.sb-shell{z-index:100;background:#fff;border-right:1px solid #e2e8f0;flex-direction:column;flex-shrink:0;width:256px;min-width:256px;height:100vh;display:flex;overflow:hidden auto}.sb-logo-area{border-bottom:1px solid #f1f5f9;align-items:center;padding:1.25rem 1.25rem 1rem;display:flex}.sb-logo{object-fit:contain;width:auto;height:36px}.sb-nav{flex-direction:column;flex:1;gap:.125rem;padding:.75rem .625rem;display:flex}.sb-item{color:#64748b;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.75rem;width:100%;padding:.625rem .875rem;font-size:.875rem;font-weight:500;transition:background .13s,color .13s;display:flex;position:relative}.sb-item:hover{color:#1e293b;background:#f8fafc}.sb-item.active{color:#16a34a;background:#f0fdf4;font-weight:600}.sb-item.active:before{content:"";background:#22c55e;border-radius:0 3px 3px 0;width:3px;position:absolute;top:20%;bottom:20%;left:0}.sb-item-ico{color:inherit;flex-shrink:0}.sb-item-label{flex:1;line-height:1.3}.sb-chevron{opacity:.55;color:inherit;flex-shrink:0;margin-left:auto;transition:transform .2s}.sb-chevron.open{opacity:.85;transform:rotate(180deg)}.sb-sub-group{flex-direction:column;gap:.0625rem;margin-bottom:.25rem;padding:.125rem 0 .25rem .75rem;display:flex}.sb-sub{color:#94a3b8;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:.625rem;width:100%;padding:.45rem .75rem;font-size:.8125rem;font-weight:500;transition:background .13s,color .13s;display:flex;position:relative}.sb-sub:hover{color:#475569;background:#f8fafc}.sb-sub.active{color:#16a34a;background:#f0fdf4;font-weight:600}.sb-sub.active:before{content:"";background:#22c55e;border-radius:0 2px 2px 0;width:2px;position:absolute;top:25%;bottom:25%;left:0}.sb-sub-ico{color:inherit;flex-shrink:0}.sb-bottom{border-top:1px solid #f1f5f9;flex-direction:column;gap:.375rem;padding:.75rem .625rem;display:flex}.sb-user{background:#f8fafc;border-radius:8px;align-items:center;gap:.75rem;padding:.625rem .875rem;display:flex}.sb-avatar{color:#fff;letter-spacing:.03em;background:#22c55e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.75rem;font-weight:700;display:flex}.sb-user-info{flex:1;min-width:0}.sb-user-name{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.8125rem;font-weight:600;overflow:hidden}.sb-user-role{color:#94a3b8;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.72rem;overflow:hidden}.sb-signout{color:#94a3b8}.sb-signout:hover{color:#ef4444;background:#fff1f2}.dr-tab-bar{border-bottom:2px solid #e2e8f0;gap:4px;padding:0 1.5rem;display:flex}.dr-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:4px 4px 0 0;align-items:center;gap:6px;margin-bottom:-2px;padding:.55rem 1.1rem;font-family:inherit;font-size:.82rem;font-weight:600;transition:color .15s,border-color .15s;display:inline-flex}.dr-tab:hover{color:#1e293b;background:#f8fafc}.dr-tab-active{color:#2563eb;background:#eff6ff;border-bottom-color:#2563eb}.dr-edit-selectors{flex-wrap:wrap;align-items:flex-end;gap:1rem;padding:1rem 1.5rem 0;display:flex}.dr-edit-loaded-badge{color:#15803d;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;align-self:flex-end;align-items:center;gap:.35rem;margin-bottom:2px;padding:.38rem .75rem;font-size:.78rem;font-weight:600;display:inline-flex}.dr-approved-banner{color:#b45309;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;align-items:center;gap:.5rem;margin:.75rem 1.5rem 0;padding:.65rem 1rem;font-size:.82rem;font-weight:600;display:flex}.dr-input-readonly{color:#64748b!important;cursor:default!important;background:#f1f5f9!important}.ab-content{flex-direction:column;gap:1.5rem;padding:1.5rem 2rem 3rem;display:flex}.ab-selectors{flex-wrap:wrap;align-items:flex-end;gap:1rem;display:flex}.ab-sel-field{flex-direction:column;gap:.35rem;min-width:200px;display:flex}.ab-sel-field label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.ab-sel-wrap{align-items:center;display:flex;position:relative}.ab-sel-ico{color:#94a3b8;pointer-events:none;z-index:1;position:absolute;left:.65rem}.ab-sel-chev{color:#94a3b8;pointer-events:none;position:absolute;right:.65rem}.ab-sel-wrap select{color:#1e293b;appearance:none;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;width:100%;padding:.5rem 2rem .5rem 2.1rem;font-size:.84rem;transition:border-color .15s}.ab-sel-wrap select:focus{border-color:#22c55e;outline:none;box-shadow:0 0 0 3px #22c55e1f}.ab-sel-wrap select:disabled{color:#94a3b8;cursor:not-allowed;background:#f8fafc}.ab-gen-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#16a34a;border:none;border-radius:8px;align-self:flex-end;align-items:center;gap:.5rem;padding:.52rem 1.2rem;font-size:.84rem;font-weight:600;transition:background .15s,opacity .15s;display:inline-flex}.ab-gen-btn:hover:not(:disabled){background:#15803d}.ab-gen-btn:disabled{opacity:.55;cursor:not-allowed}.ab-th-editable{color:#1d4ed8!important;background:#eff6ff!important}.ab-td-editable{padding:0!important}.ab-cell-editable{cursor:pointer;white-space:nowrap;border-radius:4px;justify-content:center;align-items:center;min-width:70px;min-height:28px;padding:.3rem .5rem;transition:background .12s;display:flex}.ab-cell-editable:hover{background:#dbeafe}.ab-cell-err{background:#fee2e2!important}.ab-cell-input{text-align:center;background:#fff;border:1.5px solid #3b82f6;border-radius:4px;outline:none;width:90px;padding:.2rem .35rem;font-size:.78rem}.ab-cell-spinner{border:2px solid #cbd5e1;border-top-color:#3b82f6;border-radius:50%;width:12px;height:12px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.ab-cell-ok{color:#16a34a;font-size:.85rem;font-weight:700}.ab-edit-legend{color:#64748b;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.75rem;display:flex}.ab-edit-dot{background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:2px;flex-shrink:0;width:10px;height:10px}.ab-dl-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#1d4ed8;border:none;border-radius:.45rem;align-self:flex-end;align-items:center;gap:.5rem;padding:.52rem 1.2rem;font-size:.84rem;font-weight:600;transition:background .15s;display:inline-flex}.ab-dl-btn:hover{background:#1e40af}.ab-error{color:#dc2626;background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;padding:.75rem 1rem;font-size:.84rem}.ab-summary{flex-wrap:wrap;gap:.75rem;display:flex}.ab-sum-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;flex-direction:column;flex:140px;gap:.25rem;padding:.85rem 1rem;display:flex}.ab-sum-card.highlight{background:#f0fdf4;border-color:#bbf7d0}.ab-sum-label{color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-size:.7rem;font-weight:600}.ab-sum-value{color:#1e293b;font-size:1.2rem;font-weight:700}.ab-sum-card.highlight .ab-sum-value{color:#16a34a}.ab-tbl-outer{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;overflow:hidden}.ab-tbl-wrap{overflow-x:auto}.ab-tbl{border-collapse:collapse;width:max-content;min-width:100%;font-size:.78rem}.ab-tbl thead tr th{text-align:center;white-space:nowrap;color:#475569;background:#f8fafc;border-bottom:1.5px solid #e2e8f0;border-right:1px solid #e8edf2;padding:.5rem .65rem;font-weight:600}.ab-th-port{z-index:2;min-width:130px;position:sticky;left:0;text-align:left!important;background:#f1f5f9!important;border-right:2px solid #e2e8f0!important}.ab-td-port{color:#1e293b;white-space:nowrap;z-index:1;background:#fff;border-right:2px solid #e2e8f0;padding:.45rem .65rem;font-weight:600;position:sticky;left:0}.ab-thg.time{color:#2563eb;background:#eff6ff;border-bottom-color:#bfdbfe}.ab-thg.cargo{color:#16a34a;background:#f0fdf4;border-bottom-color:#bbf7d0}.ab-thg.hfo{color:#ea580c;background:#fff7ed;border-bottom-color:#fed7aa}.ab-thg.mgo{color:#9333ea;background:#fdf4ff;border-bottom-color:#e9d5ff}.ab-thg.voyage{color:#ca8a04;background:#fefce8;border-bottom-color:#fde68a}.ab-th-row th{color:#64748b;padding:.4rem .6rem;font-size:.7rem;font-weight:600}.ab-tbl-flat thead th{white-space:nowrap;padding:.55rem .7rem;font-size:.69rem}.ab-tbl-flat tbody td{white-space:nowrap}.ab-tbl tbody td{text-align:center;color:#334155;white-space:nowrap;border-bottom:1px solid #f1f5f9;border-right:1px solid #f1f5f9;padding:.42rem .65rem}.ab-tr-even td,.ab-tr-even .ab-td-port{background:#fafbfc}.ab-tbl tbody tr:last-child td{border-bottom:none}.ab-empty{color:#94a3b8;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:3.5rem 1rem;display:flex}.ab-empty p{color:#64748b;margin:0;font-size:.9rem}.ab-empty strong{color:#1e293b}.ab-tab-bar{border-bottom:2px solid #e2e8f0;gap:4px;margin-bottom:1.25rem;padding-bottom:0;display:flex}.ab-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:4px 4px 0 0;align-items:center;gap:6px;margin-bottom:-2px;padding:.55rem 1.1rem;font-size:.82rem;font-weight:600;transition:color .15s,border-color .15s;display:inline-flex}.ab-tab:hover{color:#1e293b;background:#f8fafc}.ab-tab-active{color:#2563eb;background:#eff6ff;border-bottom-color:#2563eb}.ab-rec-filters{flex-wrap:wrap;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.ab-rec-filter-wrap{align-items:center;display:flex;position:relative}.ab-rec-filter-ico{color:#94a3b8;pointer-events:none;position:absolute;left:8px}.ab-rec-filter-input{color:#1e293b;background:#fff;border:1px solid #cbd5e1;border-radius:6px;outline:none;min-width:180px;height:34px;padding:0 .75rem 0 2rem;font-size:.8rem;transition:border-color .15s}.ab-rec-filter-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.ab-rec-stats{color:#64748b;margin-bottom:.6rem;font-size:.78rem}.ab-rec-stats strong{color:#1e293b}.ab-th-action{z-index:4;text-align:center;white-space:nowrap;background:#1e293b;min-width:120px;position:sticky;left:0}.ab-td-action{z-index:2;text-align:center;background:#fff;border-right:2px solid #e2e8f0;padding:.3rem .4rem;position:sticky;left:0}.ab-tr-even .ab-td-action{background:#fafbfc}.ab-row-save-btn{color:#fff;cursor:pointer;white-space:nowrap;background:#2563eb;border:none;border-radius:4px;align-items:center;gap:.3rem;padding:.25rem .6rem;font-size:.7rem;font-weight:600;transition:background .15s;display:inline-flex}.ab-row-save-btn:hover{background:#1d4ed8}.ab-row-save-btn:active{background:#1e40af}.ab-row-save-btn:disabled{cursor:not-allowed;background:#93c5fd}.ab-row-saved{color:#16a34a;white-space:nowrap;font-size:.72rem;font-weight:600}.ab-row-err-wrap{flex-direction:column;align-items:center;gap:2px;display:flex}.ab-row-err{color:#dc2626;white-space:nowrap;font-size:.72rem;font-weight:600}.ab-row-err-msg{color:#dc2626;text-overflow:ellipsis;white-space:nowrap;text-align:center;cursor:help;title:attr(title);max-width:140px;font-size:.62rem;overflow:hidden}.ab-inline-input{color:#1e293b;text-align:right;box-sizing:border-box;background:#fff;border:1px solid #cbd5e1;border-radius:3px;outline:none;width:100%;min-width:64px;padding:.28rem .4rem;font-family:inherit;font-size:.75rem}.ab-inline-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.ab-td-dirty{background:#fffbeb!important}.ab-td-dirty .ab-inline-input{background:#fffbeb;border-color:#f59e0b}.sb-signout.active:before{display:none}.ab-port-cards{flex-direction:column;gap:1.25rem;display:flex}.ab-port-card{background:#fff;border:1.5px solid #e2e8f0;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000a}.ab-port-card-hd{background:#f8fafc;border-bottom:1.5px solid #e2e8f0;justify-content:space-between;align-items:center;gap:1rem;padding:.875rem 1.25rem;display:flex}.ab-port-card-info{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.ab-port-card-name{color:#0f172a;letter-spacing:-.015em;font-size:1.05rem;font-weight:700}.ab-port-card-meta{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.ab-port-card-meta span{color:#64748b;white-space:nowrap;background:#e8edf3;border-radius:4px;padding:.18rem .55rem;font-size:.72rem;font-weight:500}.ab-port-card-act{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.ab-row-save-btn--card{border-radius:7px!important;gap:.4rem!important;padding:.45rem 1rem!important;font-size:.8rem!important}.ab-form-sec{border-bottom:1px solid #f1f5f9;padding:.875rem 1.25rem}.ab-form-sec:last-child{border-bottom:none}.ab-form-sec-hd{text-transform:uppercase;letter-spacing:.07em;border-radius:4px;align-items:center;margin-bottom:.7rem;padding:.22rem .65rem;font-size:.67rem;font-weight:700;display:inline-flex}.ab-form-sec-hd--blue{color:#1d4ed8;background:#eff6ff}.ab-form-sec-hd--amber{color:#b45309;background:#fffbeb}.ab-form-sec-hd--green{color:#15803d;background:#f0fdf4}.ab-form-sec-hd--orange{color:#c2410c;background:#fff7ed}.ab-form-sec-hd--purple{color:#7e22ce;background:#fdf4ff}.ab-form-sec-hd--slate{color:#475569;background:#f1f5f9}.ab-form-grid{gap:.5rem;display:grid}.ab-form-grid--dt{grid-template-columns:repeat(auto-fill,minmax(195px,1fr))}.ab-form-grid--num{grid-template-columns:repeat(auto-fill,minmax(155px,1fr))}.ab-form-grid--sm{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.ab-ff{flex-direction:column;gap:.18rem;min-width:0;display:flex}.ab-ff-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;text-overflow:ellipsis;font-size:.63rem;font-weight:600;overflow:hidden}.ab-ff-val{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;background:#f8fafc;border:1px solid #e8edf3;border-radius:6px;align-items:center;min-height:30px;padding:.32rem .6rem;font-size:.82rem;font-weight:500;display:flex;overflow:hidden}.ab-ff--editable .ab-ff-label{color:#1d4ed8}.ab-ff-input{color:#1e293b;box-sizing:border-box;background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:6px;outline:none;width:100%;min-height:30px;padding:.32rem .6rem;font-family:inherit;font-size:.82rem;transition:border-color .15s,box-shadow .15s,background .15s}.ab-ff-input:focus{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61f}.ab-ff-input::placeholder{color:#cbd5e1}.ab-ff--dirty .ab-ff-input{background:#fffbeb;border-color:#f59e0b}.ab-ff--dirty .ab-ff-input:focus{border-color:#d97706;box-shadow:0 0 0 3px #f59e0b26}.db-main{background:#f8fafc}.db-header{background:#fff;border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;padding:1.75rem 2rem 1.25rem;display:flex}.db-header-title{color:#0f172a;margin:0;font-size:1.375rem;font-weight:700}.db-header-sub{color:#94a3b8;margin-top:3px;font-size:.875rem;display:block}.db-header-badge{color:#0284c7;background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;align-items:center;gap:.5rem;padding:.4rem .9rem;font-size:.8125rem;font-weight:600;display:flex}.db-loading{color:#94a3b8;flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:400px;font-size:.875rem;display:flex}.db-spin-ring{border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite db-spin}@keyframes db-spin{to{transform:rotate(360deg)}}.db-content{flex-direction:column;flex:1;gap:1.5rem;padding:1.5rem 2rem;display:flex;overflow-y:auto}.db-kpi-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem;display:grid}.db-kpi-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;align-items:center;gap:1rem;padding:1.25rem;transition:box-shadow .15s,transform .15s;display:flex}.db-kpi-card:hover{transform:translateY(-2px);box-shadow:0 4px 18px #00000014}.db-kpi-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.db-kpi-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.725rem;font-weight:600}.db-kpi-value{margin:3px 0 0;font-size:1.625rem;font-weight:700;line-height:1}.db-card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.db-card-hd{color:#0f172a;background:#fafafa;border-bottom:1px solid #f1f5f9;align-items:center;gap:.5rem;padding:.875rem 1.5rem;font-size:.875rem;font-weight:700;display:flex}.db-mid-row{grid-template-columns:1fr 340px;gap:1.25rem;display:grid}.db-tbl-scroll{overflow-x:auto}.db-tbl{border-collapse:collapse;width:100%;font-size:.8375rem}.db-tbl th{text-align:left;color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;background:#f8fafc;border-bottom:1px solid #e2e8f0;padding:.625rem 1rem;font-size:.725rem;font-weight:600}.db-tbl td{color:#334155;border-bottom:1px solid #f8fafc;padding:.75rem 1rem}.db-tbl tbody tr:last-child td{border-bottom:none}.db-tbl tbody tr:hover td{background:#f8fafc}.db-vessel-cell{color:#1e293b;align-items:center;gap:.375rem;font-weight:500;display:flex}.db-port-chip{color:#0284c7;background:#f0f9ff;border-radius:6px;align-items:center;gap:.25rem;padding:.2rem .5rem;font-size:.775rem;font-weight:500;display:inline-flex}.db-bar-wrap{background:#f1f5f9;border-radius:99px;width:100%;height:6px}.db-bar{border-radius:99px;min-width:3px;height:6px;transition:width .6s}.db-bar--blue{background:#3b82f6}.db-bar--teal{background:linear-gradient(90deg,#0ea5e9,#38bdf8)}.db-ports-list{padding:.25rem 0}.db-port-row{border-bottom:1px solid #f8fafc;align-items:center;gap:.75rem;padding:.6rem 1.25rem;display:flex}.db-port-row:last-child{border-bottom:none}.db-port-rank{color:#64748b;background:#f1f5f9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.7rem;font-weight:700;display:flex}.db-port-name{color:#334155;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:120px;font-size:.8375rem;font-weight:500;overflow:hidden}.db-port-count{color:#0ea5e9;text-align:right;flex-shrink:0;width:26px;font-size:.8125rem;font-weight:700}.db-monthly{align-items:flex-end;gap:.5rem;height:160px;padding:1.25rem 1.5rem;display:flex;overflow-x:auto}.db-month-col{flex-direction:column;flex:1;align-items:center;gap:.25rem;min-width:52px;display:flex}.db-month-bar-wrap{flex:1;align-items:flex-end;width:100%;display:flex}.db-month-bar{background:linear-gradient(#3b82f6,#93c5fd);border-radius:4px 4px 0 0;width:28px;min-height:4px;margin:0 auto;transition:height .6s}.db-month-label{color:#94a3b8;text-align:center;white-space:nowrap;font-size:.7rem;line-height:1.3}.db-month-val{color:#64748b;font-size:.7rem;font-weight:600}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--spacing:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.sticky{position:sticky}.start{inset-inline-start:var(--spacing)}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-flex{display:inline-flex}.table{display:table}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.italic{font-style:italic}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary-900:#0a1628;--primary-800:#0f2035;--primary-700:#132d4a;--primary-600:#1a3d5c;--primary-500:#1e4d6e;--primary-400:#2a6f97;--primary-300:#3d8bc4;--primary-200:#6db3e0;--primary-100:#a8d4f0;--accent-500:#00b4d8;--accent-400:#48cae4;--accent-300:#90e0ef;--accent-200:#ade8f4;--accent-glow:#00b4d84d;--neutral-50:#f8fafc;--neutral-100:#f1f5f9;--neutral-200:#e2e8f0;--neutral-300:#cbd5e1;--neutral-400:#94a3b8;--neutral-500:#64748b;--neutral-600:#475569;--neutral-700:#334155;--neutral-800:#1e293b;--neutral-900:#0f172a;--error:#ef4444;--error-light:#ef44441a;--success:#22c55e;--glass-bg:#0f203599;--glass-border:#ffffff14;--glass-highlight:#ffffff0a;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0000004d;--shadow-lg:0 8px 32px #0006;--shadow-xl:0 16px 48px #00000080;--shadow-glow:0 0 30px #00b4d826;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-family);color:var(--neutral-900);background:#f1f5f9;min-height:100vh;line-height:1.6}#root{min-height:100vh}a{color:var(--accent-400);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-300)}input,button{font-family:inherit}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
