:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.card{padding:2em}#app{max-width:1280px;margin:0;padding:0rem;text-align:center}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}[data-v-51d8362c]{margin:0;padding:0;box-sizing:border-box}.login-container[data-v-51d8362c]{position:fixed;inset:0;background:linear-gradient(135deg,#4facfe,#00f2fe);display:flex;align-items:center;justify-content:center;overflow-y:auto}.login-card[data-v-51d8362c]{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:40px;width:100%;max-width:400px;text-align:center;margin:20px;position:relative;z-index:1}.login-header[data-v-51d8362c]{margin-bottom:40px}.login-logo[data-v-51d8362c]{width:80px;height:80px;border-radius:16px;object-fit:contain}.login-title[data-v-51d8362c]{font-size:2rem;font-weight:700;color:#222;margin:0 0 8px;letter-spacing:1px}.login-subtitle[data-v-51d8362c]{font-size:.9rem;color:#666;margin:0;font-weight:500}.login-form[data-v-51d8362c]{margin-bottom:30px}.form-group[data-v-51d8362c]{margin-bottom:20px;text-align:left}.form-label[data-v-51d8362c]{display:block;font-size:.95rem;font-weight:600;color:#222;margin-bottom:8px}.form-input[data-v-51d8362c]{width:100%;padding:12px 16px;border:2px solid #e3e3e3;border-radius:12px;font-size:1rem;background:#f3f8fa;color:#222;transition:border-color .3s ease;box-sizing:border-box}.form-input[data-v-51d8362c]:focus{outline:none;border-color:#4facfe;background:#fff}.form-input[data-v-51d8362c]:disabled{opacity:.6;cursor:not-allowed}.password-wrapper[data-v-51d8362c]{position:relative;display:flex;align-items:center}.password-input[data-v-51d8362c]{padding-right:44px}.password-toggle[data-v-51d8362c]{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:32px;height:32px;border:none;background:transparent;color:#64748b;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer}.password-toggle[data-v-51d8362c]:hover:not(:disabled){background:#eef2f7;color:#1f2937}.error-message[data-v-51d8362c]{background:#fee;color:#d9534f;padding:12px;border-radius:8px;font-size:.9rem;margin-bottom:20px;border:1px solid #f5c6cb}.login-btn[data-v-51d8362c]{width:100%;padding:14px;background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.login-btn[data-v-51d8362c]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #4facfe4d}.login-btn[data-v-51d8362c]:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-spinner[data-v-51d8362c]{width:16px;height:16px;border:2px solid #fff;border-top:2px solid transparent;border-radius:50%;animation:spin-51d8362c 1s linear infinite}@keyframes spin-51d8362c{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer[data-v-51d8362c]{margin-top:30px;padding-top:20px;border-top:1px solid #e3e3e3}.login-footer p[data-v-51d8362c]{font-size:.8rem;color:#888;margin:0}@media (max-width: 480px){.login-card[data-v-51d8362c]{padding:30px 20px;margin:10px}.login-title[data-v-51d8362c]{font-size:1.5rem}.login-logo[data-v-51d8362c]{width:60px;height:60px}}html{background:#f3f8fa!important;min-height:100vh;min-width:100vw;width:100%;height:100%;margin:0;padding:0}body{background:#f3f8fa!important;font-family:Inter,Arial,sans-serif;margin:0;padding:0;overflow-x:auto;overflow-y:auto;min-height:100vh;min-width:100vw;width:100%;height:100%}.main-container{background:#f3f8fa!important;min-height:100vh;min-width:100vw;width:100%;height:100%;margin:0;padding:0;box-sizing:border-box}.main-container.admin-mode{display:flex;flex-direction:column;gap:16px;padding:16px;box-sizing:border-box;min-height:100vh;overflow-y:auto}.main-container.admin-mode .admin-toolbar,.main-container.admin-mode .header,.main-container.admin-mode .grid-layout,.main-container.admin-mode .admin-users-panel{margin-left:0;margin-right:0}.main-container.admin-mode .admin-toolbar{margin-top:0;position:sticky;top:16px;z-index:20}.main-container.admin-mode .header,.main-container.admin-mode .grid-layout,.main-container.admin-mode .admin-users-panel{margin-top:0}.main-container.admin-mode .grid-layout{height:calc(100vh - 176px)}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:20px;margin:16px;padding:16px 24px;box-shadow:0 2px 12px #0f172a14;gap:16px}.admin-toolbar-left{display:flex;align-items:center;gap:24px}.admin-brand{display:flex;align-items:center;gap:12px}.admin-brand-logo{width:44px;height:44px;border-radius:12px;object-fit:contain}.admin-brand-text{display:flex;flex-direction:column;gap:2px}.admin-brand-title{font-size:.95rem;font-weight:600;color:#0f172a;letter-spacing:.04em}.admin-brand-subtitle{font-size:.8rem;color:#64748b}.admin-tabs{display:flex;align-items:center;gap:12px}.admin-tab{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;background:#f1f5f9;border-radius:999px;border:none;font-size:.9rem;font-weight:600;color:#475569;cursor:pointer;transition:all .2s ease}.admin-tab:hover{background:#e2e8f0;color:#1d4ed8}.admin-tab.active{background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;box-shadow:0 8px 16px #2563eb40}.tab-badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:999px;border:1px solid transparent}.tab-badge.beta{background:#fbbf2426;border-color:#fbbf2480;color:#b45309}.admin-toolbar-right{display:flex;align-items:center;gap:16px}.admin-user-pill{display:flex;align-items:center;gap:12px;background:#eff6ff;border-radius:999px;padding:8px 14px;border:1px solid rgba(59,130,246,.2)}.admin-user-initials{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;letter-spacing:.03em}.admin-user-meta{display:flex;flex-direction:column;line-height:1.2}.admin-user-name{font-size:.9rem;font-weight:600;color:#0f172a}.admin-user-role{font-size:.75rem;font-weight:500;color:#2563eb;text-transform:uppercase;letter-spacing:.08em}.admin-logout{background:#fee2e2;border:1px solid #fecaca;color:#b91c1c;border-radius:999px;padding:10px 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .2s ease}.admin-logout:hover{background:#fecaca;color:#7f1d1d}.admin-users-panel{margin:0 16px 16px;background:#f8fafc;border-radius:24px;box-shadow:inset 0 1px #ffffff80,0 20px 40px #0f172a14;padding:24px;min-height:calc(100vh - 160px);box-sizing:border-box}.main-container:not(.admin-mode) .header{position:sticky;top:16px;z-index:20}.main-container:not(.admin-mode) .grid-layout{margin-top:0;height:calc(100vh - 176px)!important}.header{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:20px;margin:16px;padding:16px 24px;box-shadow:0 2px 12px #e3e3e3;min-width:calc(100vw - 32px);max-width:none;height:80px;box-sizing:border-box}.header-left{display:flex;align-items:center}.logout-btn{background:#f3f8fa;color:#666;border:1px solid #e3e3e3;border-radius:8px;padding:8px 12px;font-size:.9rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.logout-btn:hover{background:#e3e3e3;color:#333}.header-right{display:inline-flex;align-items:center;gap:12px}.logo{width:48px;height:48px;margin-right:18px;border-radius:12px;object-fit:contain}.header-title{font-size:1.5rem;font-weight:600;color:#222;letter-spacing:1px}.sidebar{background:#fff;border-radius:20px;box-shadow:0 2px 8px #e3e3e3;padding:16px 12px 12px;display:flex;flex-direction:column;min-width:0;height:100%;position:sticky;top:0;overflow-y:auto}.sidebar-title{font-size:1.1rem;font-weight:600;color:#222;margin-bottom:10px;text-align:center}.selected-ship-info{background:linear-gradient(135deg,#1976d2,#1565c0);border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 4px 12px #1976d24d;border:2px solid #ffffff}.info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.info-title{font-size:1rem;font-weight:600;color:#fff;margin:0;display:flex;align-items:center;text-shadow:0 1px 2px rgba(0,0,0,.1)}.close-ship-btn{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:16px;font-weight:700;line-height:1}.close-ship-btn:hover{background:#ffffff4d;transform:scale(1.1)}.ship-details{background:#fffffff2;border-radius:8px;padding:12px;box-shadow:inset 0 1px 3px #0000001a}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #e3f2fd}.detail-row:last-child{border-bottom:none}.detail-label{font-size:.85rem;font-weight:600;color:#1976d2;flex:1}.detail-value{font-size:.9rem;font-weight:500;color:#222;text-align:right;flex:1;font-family:Courier New,monospace}.search-row{display:flex;align-items:center;gap:6px;margin-bottom:8px}.search-input{flex:1;padding:6px 8px;border-radius:8px;border:1px solid #e3e3e3;background:#f3f8fa;color:#222;font-size:.98rem}.search-select{padding:5px 8px;border-radius:8px;border:1px solid #e3e3e3;background:#f3f8fa;color:#222;font-size:.95rem}.search-btn{background:none;border:none;cursor:pointer;padding:0}.ship-list{list-style:none;padding:0;margin:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#1976d2 #f0f0f0}.ship-list::-webkit-scrollbar{width:40px}.ship-list::-webkit-scrollbar-track{background:#f0f0f0;border-radius:6px}.ship-list::-webkit-scrollbar-thumb{background:#1976d2;border-radius:16px;border:16px solid #f0f0f0}.ship-list::-webkit-scrollbar-thumb:hover{background:#1565c0}.ship-scroll-controls{position:absolute;right:100px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:8px;z-index:10}.ship-scroll-btn{width:32px;height:32px;border-radius:50%;border:1px solid #e3e3e3;background:#ffffffe6;box-shadow:0 2px 8px #0000001a;cursor:pointer;color:#1976d2;font-weight:700}.ship-scroll-btn:hover{background:#f3f8fa}.ship-scroll-btn:disabled{opacity:.4;cursor:not-allowed}.ship-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #e3e3e3;cursor:pointer;transition:background .2s}.ship-item:hover{background:#f3f8fa}.ship-item.selected{background:#e3f2fd;border:2px solid #1976d2;border-radius:6px;margin:4px 0;padding:10px 8px;box-shadow:0 2px 4px #0000001a}.ship-item.selected .ship-name,.ship-item.selected .ship-sn{color:#1976d2;font-weight:600}.ship-item.selected .ship-sn{background:#bbdefb;color:#1976d2}.loading-item,.error-item,.empty-item{display:flex;align-items:center;justify-content:center;padding:20px;text-align:center;color:#666;font-style:italic}.loading-text{color:#3498db}.error-text{color:#e74c3c}.empty-text{color:#95a5a6}.ship-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;position:relative;color:#1976d2;--ship-status-color: #9ca3af}.ship-icon img{width:28px;height:28px;object-fit:contain}.ship-icon:after{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:var(--ship-status-color);border:2px solid rgba(255,255,255,.9);right:-6px;top:0;box-shadow:0 0 4px #0003}.ship-icon.ship-status-active{color:#2ecc40;--ship-status-color: #2ecc40}.ship-icon.ship-status-inactive{color:#e74c3c;--ship-status-color: #e74c3c}.ship-icon.ship-status-unknown{color:#6b7280;--ship-status-color: #6b7280}.ship-icon-large{width:40px;height:40px;margin-right:8px;display:inline-flex;align-items:center;justify-content:center;position:relative;color:#1976d2;--ship-status-color: #9ca3af}.ship-icon-large img{width:36px;height:36px;object-fit:contain}.ship-icon-large:after{content:"";position:absolute;width:10px;height:10px;border-radius:50%;background:var(--ship-status-color);border:2px solid rgba(255,255,255,.9);right:-6px;top:4px;box-shadow:0 0 4px #00000040}.ship-icon-large.ship-status-active{color:#2ecc40;--ship-status-color: #2ecc40}.ship-icon-large.ship-status-inactive{color:#e74c3c;--ship-status-color: #e74c3c}.ship-icon-large.ship-status-unknown{color:#6b7280;--ship-status-color: #6b7280}.ship-info{display:flex;flex-direction:column;flex:1;gap:2px}.ship-name{font-weight:600;color:#222;font-size:.95rem;line-height:1.2;margin-left:40px;text-align:left}.ship-sn{font-size:.85rem;color:#666;font-weight:500;font-family:monospace;background:#f8f9fa;padding:2px 6px;border-radius:4px;line-height:1.2;width:fit-content;margin-left:40px;margin-top:2px;align-self:flex-start}.sidebar-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;font-size:.98rem;color:#222}.total-data{font-weight:600;margin-left:8px}.export-btn{background:#e3f7e3;color:#2ecc40;border:none;border-radius:8px;padding:5px 16px;font-weight:600;cursor:pointer;box-shadow:0 1px 4px #e3e3e3;transition:background .2s;font-size:.98rem}.export-btn:hover{background:#c8f7c5}.refresh-btn{background:#e3f2fd;color:#2196f3;border:none;border-radius:8px;padding:5px 12px;font-weight:600;cursor:pointer;box-shadow:0 1px 4px #e3e3e3;transition:background .2s;font-size:.98rem;margin-right:8px}.refresh-btn:hover:not(:disabled){background:#bbdefb}.refresh-btn:disabled{opacity:.6;cursor:not-allowed}.test-api-btn{background:#fff3cd;color:#856404;border:none;border-radius:8px;padding:5px 12px;font-weight:600;cursor:pointer;box-shadow:0 1px 4px #e3e3e3;transition:background .2s;font-size:.98rem;margin-right:8px}.test-api-btn:hover:not(:disabled){background:#ffeaa7}.test-api-btn:disabled{opacity:.6;cursor:not-allowed}.map-container{position:relative;background:#fff;border-radius:20px;box-shadow:0 2px 8px #e3e3e3;height:100%;display:flex;flex-direction:column;min-width:100%;width:auto;overflow:hidden}#map{flex:1;width:100%;height:100%;min-height:100%;border-radius:20px}.map-ship-icon-wrapper{width:36px;height:48px;display:inline-flex;align-items:center;justify-content:center}.map-ship-icon{position:relative;width:36px;height:48px;display:flex;align-items:center;justify-content:center;--ship-status-color: #9ca3af;--ship-border: #1976d2}.map-ship-icon img{width:28px;height:44px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.35));transform:rotate(var(--ship-heading, 0deg));transform-origin:50% 60%}.map-ship-icon:before{content:"";position:absolute;bottom:8px;width:24px;height:24px;border-radius:50%;border:2px solid var(--ship-border);opacity:.35}.map-ship-icon .ship-status-dot{position:absolute;bottom:4px;right:2px;width:12px;height:12px;border-radius:50%;background:var(--ship-status-color);border:2px solid #ffffff;box-shadow:0 0 4px #0000004d}.map-ship-icon.ship-status-active{--ship-status-color: #2ecc40}.map-ship-icon.ship-status-inactive{--ship-status-color: #e74c3c}.map-ship-icon.ship-status-unknown{--ship-status-color: #6b7280}.summary-btn-container{position:absolute;right:16px;bottom:56px;z-index:1000;display:flex;align-items:center;gap:10px}.kmlkmz-global-error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#dc2626;color:#fff;padding:14px 22px;font-size:15px;font-weight:600;border-radius:10px;box-shadow:0 6px 18px #00000040;z-index:1200;max-width:60%;text-align:center;line-height:1.4;animation:kmlkmzFade .3s ease-out}.kmlkmz-global-success{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#16a34a;color:#fff;padding:14px 22px;font-size:15px;font-weight:600;border-radius:10px;box-shadow:0 6px 18px #00000040;z-index:1200;max-width:60%;text-align:center;line-height:1.4;animation:kmlkmzFade .2s ease-out}@keyframes kmlkmzFade{0%{opacity:0;transform:translate(-50%,-55%)}to{opacity:1;transform:translate(-50%,-50%)}}.copyright{position:absolute;right:16px;bottom:16px;font-size:.9rem;color:#888;background:#ffffffe6;padding:6px 12px;border-radius:8px;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;gap:8px}.waypoint-actions{position:absolute;right:24px;bottom:56px;display:flex;gap:10px;z-index:1000}.waypoint-btn{background:#222;color:#fff;border:none;border-radius:12px;padding:10px 22px;font-size:1rem;font-weight:600;box-shadow:0 2px 8px #e3e3e3;cursor:pointer;opacity:.95}.waypoint-btn:hover{background:#444}.waypoint-eta-btn{background:#fff;color:#222;border:1px solid #e3e3e3;border-radius:12px;padding:10px 18px 10px 10px;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:8px;box-shadow:0 2px 8px #e3e3e3;cursor:pointer}.waypoint-eta-btn:hover{background:#f3f8fa}.eta-icon{width:22px;height:22px}.tracking-btn{background:#fff;color:#222;border:1px solid #e3e3e3;border-radius:12px;padding:8px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #e3e3e3;cursor:pointer}.tracking-btn:hover{background:#f3f8fa}.history-icon{width:24px;height:24px;border-radius:6px}.summary-btn{background:#fff;color:#222;border:1px solid #e3e3e3;width:56px;height:56px;border-radius:12px;padding:6px;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #e3e3e3;cursor:pointer}.summary-btn:hover{background:#f8f9fa}.summary-icon{width:35px;height:35px;border-radius:4px}.tracking-range{-webkit-appearance:none;appearance:none;width:180px;height:8px;border-radius:6px;background:#e3e3e3;outline:none;margin-right:8px}.tracking-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#000;cursor:pointer;box-shadow:0 1px 3px #0003}.tracking-range::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#1976d2;cursor:pointer}.tracking-range-meta{display:flex;flex-direction:column;gap:2px;color:#111;font-size:.85rem;margin-right:8px}.tracking-range-meta .meta-line{display:flex;gap:6px;align-items:baseline}.tracking-range-meta .meta-label{color:#666}.tracking-range-meta .meta-value{color:#1976d2;font-weight:600;font-family:Courier New,monospace}.track-ship-red-wrapper{background:transparent!important;border:none!important}.track-ship-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;transform:rotate(var(--track-heading, 0deg));transform-origin:50% 60%}.track-ship-red{width:36px;height:40px;display:block;filter:invert(17%) sepia(86%) saturate(7477%) hue-rotate(1deg) brightness(99%) contrast(113%)}.tracking-info{position:absolute;top:16px;right:16px;background:#fffffff2;padding:10px 14px;border-radius:10px;box-shadow:0 6px 18px #0000001f;z-index:1201;font-size:.95rem;color:#111}.tracking-info .ti-row{margin-bottom:6px}.tracking-info .ti-row strong{color:#1976d2}html{scroll-behavior:smooth}.tracking-download{position:absolute;left:12px;bottom:48px;z-index:1201}.tracking-download .download-btn{background:#737373;color:#fff;border:none;border-radius:10px;padding:8px 12px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #00000026}.tracking-download .download-btn:hover{background:#121212}@media (min-width: 1920px){.grid-layout,.header{max-width:1800px;margin:16px auto}}@media (max-width: 320px){.grid-layout,.header{margin:8px;min-width:calc(100vw - 16px)}}html,body,.main-container{background-attachment:fixed;background-repeat:no-repeat;background-size:cover}.grid-layout{display:grid;grid-template-columns:minmax(300px,360px) 1fr;grid-template-rows:1fr;gap:16px;height:calc(100vh - 176px);margin:16px;min-width:calc(100vw - 32px);width:100%;box-sizing:border-box;background:transparent}.sidebar,.map-container{background:#fff!important}*{box-sizing:border-box}html:before,body:before,.main-container:before{content:"";position:fixed;top:0;left:0;width:100vw;height:100vh;background:#f3f8fa;z-index:-1;pointer-events:none}html,body{position:relative}html:after,body:after{content:"";position:absolute;inset:0;background:#f3f8fa;z-index:-2;pointer-events:none}html,body,.main-container{background-color:#f3f8fa!important}.sidebar,.map-container,.header,.modal-overlay,.waypoint-eta-panel{background-color:#fff!important}
