:root{--primary: #4285F4;--primary-hover: #3367D6;--primary-light: #E8F0FE;--primary-ultra-light: #F0F6FF;--bg: #FAFBFF;--bg-card: #FFFFFF;--border: #E1E5EB;--border-light: #EEF1F6;--text: #1A1D26;--text-secondary: #5F6577;--text-muted: #9BA1B2;--danger: #EA4335;--success: #34A853;--warning: #FBBC04;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .06);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .12);--radius: 10px;--radius-sm: 6px;--radius-lg: 16px;--transition: .2s ease}*{margin:0;padding:0;box-sizing:border-box}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:0 4px 24px #00000014;padding:40px 32px;width:100%;max-width:380px}.login-title{font-size:22px;font-weight:700;margin-bottom:4px;text-align:center}.login-subtitle{font-size:14px;color:var(--text-muted);text-align:center;margin-bottom:24px}.login-card .form-group{margin-bottom:16px}.login-card .form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}.login-card .form-group input{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:15px;color:var(--text);transition:var(--transition)}.login-card .form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4285f426}.otp-code{font-family:SF Mono,SFMono-Regular,Consolas,monospace;font-size:13px;font-weight:600;background:#f0f6ff;color:var(--primary);padding:4px 8px;border-radius:4px;cursor:pointer;letter-spacing:1px}html,body{overflow-x:clip;max-width:100vw}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;margin:0}.top-nav{display:flex;align-items:center;justify-content:space-between;height:60px;padding:0 24px;background:var(--bg-card);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm);overflow-x:clip;overflow-y:visible;max-width:100vw;box-sizing:border-box}.nav-left{display:flex;align-items:center;gap:12px;min-width:180px}.app-logo{width:32px;height:32px;object-fit:contain}.app-title{font-size:18px;font-weight:700;color:var(--text);letter-spacing:-.3px}.nav-tabs{display:flex;gap:4px;overflow-x:auto;overflow-y:hidden;flex:1;min-width:0;scrollbar-width:none}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:14px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius);transition:all var(--transition);position:relative;flex-shrink:0;white-space:nowrap}.nav-tab:hover{background:var(--primary-ultra-light);color:var(--primary)}.nav-tab.active{color:var(--primary);background:var(--primary-light)}.nav-tab.active:after{content:"";position:absolute;bottom:-11px;left:50%;transform:translate(-50%);width:40px;height:3px;background:var(--primary);border-radius:3px}.nav-tab svg{flex-shrink:0}.nav-right{display:flex;align-items:center;min-width:180px;justify-content:flex-end}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7B61FF);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);border:none}.user-avatar:hover{transform:scale(1.08);box-shadow:0 2px 12px #4285f44d}.top-nav{display:none!important}:root{--sb-collapsed: 48px;--sb-expanded: 210px}.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sb-collapsed);background:#fff;border-right:1px solid var(--border-light);z-index:200;display:flex;flex-direction:column;transition:width .2s cubic-bezier(.4,0,.2,1),box-shadow .2s;overflow:hidden}.sidebar:hover,.sidebar.pinned{width:var(--sb-expanded);box-shadow:2px 0 16px #0000000f}.sidebar.pinned{box-shadow:none}.sidebar-header{display:flex;align-items:center;gap:10px;padding:12px;border-bottom:1px solid var(--border-light);flex-shrink:0;height:48px;box-sizing:border-box}.sidebar-logo{width:24px;height:24px;object-fit:contain;flex-shrink:0}.sidebar-title{font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.3px;flex:1;opacity:0;white-space:nowrap;transition:opacity .15s}.sidebar:hover .sidebar-title,.sidebar.pinned .sidebar-title{opacity:1}.sidebar-pin{width:24px;height:24px;border:none;background:none;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;opacity:0}.sidebar:hover .sidebar-pin,.sidebar.pinned .sidebar-pin{opacity:1}.sidebar-pin:hover{background:var(--bg);color:var(--primary)}.sidebar.pinned .sidebar-pin{color:var(--primary);background:var(--primary-ultra-light);transform:rotate(45deg)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:6px;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.sidebar-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .12s;text-align:left;white-space:nowrap;box-sizing:border-box}.sidebar-item:hover{background:var(--bg);color:var(--text)}.sidebar-item.active{background:transparent;color:var(--primary);font-weight:600}.sidebar-item svg{flex-shrink:0;opacity:.6;width:22px;height:22px}.sidebar-item:hover svg{opacity:.9}.sidebar-item.active svg{opacity:.85}.sidebar-item span{opacity:0;transition:opacity .15s;overflow:hidden}.sidebar:hover .sidebar-item span,.sidebar.pinned .sidebar-item span{opacity:1}.sidebar-separator{height:1px;background:var(--border-light);margin:4px 10px}.sidebar-footer{border-top:1px solid var(--border-light);padding:6px;flex-shrink:0}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 10px;margin-top:4px;cursor:pointer;border-radius:var(--radius-sm);transition:background .12s}.sidebar-user:hover{background:var(--bg)}.sidebar-user-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7B61FF);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0}.sidebar-user-name{font-size:12px;font-weight:500;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:0;transition:opacity .15s}.sidebar:hover .sidebar-user-name,.sidebar.pinned .sidebar-user-name{opacity:1}.sidebar-user-menu{display:none;position:absolute;bottom:60px;left:8px;width:200px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0000001f;z-index:300;padding:8px 0}.sidebar-user-menu.open{display:block}.sidebar-user-menu-info{padding:10px 14px;font-size:12px;line-height:1.5;color:var(--text-secondary)}.sidebar-user-menu-info strong{color:var(--text);font-size:13px;display:block}.sidebar-user-menu-info small{color:var(--text-muted)}.sidebar-user-menu-divider{height:1px;background:var(--border-light);margin:4px 0}.sidebar-user-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 14px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:13px;color:var(--danger);transition:background .1s}.sidebar-user-menu-item:hover{background:var(--bg)}.sidebar-toggle{display:none}.main-content{max-width:100%;margin:0;padding:28px 40px 28px calc(var(--sb-collapsed) + 40px);transition:padding-left .2s cubic-bezier(.4,0,.2,1);overflow-x:hidden;box-sizing:border-box}body.sidebar-pinned .main-content{padding-left:calc(var(--sb-expanded) + 40px)}.main-content:has(#tab-mapbox.active),.main-content:has(#tab-map.active),.main-content:has(#tab-embeddedmap.active),.main-content:has(#tab-fleetmap.active),.main-content:has(#tab-mapstitch.active){max-width:100%;padding:0 0 0 var(--sb-collapsed);overflow:hidden}body.sidebar-pinned .main-content:has(#tab-mapbox.active),body.sidebar-pinned .main-content:has(#tab-map.active),body.sidebar-pinned .main-content:has(#tab-embeddedmap.active),body.sidebar-pinned .main-content:has(#tab-fleetmap.active),body.sidebar-pinned .main-content:has(#tab-mapstitch.active){padding-left:var(--sb-expanded)}body:has(#tab-fleetmap.active),body:has(#tab-mapbox.active),body:has(#tab-map.active),body:has(#tab-embeddedmap.active),body:has(#tab-mapstitch.active){overflow:hidden}.tab-content{display:none;animation:fadeIn .3s ease}.tab-content.active{display:block}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.control-section{margin-bottom:28px}.control-label{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}.control-label .required-badge{font-size:11px;color:var(--text-muted);text-transform:none;font-weight:400;letter-spacing:0}.vessel-select{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg-card);font-family:inherit;font-size:15px;color:var(--text);cursor:pointer;transition:var(--transition);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%235F6577' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}.vessel-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4285f426}.date-buttons{display:flex;gap:8px}.date-btn{padding:10px 22px;border:1.5px solid var(--border);border-radius:24px;background:var(--bg-card);font-family:inherit;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.date-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-ultra-light)}.date-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 2px 8px #4285f440}.timesheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.progress-bar-container{display:flex;align-items:center;gap:12px;margin-bottom:16px}.progress-bar-track{flex:1;height:10px;background:var(--border);border-radius:5px;overflow:hidden}.progress-bar-fill{height:100%;width:0%;background:linear-gradient(90deg,#4285F4,#34a853);border-radius:5px;transition:width .5s ease}.progress-bar-label{font-size:13px;font-weight:600;color:var(--text-secondary);white-space:nowrap;min-width:90px;text-align:right}.progress-expand-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border);border-radius:50%;background:var(--bg-card);color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:background var(--transition),color var(--transition),border-color var(--transition)}.progress-expand-btn:hover{background:var(--primary-ultra-light);color:var(--primary);border-color:var(--primary)}.progress-expand-btn svg{transition:transform .3s ease}.inline-dashboard{max-height:0;overflow:hidden;transition:max-height .4s ease,opacity .3s ease;opacity:0}.inline-dashboard.open{max-height:700px;opacity:1}.timesheet-title{font-size:24px;font-weight:700;color:var(--text);letter-spacing:-.5px}.add-btn{display:flex;align-items:center;gap:8px;padding:10px 24px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:0 2px 8px #4285f440}.add-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 16px #4285f459}.add-btn:active{transform:translateY(0)}.entries-table{width:100%;background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.entries-table table{width:100%;border-collapse:collapse}.entries-table th{text-align:left;padding:14px 20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);background:var(--primary-ultra-light);border-bottom:1px solid var(--border-light)}.entries-table td{padding:14px 20px;font-size:14px;color:var(--text);border-bottom:1px solid var(--border-light);vertical-align:middle}.entries-table tr:last-child td{border-bottom:none}.entries-table tr:hover td{background:var(--primary-ultra-light)}.gap-row td{text-align:center;padding:8px 20px;font-size:13px;font-weight:600;color:#92400e;border:1px solid #fcd34d;background:#fef3c7;pointer-events:none;box-shadow:0 1px 3px #fcd34d33}.gap-row td:before{content:"⚠️ ";margin-right:4px}.entries-table tr.gap-row:hover td{background:#fef3c7}.entry-tag{display:inline-block;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;background:var(--primary-light);color:var(--primary)}.entry-tag.cargo-ops{background:#E8F5E9;color:#2e7d32}.entry-tag.waiting{background:#FFF8E1;color:#f57f17}.entry-tag.transit{background:#E3F2FD;color:#1565c0}.entry-tag.maintenance{background:#F3E5F5;color:#7b1fa2}.entry-tag.bunkering{background:#FBE9E7;color:#d84315}.entry-tag.anchored{background:#E0F2F1;color:#00695c}.entry-tag.weather-delay{background:#ECEFF1;color:#455a64}.entry-tag.port-stay{background:#E8EAF6;color:#283593}.entry-actions{display:flex;gap:4px;opacity:0;transition:var(--transition)}.entries-table tr:hover .entry-actions{opacity:1}.entry-action-btn{padding:4px 8px;border:none;background:none;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm);transition:var(--transition);display:flex;align-items:center}.entry-action-btn:hover{background:var(--primary-light);color:var(--primary)}.entry-action-btn.delete:hover{background:#FFEAEA;color:var(--danger)}.sync-cell{display:flex;align-items:center;gap:6px}.sync-icon{display:inline-flex;flex-shrink:0}.sync-icon.sync-pending svg{animation:sync-spin 1.2s linear infinite}.sync-icon.sync-failed{cursor:pointer}@keyframes sync-spin{to{transform:rotate(360deg)}}.sync-row-pending{background:#FFFBEB!important}.sync-row-pending:hover{background:#FEF3C7!important}.sync-row-failed{background:#FEF2F2!important}.sync-row-failed:hover{background:#FEE2E2!important}.sync-icon{position:relative}.sync-tooltip{display:none;position:absolute;left:0;bottom:calc(100% + 6px);z-index:100;background:#fff;border:1px solid #E2E8F0;border-radius:8px;padding:8px 12px;font-size:11px;line-height:1.5;color:#475569;white-space:nowrap;box-shadow:0 4px 12px #0f172a1a;font-family:IBM Plex Sans,system-ui,sans-serif;pointer-events:none}.sync-tooltip:before{content:"";position:absolute;bottom:-5px;left:7px;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid #E2E8F0}.sync-tooltip:after{content:"";position:absolute;bottom:-4px;left:8px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #fff}.sync-tooltip strong{color:#0f172a;font-weight:600}.sync-tooltip-failed{border-left:3px solid #DC2626}.sync-tooltip-pending{border-left:3px solid #CA8A04}.sync-tooltip-ok{border-left:3px solid #0D9488}.sync-icon:hover .sync-tooltip{display:block}.sync-banner{display:none;align-items:center;gap:8px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;margin:8px 0;font-family:IBM Plex Sans,system-ui,sans-serif}.sync-banner-pending{background:#FFFBEB;border:1px solid #FDE68A;color:#92400e}.sync-banner-failed{background:#FEF2F2;border:1px solid #FECACA;color:#991b1b}.sync-banner .sync-spinner-icon{animation:sync-spin 1.2s linear infinite}.sync-retry-btn{margin-left:auto;padding:4px 12px;border-radius:4px;background:#DC2626;color:#fff;border:none;font-size:12px;font-weight:600;cursor:pointer;transition:background .15s;font-family:IBM Plex Sans,system-ui,sans-serif}.sync-retry-btn:hover{background:#B91C1C}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state svg{margin-bottom:16px;opacity:.4}.empty-state p{font-size:15px}.panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s ease}.panel-overlay.open{opacity:1;pointer-events:all}.slide-panel{position:absolute;right:0;top:0;bottom:0;width:480px;max-width:100vw;background:var(--bg-card);box-shadow:var(--shadow-lg);transform:translate(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}.panel-overlay.open .slide-panel{transform:translate(0)}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-light)}.panel-header h2{font-size:20px;font-weight:700}.panel-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:6px;border-radius:var(--radius-sm);transition:var(--transition);display:flex}.panel-close:hover{background:#FFEAEA;color:var(--danger)}.entry-form{padding:24px;flex:1;overflow-y:auto}.form-group{margin-bottom:20px}.field-error{color:#e53e3e;font-size:.8rem;margin-top:4px;display:none}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-group .required{color:var(--danger)}.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:12px 40px 12px 16px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:15px;color:var(--text);transition:var(--transition);background:var(--bg-card)}.form-group select:invalid{color:var(--text-muted)}.form-group select option{color:var(--text)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4285f426}.form-group textarea{resize:vertical}.form-group input[type=file]{font-family:inherit;font-size:14px;color:var(--text-secondary)}.form-actions{display:flex;gap:12px;padding-top:8px}.btn{padding:12px 28px;border-radius:var(--radius);font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);border:none}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4285f440}.btn-primary:hover{background:var(--primary-hover);box-shadow:0 4px 16px #4285f459}.btn-secondary{background:var(--bg);color:var(--text-secondary);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--primary-ultra-light);border-color:var(--primary);color:var(--primary)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:28px}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);transition:var(--transition)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-value{font-size:32px;font-weight:700;color:var(--primary);margin-bottom:4px}.stat-label{font-size:13px;color:var(--text-muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.chart-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light);margin-bottom:20px}.chart-card h3{font-size:18px;font-weight:700;margin-bottom:16px;color:var(--text)}.chart-container{position:relative;height:300px}.buoy-scale-tabs{border-bottom:none;padding-bottom:0;margin-bottom:0;justify-content:flex-end}.buoy-scale-btn.disabled{opacity:.35;cursor:not-allowed;pointer-events:none}.buoy-chart-card{background:#fff;border-radius:12px;padding:0;box-shadow:0 1px 2px #0f172a0d;border:1px solid #E2E8F0;overflow:hidden;transition:box-shadow .2s}.buoy-chart-card:hover{box-shadow:0 4px 6px -1px #0f172a12}.buoy-chart-header{display:flex;justify-content:space-between;align-items:center;padding:14px 20px 0}.buoy-chart-title-row{display:flex;align-items:center;gap:8px;color:#0f172a}.buoy-chart-title-row svg{opacity:.7;color:#0c4a6e}.buoy-chart-title-row h3{font-size:15px;font-weight:600;letter-spacing:.01em;color:#0f172a;margin:0;font-family:IBM Plex Sans,system-ui,sans-serif}.buoy-chart-meta{display:flex;align-items:center;gap:10px}.buoy-chart-badge{font-size:10px;font-weight:700;letter-spacing:.08em;padding:3px 8px;border-radius:4px;text-transform:uppercase}.buoy-badge-light{background:#E0F2FE;color:#0284c7}.buoy-badge-moderate{background:#CFFAFE;color:#0891b2}.buoy-badge-fresh{background:#FEF9C3;color:#a16207}.buoy-badge-strong{background:#FFEDD5;color:#c2410c}.buoy-badge-storm{background:#FEE2E2;color:#dc2626}.buoy-badge-calm{background:#CFFAFE;color:#0891b2}.buoy-badge-rough{background:#FFEDD5;color:#c2410c}.buoy-badge-dry{background:#F0FDF4;color:#16a34a}.buoy-badge-heavy{background:#EFF6FF;color:#1d4ed8}.buoy-unit-toggle{display:inline-flex;border:1px solid #E2E8F0;border-radius:4px;overflow:hidden}.buoy-unit-btn{background:transparent;border:none;padding:3px 10px;font-size:11px;font-weight:600;color:#94a3b8;cursor:pointer;transition:all .12s;font-family:IBM Plex Sans,system-ui,sans-serif}.buoy-unit-btn.active{background:#0F172A;color:#fff}.buoy-source-link{font-size:11px;color:#94a3b8;text-decoration:none;font-family:IBM Plex Sans,system-ui,sans-serif;transition:color .2s}.buoy-source-link:hover{color:#0c4a6e}.buoy-summary-strip{display:flex;gap:0;padding:12px 20px;border-bottom:1px solid var(--border-light)}.buoy-stat{flex:1;text-align:center;padding:0 8px;border-right:1px solid #E2E8F0}.buoy-stat:last-child{border-right:none}.buoy-stat-value{display:block;font-size:18px;font-weight:700;line-height:1.2;font-family:IBM Plex Mono,monospace;font-variant-numeric:tabular-nums}.buoy-stat-label{display:block;font-size:10px;color:#94a3b8;text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-family:IBM Plex Sans,system-ui,sans-serif;font-weight:500}.buoy-dir-row{display:flex;justify-content:space-around;padding:6px 20px 4px;border-top:1px solid #F1F5F9;min-height:32px}.buoy-dir-cell{display:flex;flex-direction:column;align-items:center;gap:1px;flex:1}.buoy-dir-label{font-size:8px;color:var(--text-muted);letter-spacing:.04em;font-weight:600}.buoy-status{font-size:11px;color:#94a3b8;padding:6px 20px 12px;margin:0;font-family:IBM Plex Sans,system-ui,sans-serif}.buoy-tbl-title{padding:14px 20px 10px;font-size:14px;font-weight:600;color:#0f766e}.buoy-tbl-date{font-weight:400;color:var(--text-muted);margin-left:12px;font-size:12px}.buoy-tbl-scroll{overflow-x:auto;padding:0 0 8px;-webkit-overflow-scrolling:touch}.buoy-tbl{border-collapse:collapse;font-size:12px;min-width:100%}.buoy-tbl th,.buoy-tbl td{padding:3px 4px;text-align:center;white-space:nowrap;min-width:46px;border-right:1px solid #f1f5f9}.buoy-tbl-label{position:sticky;left:0;background:#fff;z-index:2;text-align:right!important;padding-right:10px!important;font-weight:600;color:var(--text-secondary);min-width:110px!important;max-width:110px;font-size:11px;border-right:2px solid #e2e8f0!important}.buoy-tbl-day-row th{background:#f1f5f9;font-weight:700;font-size:13px;padding:8px 0;border-bottom:2px solid #cbd5e1;color:var(--text)}.buoy-tbl-day{border-left:2px solid #cbd5e1}.buoy-tbl-time-row th{font-weight:500;font-size:10px;color:var(--text-muted);padding:5px 2px;border-bottom:1px solid #e2e8f0}.buoy-tbl-day-start{border-left:2px solid #cbd5e1!important}.buoy-tbl-section td{background:#f8fafc;text-align:left!important;padding:6px 12px;font-size:12px;color:var(--text);border-top:2px solid #e2e8f0;border-bottom:1px solid #e2e8f0}.buoy-tbl-section .buoy-tbl-label{background:#f8fafc}.buoy-tbl-bar-cell{vertical-align:bottom;padding:2px 1px 0!important}.buoy-tbl-bar-wrap{position:relative;width:100%;display:flex;justify-content:center}.buoy-tbl-wind-gust{width:22px;background:#93c5fd;border-radius:2px 2px 0 0;position:absolute;bottom:0}.buoy-tbl-wind-avg{width:22px;background:#3b82f6;border-radius:2px 2px 0 0;position:absolute;bottom:0}.buoy-tbl-val{font-weight:700;font-size:12px;padding:3px 2px}.buoy-tbl-gust{color:#334155;font-weight:500}.buoy-tbl-dir{font-size:10px;color:var(--text-muted);line-height:1.3;padding:4px 2px!important}.buoy-tbl-dir span{display:block;font-size:9px;font-weight:600;margin-top:1px}.buoy-tbl-wave-peak{width:22px;background:#7dd3fc;border-radius:2px 2px 0 0;position:absolute;bottom:0}.buoy-tbl-wave-avg{width:22px;background:#0891b2;border-radius:2px 2px 0 0;position:absolute;bottom:0}.mfc-card{background:#fff;border:1px solid #E2E8F0;border-radius:12px;overflow:hidden;box-shadow:0 1px 2px #0f172a0d}.mfc-header{padding:14px 20px 10px;border-bottom:1px solid #e2e8f0}.mfc-title-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.mfc-title{font-size:15px;font-weight:600;color:#0f172a;font-family:IBM Plex Sans,system-ui,sans-serif}.mfc-unit-toggles{display:flex;gap:8px;flex-shrink:0}.mfc-unit-group{display:inline-flex;border:1px solid #E2E8F0;border-radius:4px;overflow:hidden}.mfc-unit-btn{padding:3px 10px;font-size:11px;font-weight:600;border:none;background:#F8FAFC;color:#94a3b8;cursor:pointer;transition:all .12s;font-family:IBM Plex Sans,system-ui,sans-serif}.mfc-unit-btn:not(:last-child){border-right:1px solid #E2E8F0}.mfc-unit-btn.active{background:#475569;color:#fff}.mfc-unit-btn:hover:not(.active){background:#F1F5F9}.mfc-meta{display:flex;align-items:center;gap:12px;margin-top:4px;font-size:11px;color:#94a3b8;font-family:IBM Plex Sans,system-ui,sans-serif}.mfc-days-badge{background:#E2E8F0;color:#475569;padding:2px 8px;border-radius:4px;font-weight:600;font-size:10px;font-family:IBM Plex Sans,system-ui,sans-serif}.mfc-update-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;font-size:11px;font-weight:600;color:#475569;font-family:IBM Plex Sans,system-ui,sans-serif;background:#fff;border:1px solid #E2E8F0;border-radius:8px;cursor:pointer;transition:all .15s;margin-left:auto}.mfc-update-btn:hover{background:#F1F5F9;border-color:#0c4a6e;color:#0c4a6e}.mfc-update-btn.loading{opacity:.6;pointer-events:none}.mfc-update-btn.loading svg{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.mfc-progress{display:flex;align-items:center;gap:10px;padding:8px 20px;background:#f0f4f8;border-bottom:1px solid #e2e8f0}.mfc-progress-bar{flex:1;height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden;max-width:200px}.mfc-progress-fill{height:100%;width:0%;background:linear-gradient(90deg,#1e3a5c,#3b82f6);border-radius:3px;transition:width .6s ease}.mfc-progress-text{font-size:11px;font-weight:500;color:#1e3a5c;white-space:nowrap}.mfc-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.mfc-table{border-collapse:collapse;table-layout:fixed;font-size:12px;min-width:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}.mfc-table th,.mfc-table td{padding:3px 4px;text-align:center;white-space:nowrap;min-width:46px;border-right:1px solid #edf2f7}.mfc-footer{display:flex;align-items:center;gap:12px;padding:8px 16px;font-size:11px;color:#94a3b8;border-top:1px solid #E2E8F0;font-family:IBM Plex Sans,system-ui,sans-serif}.mfc-label-cell{position:sticky;left:0;background:#fff;z-index:3;text-align:right!important;padding-right:10px!important;font-weight:600;color:#475569;width:110px;min-width:110px!important;max-width:110px;font-size:11px;border-right:2px solid #E2E8F0!important;font-family:IBM Plex Sans,system-ui,sans-serif;overflow:hidden;text-overflow:ellipsis}.mfc-day-header th,.mfc-day-header td{background:#F1F5F9;color:#0f172a;font-weight:700;font-size:13px;padding:8px 0;border-bottom:1px solid #E2E8F0;border-right:1px solid #E2E8F0;font-family:IBM Plex Sans,system-ui,sans-serif}.mfc-day-header .mfc-label-cell{background:#F1F5F9;color:#0f172a;border-right-color:#cbd5e1!important}.mfc-day-th{border-left:2px solid #CBD5E1}.mfc-day-header-repeat td,.mfc-day-header-repeat th{border-top:2px solid #E2E8F0}.mfc-time-header th,.mfc-time-header td{background:#F8FAFC;color:#475569;font-weight:500;font-size:10px;padding:5px 2px;border-bottom:1px solid #E2E8F0;border-right:1px solid #E2E8F0}.mfc-time-header .mfc-label-cell{background:#F8FAFC;color:#475569;border-right-color:#cbd5e1!important}.mfc-day-border{border-left:2px solid #CBD5E1!important}.mfc-section-row td{background:#F8FAFC;border-top:1px solid #E2E8F0;border-bottom:1px solid #E2E8F0;padding:6px 4px}.mfc-section-label{font-weight:700!important;font-size:12px!important;color:#0f172a!important;background:#F8FAFC!important;text-transform:uppercase;letter-spacing:.5px;text-align:left!important;font-family:IBM Plex Sans,system-ui,sans-serif!important}.mfc-section-summary{text-align:center;font-size:12px;color:#0f172a;font-weight:500;font-family:IBM Plex Sans,system-ui,sans-serif;letter-spacing:.2px;line-height:1.5;vertical-align:middle}.mfc-bar-cell{vertical-align:bottom;padding:2px 1px 0!important}.mfc-bar-wrap{position:relative;width:100%;display:flex;justify-content:center}.mfc-wind-gust-bar{width:70%;left:15%;background:#D6DEE8;border-radius:2px;border:.5px solid #B0BEC5;position:absolute;bottom:0}.mfc-wind-avg-bar{width:70%;left:15%;background:#6B7F95;border-radius:2px;border:.5px solid #546E7A;position:absolute;bottom:0}.mfc-wave-peak-bar{width:70%;left:15%;background:#BAE6FD;border-radius:2px;border:.5px solid #7DD3FC;position:absolute;bottom:0}.mfc-wave-avg-bar{width:70%;left:15%;background:#0EA5E9;border-radius:2px;border:.5px solid #0284C7;position:absolute;bottom:0}.mfc-wave-bars td{border-top:1px solid #e2e8f0}.mfc-bar-cell[data-tip]{position:relative;cursor:default}.mfc-bar-cell[data-tip]:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);white-space:nowrap;background:#0F172A;color:#e2e8f0;font-size:11px;font-weight:500;font-family:IBM Plex Sans,system-ui,sans-serif;padding:5px 10px;border-radius:6px;box-shadow:0 4px 12px #0000004d;z-index:100;pointer-events:none;opacity:0;transition:opacity .08s ease}.mfc-bar-cell[data-tip]:hover:after{opacity:1}.mfc-val{font-weight:400;font-size:12px;padding:3px 2px;color:#334155;font-family:IBM Plex Mono,monospace;font-variant-numeric:tabular-nums}.mfc-gust-val{font-weight:500;color:#334155!important}.mfc-pressure-val{font-size:10px;font-weight:400}.mfc-dir-row td{padding:4px 2px!important;line-height:1.2}.mfc-dir-cell svg{opacity:.75;display:inline-block;vertical-align:middle}.mfc-dir-text{display:block;font-size:9px;font-weight:600;color:#5b6c7d;margin-top:1px}.mfc-icon-cell{padding:4px 2px!important}.mfc-wx-icon{width:22px;height:22px}.mfc-trend-cell{font-size:10px;padding:2px!important}.mfc-trend-arrow{display:inline-block;vertical-align:middle}.mfc-trend-up{color:#27ae60;font-size:14px}.mfc-trend-down{color:#c0392b;font-size:14px}.mfc-trend-flat{color:#95a5a6;font-size:12px}.mfc-table tbody tr:nth-child(2n):not(.mfc-section-row):not(.mfc-bars-row):not(.mfc-day-header):not(.mfc-time-header):not(.mfc-day-header-repeat) td:not(.mfc-label-cell){background:#fafbfc}.bw2-card{margin-top:20px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:20px 24px;box-shadow:0 2px 8px #0000000a}.bw2-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:4px}.bw2-title{font-size:15px;font-weight:700;color:#1e293b}.bw2-controls{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.bw2-meta{font-size:11px;color:#94a3b8;margin-bottom:16px;display:flex;gap:12px;align-items:center}.bw2-charts{display:flex;flex-direction:column;gap:12px}.bw2-chart-wrap{background:#f8fafc;border:1px solid #f0f4f8;border-radius:10px;padding:14px 16px}.bw2-chart-label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}.bwv{overflow:hidden}.bwv-label{font-weight:700;text-transform:uppercase;letter-spacing:1px}.bwv1{background:var(--bg-card);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);border-radius:var(--radius-lg);padding:0}.bwv1:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);transition:var(--transition)}.bwv1 .bwv-label{padding:12px 24px;font-size:13px;color:var(--text-muted);background:var(--bg-card);border-bottom:1px solid var(--border-light);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.bwv1 .mfc-header{background:var(--bg-card);border-bottom:1px solid var(--border-light);padding:16px 24px 12px!important}.bwv1 .mfc-title{color:var(--text)!important;font-size:18px!important;font-weight:700!important}.bwv1 .mfc-meta{color:var(--text-muted)!important}.bwv1 .mfc-days-badge{background:var(--primary)!important}.bwv1 .mfc-day-header th,.bwv1 .mfc-day-header td{background:var(--primary)!important;font-size:13px!important;padding:10px 0!important}.bwv1 .mfc-time-header th,.bwv1 .mfc-time-header td{background:var(--primary-hover)!important;font-size:10px!important}.bwv1 .mfc-section-label{color:var(--text)!important;font-size:13px!important;font-weight:700!important;text-transform:uppercase!important;letter-spacing:.5px!important}.bwv1 .mfc-section-row td{background:var(--primary-ultra-light)!important;font-size:11px!important;color:var(--text-muted)!important}.bwv1 .mfc-wind-avg-bar{background:var(--primary)!important}.bwv1 .mfc-wind-gust-bar{background:#B4D0F7!important}.bwv1 .mfc-wave-avg-bar{background:#34A853!important}.bwv1 .mfc-wave-peak-bar{background:#93D4A4!important}.bwv1 .mfc-val{font-size:12px!important;color:var(--text)!important}.bwv1 .mfc-gust-val{color:var(--text-muted)!important}.bwv1 .mfc-unit-btn.active{background:var(--primary)!important}.bwv1 .mfc-unit-btn{border-color:var(--border-light)!important}.bwv1 .mfc-label-cell{background:var(--bg-card)!important;color:var(--text-muted)!important;font-size:11px!important;font-weight:500!important}.bwv1 .mfc-table th,.bwv1 .mfc-table td{padding:3px 4px!important;min-width:46px!important;border-right-color:var(--border-light)!important}.bwv1 .mfc-day-border{border-left-color:var(--border-light)!important}.bwv2{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 50%,#f0f9ff 100%);border:1px solid #bae6fd;border-radius:20px;box-shadow:0 4px 24px #0e74901a}.bwv2 .bwv-label{padding:14px 24px;font-size:12px;color:#0e7490;background:rgba(14,116,144,.04);border-bottom:1px solid #bae6fd;letter-spacing:2px}.bwv2 .mfc-header{background:rgba(255,255,255,.6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #bae6fd;padding:18px 24px 14px!important}.bwv2 .mfc-title{color:#0e7490!important;font-size:17px!important;font-weight:600!important}.bwv2 .mfc-days-badge{background:#0e7490!important;font-size:11px!important;padding:4px 14px!important;border-radius:14px!important}.bwv2 .mfc-day-header th,.bwv2 .mfc-day-header td{background:#0e7490!important;font-size:14px!important;padding:12px 0!important}.bwv2 .mfc-time-header th,.bwv2 .mfc-time-header td{background:#0c6478!important;font-size:11px!important;padding:7px 2px!important}.bwv2 .mfc-section-label{color:#0e7490!important;font-size:14px!important;letter-spacing:1px!important}.bwv2 .mfc-wind-avg-bar{background:#0891b2!important}.bwv2 .mfc-wind-gust-bar{background:#67e8f9!important}.bwv2 .mfc-wave-avg-bar{background:#0284c7!important}.bwv2 .mfc-wave-peak-bar{background:#7dd3fc!important}.bwv2 .mfc-val{color:#0c4a6e!important;font-size:14px!important;font-weight:800!important}.bwv2 .mfc-gust-val{font-size:12px!important;font-weight:500!important}.bwv2 .mfc-unit-btn.active{background:#0e7490!important}.bwv2 .mfc-label-cell{background:#f0f9ff!important;min-width:130px!important;font-size:12px!important}.bwv2 .mfc-table th,.bwv2 .mfc-table td{padding:5px 6px!important;min-width:54px!important}.bwv2 .mfc-dir-text{font-size:10px!important}.bwv2 .mfc-section-row td{padding:6px 4px!important}.bwv3{background:#fafafa;border:1px solid #d4d4d4;border-radius:6px}.bwv3 .bwv-label{padding:6px 12px;font-size:9px;color:#525252;background:#f5f5f5;border-bottom:1px solid #d4d4d4;letter-spacing:2px}.bwv3 .mfc-header{background:#fafafa;border-bottom:1px solid #d4d4d4;padding:8px 12px 6px!important}.bwv3 .mfc-title{color:#171717!important;font-weight:900!important;font-size:12px!important;letter-spacing:-.3px!important}.bwv3 .mfc-meta{font-size:9px!important}.bwv3 .mfc-days-badge{background:#404040!important;font-size:9px!important;padding:1px 6px!important}.bwv3 .mfc-day-header th,.bwv3 .mfc-day-header td{background:#262626!important;font-size:10px!important;padding:5px 0!important}.bwv3 .mfc-time-header th,.bwv3 .mfc-time-header td{background:#404040!important;font-size:8px!important;padding:3px 1px!important}.bwv3 .mfc-section-label{color:#171717!important;font-size:9px!important;font-weight:900!important}.bwv3 .mfc-wind-avg-bar{background:#404040!important}.bwv3 .mfc-wind-gust-bar{background:#a3a3a3!important}.bwv3 .mfc-wave-avg-bar{background:#525252!important}.bwv3 .mfc-wave-peak-bar{background:#d4d4d4!important}.bwv3 .mfc-val{color:#262626!important;font-size:10px!important;font-weight:700!important}.bwv3 .mfc-gust-val{font-size:9px!important}.bwv3 .mfc-unit-btn{font-size:9px!important;padding:2px 6px!important}.bwv3 .mfc-unit-btn.active{background:#262626!important}.bwv3 .mfc-label-cell{background:#fafafa!important;min-width:80px!important;max-width:80px!important;font-size:9px!important;padding-right:6px!important}.bwv3 .mfc-table th,.bwv3 .mfc-table td{padding:2px!important;min-width:34px!important;font-size:10px}.bwv3 .mfc-dir-text{font-size:7px!important}.bwv3 .mfc-section-row td{padding:3px 2px!important;font-size:9px!important}.bwv3 .mfc-icon-cell{padding:2px 1px!important}.bwv3 .mfc-wx-icon{width:16px!important;height:16px!important}.bwv3 .mfc-trend-arrow{width:6px!important;height:9px!important}.bwv4{background:#faf8f5;border:1px solid #d6cfc5;border-radius:12px;box-shadow:0 2px 12px #8b5a2b0f}.bwv4 .bwv-label{padding:12px 20px;font-size:10px;color:#92400e;background:#fef7ed;border-bottom:1px solid #e8ddd0;font-family:Georgia,Times New Roman,serif;letter-spacing:3px}.bwv4 .mfc-header{background:#faf8f5;border-bottom:1px solid #e8ddd0}.bwv4 .mfc-title{color:#78350f!important;font-size:16px!important;font-family:Georgia,serif!important;font-weight:700!important;font-style:italic!important}.bwv4 .mfc-days-badge{background:#b45309!important;font-size:10px!important}.bwv4 .mfc-day-header th,.bwv4 .mfc-day-header td{background:#92400e!important;font-size:13px!important;padding:10px 0!important;font-family:Georgia,serif!important;letter-spacing:.5px!important}.bwv4 .mfc-time-header th,.bwv4 .mfc-time-header td{background:#78350f!important;font-size:10px!important}.bwv4 .mfc-section-label{color:#92400e!important;font-size:13px!important;font-family:Georgia,serif!important;font-style:italic!important}.bwv4 .mfc-wind-avg-bar{background:#b45309!important}.bwv4 .mfc-wind-gust-bar{background:#fbbf24!important}.bwv4 .mfc-wave-avg-bar{background:#c2410c!important}.bwv4 .mfc-wave-peak-bar{background:#fb923c!important}.bwv4 .mfc-val{color:#78350f!important;font-size:13px!important;font-weight:600!important}.bwv4 .mfc-gust-val{font-size:11px!important;color:#a3724e!important}.bwv4 .mfc-unit-btn.active{background:#b45309!important}.bwv4 .mfc-label-cell{background:#faf8f5!important;font-size:11px!important;font-family:Georgia,serif!important}.bwv4 .mfc-table th,.bwv4 .mfc-table td{padding:4px 5px!important;min-width:48px!important}.bwv4 .mfc-section-row td{background:#fef7ed!important;font-family:Georgia,serif!important;font-style:italic}.bwv5{background:#fff;border:3px solid #7c3aed;border-radius:24px;box-shadow:8px 8px #ede9fe}.bwv5 .bwv-label{padding:14px 24px;font-size:13px;color:#7c3aed;background:#faf5ff;border-bottom:3px solid #ede9fe;letter-spacing:3px}.bwv5 .mfc-header{background:#fff;border-bottom:3px solid #ede9fe;padding:20px 28px 14px!important}.bwv5 .mfc-title{color:#5b21b6!important;font-size:20px!important;font-weight:900!important;letter-spacing:-.5px!important}.bwv5 .mfc-meta{font-size:12px!important}.bwv5 .mfc-days-badge{background:#7c3aed!important;font-size:12px!important;padding:4px 16px!important;border-radius:14px!important}.bwv5 .mfc-day-header th,.bwv5 .mfc-day-header td{background:#7c3aed!important;font-size:16px!important;padding:14px 0!important;font-weight:800!important}.bwv5 .mfc-time-header th,.bwv5 .mfc-time-header td{background:#6d28d9!important;font-size:12px!important;padding:8px 2px!important}.bwv5 .mfc-section-label{color:#7c3aed!important;font-size:16px!important;font-weight:900!important;letter-spacing:2px!important}.bwv5 .mfc-wind-avg-bar{background:#7c3aed!important}.bwv5 .mfc-wind-gust-bar{background:#c4b5fd!important}.bwv5 .mfc-wave-avg-bar{background:#8b5cf6!important}.bwv5 .mfc-wave-peak-bar{background:#ddd6fe!important}.bwv5 .mfc-val{color:#4c1d95!important;font-size:15px!important;font-weight:800!important}.bwv5 .mfc-gust-val{font-size:13px!important}.bwv5 .mfc-unit-btn{font-size:12px!important;padding:5px 14px!important}.bwv5 .mfc-unit-btn.active{background:#7c3aed!important}.bwv5 .mfc-label-cell{background:#faf5ff!important;min-width:140px!important;font-size:13px!important;font-weight:700!important}.bwv5 .mfc-table th,.bwv5 .mfc-table td{padding:5px 7px!important;min-width:56px!important}.bwv5 .mfc-section-row td{background:#faf5ff!important;padding:8px 4px!important}.bwv5 .mfc-icon-cell{padding:6px 3px!important}.bwv5 .mfc-wx-icon{width:28px!important;height:28px!important}.bwv5 .mfc-dir-text{font-size:11px!important}.sea-charts-section{margin-top:28px;padding-top:24px;border-top:2px solid #e2e8f0}.sea-charts-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:20px}.sea-charts-header h3{font-size:18px;font-weight:700;color:#1e293b;margin:0}.sea-charts-sub{font-size:12px;color:#94a3b8}.sea-chart-card{background:#fff;border:1px solid #e8ecf0;border-radius:12px;padding:20px 24px;margin-bottom:16px;box-shadow:0 1px 3px #0000000a;transition:box-shadow .2s}.sea-chart-card:hover{box-shadow:0 4px 12px #00000014}.sea-chart-title{font-size:14px;font-weight:700;color:#1e293b;margin-bottom:2px}.sea-chart-desc{font-size:11px;color:#94a3b8;margin-bottom:14px}.sea-calendar{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.sea-cal-day{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px;text-align:center;transition:transform .15s,box-shadow .15s}.sea-cal-day:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.sea-cal-date{font-size:11px;font-weight:700;color:#475569;margin-bottom:4px}.sea-cal-icon{font-size:20px;margin:4px 0}.sea-cal-temp{font-size:13px;font-weight:700;color:#1e293b}.sea-cal-detail{font-size:10px;color:#64748b;line-height:1.5;margin-top:4px}.sea-cal-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:9px;font-weight:700;margin-top:4px}.weather-sticky-header{position:sticky;top:0;z-index:20;background:#fff;border-bottom:1px solid #E2E8F0;margin:-16px -16px 12px;padding:12px 16px 8px}.weather-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.weather-location{font-size:24px;font-weight:700;color:#0f172a;letter-spacing:-.3px;font-family:IBM Plex Sans,system-ui,sans-serif}.weather-location-sub{font-size:12px;color:#94a3b8;margin-top:2px;font-family:IBM Plex Sans,system-ui,sans-serif}.weather-tabs{display:inline-flex;gap:4px;background:var(--bg, #fff);border-radius:6px;padding:3px;border:1px solid #E2E8F0}.weather-tab{padding:8px 20px;border:none;border-radius:4px;background:transparent;color:#475569;font-size:14px;font-weight:600;font-family:IBM Plex Sans,system-ui,sans-serif;cursor:pointer;transition:all .15s;white-space:nowrap}.weather-tab:hover{color:#0c4a6e;background:#E0F2FE}.weather-tab.active{background:#0F172A;color:#fff;box-shadow:0 1px 3px #0f172a33}.buoy-scale-tabs .weather-tab{padding:6px 14px;font-size:12px;font-weight:500;color:#94a3b8}.buoy-scale-tabs .weather-tab:hover{color:#0c4a6e;background:#E0F2FE}.buoy-scale-tabs .weather-tab.active{background:#E0F2FE;color:#0c4a6e;font-weight:600;box-shadow:none}.weather-content{display:block}.forecast-table{width:100%;border-collapse:collapse;font-size:12px;font-family:IBM Plex Sans,system-ui,sans-serif;background:white;border:1px solid #E2E8F0;border-radius:12px}.forecast-table th{background:#F8FAFC;padding:8px 4px;font-weight:600;color:#0f172a;border-bottom:1px solid #E2E8F0;font-size:11px}.forecast-table td{padding:12px 4px;text-align:center;border-bottom:1px solid #F1F5F9;vertical-align:middle;font-family:IBM Plex Mono,monospace;font-variant-numeric:tabular-nums}.forecast-table .label-cell{background:#F8FAFC;font-weight:600;font-family:IBM Plex Sans,system-ui,sans-serif;text-align:left;padding-left:12px;border-right:2px solid #E2E8F0;white-space:nowrap;color:#475569}.forecast-table tr:last-child td{border-bottom:none}.update-btn{display:flex;align-items:center;gap:6px;padding:8px 20px;border-radius:8px;border:1px solid #E2E8F0;background:#fff;color:#475569;font-family:IBM Plex Sans,system-ui,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.update-btn:hover{border-color:#0c4a6e;color:#0c4a6e;background:#E0F2FE}.update-btn.loading svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.location-toggle{display:flex;gap:4px;background:var(--bg);border-radius:var(--radius);padding:4px;display:inline-flex;border:1px solid var(--border-light);margin-bottom:24px}.location-btn{padding:10px 24px;border:none;background:none;border-radius:var(--radius-sm);font-family:inherit;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition)}.location-btn.active{background:var(--primary);color:#fff;box-shadow:0 2px 6px #4285f433}.location-btn:hover:not(.active){color:var(--primary)}.tide-table{width:100%;background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.tide-table table{width:100%;border-collapse:collapse}.tide-table th{text-align:left;padding:14px 24px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);background:var(--primary-ultra-light);border-bottom:1px solid var(--border-light)}.tide-table td{padding:14px 24px;font-size:14px;color:var(--text);border-bottom:1px solid var(--border-light)}.tide-table tr:last-child td{border-bottom:none}.tide-table tr:hover td{background:var(--primary-ultra-light)}.tide-type{display:inline-block;padding:3px 10px;border-radius:12px;font-size:12px;font-weight:600}.tide-type.high{background:#E3F2FD;color:#1565c0}.tide-type.low{background:#FFF8E1;color:#f57f17}.loading-indicator{display:flex;align-items:center;gap:12px;padding:16px 20px;margin-bottom:16px;background:var(--primary-ultra-light);border-radius:var(--radius);border:1px solid var(--primary-light);color:var(--primary);font-size:14px;font-weight:500;animation:fadeIn .2s ease}.spinner{width:20px;height:20px;border:2.5px solid var(--primary-light);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@media (max-width: 768px){.top-nav{padding:0 12px;height:56px}.nav-left,.nav-right{min-width:auto}.app-logo{width:28px;height:28px}.app-title{font-size:15px}.nav-tab span{display:none}.nav-tab{padding:10px 14px}.main-content{padding:16px}.slide-panel{width:100vw}.timesheet-title{font-size:18px}.dashboard-grid{grid-template-columns:1fr}.entries-table th{padding:10px;font-size:11px;letter-spacing:.3px}.entries-table td{padding:10px;font-size:13px}.gap-row td{padding:6px 10px;font-size:12px}.entry-tag{padding:3px 8px;font-size:11px}.entry-actions{opacity:1}.entry-action-btn{padding:4px 6px}.control-section{margin-bottom:16px}.date-btn,.add-btn{padding:8px 16px;font-size:13px}.vessel-select{padding:10px 14px;font-size:14px}.progress-bar-label{font-size:12px;min-width:80px}}@media (max-width: 480px){body{overflow-x:hidden}.top-nav{padding:0 10px;height:52px}.nav-left{gap:6px;flex-shrink:1;min-width:0}.nav-right{flex-shrink:0}.app-logo{width:26px;height:26px}.app-title{font-size:15px}.nav-tabs{gap:0}.nav-tab{padding:10px}.nav-tab svg{width:22px;height:22px}.nav-tab.active:after{bottom:-10px;width:30px;height:3px}.user-avatar{width:34px;height:34px;font-size:13px}.main-content{padding:8px 12px;overflow-x:hidden}.control-label{display:none}.control-section{margin-bottom:6px}.vessel-select{padding:10px 14px;font-size:15px;border-radius:8px}.date-buttons{gap:6px}.date-btn{padding:8px 16px;font-size:14px;border-width:1px;border-radius:20px}.timesheet-header{margin-bottom:6px}.timesheet-title{font-size:18px;letter-spacing:-.3px}.add-btn{padding:8px 16px;font-size:14px;gap:6px;border-radius:8px}.add-btn svg{width:16px;height:16px}.progress-bar-container{gap:6px;margin-bottom:6px}.progress-bar-track{height:8px}.progress-bar-label{font-size:12px;min-width:80px}.progress-expand-btn{width:24px;height:24px}.progress-expand-btn svg{width:12px;height:12px}.slide-panel{width:100vw}.entries-table th:nth-child(5),.entries-table td:nth-child(5){display:none}.entries-table{overflow-x:hidden;border-radius:10px}.entries-table table{table-layout:fixed;width:100%}.entries-table th:nth-child(1),.entries-table td:nth-child(1){width:28%}.entries-table th:nth-child(2),.entries-table td:nth-child(2){width:14%}.entries-table th:nth-child(3),.entries-table td:nth-child(3){width:34%}.entries-table th:nth-child(4),.entries-table td:nth-child(4){width:24%}.entries-table th{padding:10px 4px 10px 8px;font-size:12px;letter-spacing:.3px}.entries-table td{padding:14px 4px 14px 8px;font-size:14px}.entries-table th:first-child,.entries-table td:first-child{padding-left:10px}.entries-table td:nth-child(3){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gap-row td{padding:6px;font-size:12px}.entry-tag{padding:4px 8px;font-size:11px;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:inline-block}.entry-form{padding:18px}.form-group{margin-bottom:16px}.panel-header{padding:16px 18px}.empty-state{padding:40px 16px}.admin-tabs{flex-wrap:wrap;gap:6px}.admin-tab{padding:8px 16px;font-size:.85rem}}.admin-container{max-width:600px}.admin-title{font-size:1.4rem;font-weight:700;margin-bottom:20px;color:var(--text-primary)}.admin-tabs{display:flex;gap:8px;margin-bottom:20px}.admin-tab{padding:8px 20px;border:1px solid var(--border);border-radius:20px;background:white;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-secondary);transition:all .2s}.admin-tab:hover{border-color:var(--primary);color:var(--primary)}.admin-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.admin-add-row{display:flex;gap:10px;margin-bottom:20px}.admin-add-row input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}.admin-add-row input:focus{border-color:var(--primary)}.admin-list{display:flex;flex-direction:column;gap:6px}.admin-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:white;border:1px solid var(--border);border-radius:10px;transition:box-shadow .2s,border-color .2s}.admin-item:hover{border-color:var(--primary-light);box-shadow:0 2px 8px #4285f414}.admin-item-text{font-size:.95rem;font-weight:500;color:var(--text-primary)}.admin-item-actions{display:flex;gap:6px}.admin-action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;border-radius:6px;color:var(--text-muted);transition:all .2s}.admin-action-btn:hover{background:var(--bg-muted)}.admin-action-btn.edit:hover{color:var(--primary)}.admin-action-btn.delete:hover{color:#e53e3e}.admin-empty{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:.95rem}.admin-add-user{display:flex;gap:10px;margin-bottom:20px;align-items:center}.admin-input{flex:2;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}.admin-input:focus{border-color:var(--primary)}.admin-select{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-family:inherit;outline:none;background:white;cursor:pointer}.user-item{align-items:flex-start}.user-info{display:flex;flex-direction:column;gap:4px}.user-main{display:flex;align-items:center;gap:8px}.user-name{font-weight:600;color:var(--text-primary)}.user-email{font-size:.85rem;color:var(--text-muted)}.user-role-badge{font-size:.75rem;padding:2px 8px;border-radius:12px;font-weight:500;background:#edf2f7;color:#4a5568}.user-role-badge.admin{background:#fed7d7;color:#c53030}.user-role-badge.dispatcher{background:#feebc8;color:#c05621}.user-role-badge.vessel{background:#c6f6d5;color:#2f855a}@media (max-width: 600px){.admin-add-user{flex-wrap:wrap;flex-direction:column;align-items:stretch}}.btn-warning{background:#ed8936;border-color:#ed8936}.btn-warning:hover{background:#dd6b20}.admin-add-user button{white-space:nowrap}.user-menu-wrapper{position:relative}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:260px;background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border-light);opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s ease;z-index:300;overflow:hidden}.user-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.user-dropdown-profile{display:flex;align-items:center;gap:12px;padding:16px}.user-dropdown-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),#7B61FF);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.user-dropdown-info{display:flex;flex-direction:column;gap:2px;min-width:0}.user-dropdown-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-email{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-dropdown-divider{height:1px;background:var(--border-light)}.user-dropdown-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:10px 16px 4px}.user-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;border:none;background:none;cursor:pointer;font-family:inherit;font-size:13px;color:var(--text);transition:background var(--transition);text-align:left}.user-dropdown-item:hover{background:var(--primary-ultra-light)}.user-dropdown-item-avatar{width:28px;height:28px;border-radius:50%;background:var(--border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.user-dropdown-item-role{margin-left:auto;font-size:11px;color:var(--text-muted)}.user-dropdown-logout{color:var(--danger);padding:12px 16px}.user-dropdown-logout:hover{background:#ffeaea}.tide-info-card{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.tide-info-loading{text-align:center;padding:20px;color:var(--text-muted);font-size:14px}.tide-info-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--border-light)}.tide-info-header h4{display:flex;align-items:center;gap:6px}.tide-info-list{display:flex;flex-direction:column;gap:0}.tide-entry{cursor:default;transition:all .15s ease}.tide-entry:hover{transform:translate(4px);box-shadow:0 2px 6px #0000000f}.tide-entry:last-child{margin-bottom:0!important}.ms-root{display:flex;flex-direction:column;height:calc(100vh - 64px);width:100%;background:#101922;color:#e2e8f0;font-family:Inter,system-ui,sans-serif;overflow:hidden;position:relative}.ms-loading{position:absolute;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:rgba(16,25,34,.95);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:opacity .5s}.ms-loading.hidden{opacity:0;pointer-events:none}.ms-loading-inner{text-align:center}.ms-loading-text{color:#94a3b8;margin-top:12px;font-size:13px}.ms-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#137fec;border-radius:50%;animation:msSpin .8s linear infinite;margin:0 auto}@keyframes msSpin{to{transform:rotate(360deg)}}.ms-header{display:flex;align-items:center;justify-content:space-between;height:56px;min-height:56px;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.08);background:#101922;z-index:20}.ms-header-left{display:flex;align-items:center;gap:32px}.ms-logo{display:flex;align-items:center;gap:10px;color:#137fec}.ms-logo-icon{font-size:28px}.ms-logo-text{font-size:16px;font-weight:700;color:#f1f5f9;letter-spacing:-.3px}.ms-nav{display:flex;align-items:center;gap:24px}.ms-nav-link{font-size:13px;font-weight:500;color:#64748b;cursor:pointer;padding-bottom:2px;border-bottom:2px solid transparent;transition:all .15s;text-decoration:none}.ms-nav-link:hover{color:#137fec}.ms-nav-link.active{color:#137fec;font-weight:600;border-bottom-color:#137fec}.ms-header-right{display:flex;align-items:center;gap:16px}.ms-search-wrap{position:relative}.ms-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#64748b;font-size:20px}.ms-search{width:240px;padding:8px 12px 8px 36px;border:none;border-radius:8px;background:rgba(255,255,255,.06);color:#e2e8f0;font-size:13px;outline:none;transition:all .2s}.ms-search::placeholder{color:#475569}.ms-search:focus{background:rgba(255,255,255,.1);box-shadow:0 0 0 2px #137fec4d}.ms-header-count{font-size:11px;color:#64748b;white-space:nowrap}.ms-main{display:flex;flex:1;overflow:hidden}.ms-sidebar{width:220px;min-width:220px;display:flex;flex-direction:column;border-right:1px solid rgba(255,255,255,.08);background:#0d1520;overflow:hidden}.ms-sidebar-section{padding:16px}.ms-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#475569;margin-bottom:12px}.ms-sidebar-btn{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;border-radius:8px;background:transparent;color:#94a3b8;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;text-align:left}.ms-sidebar-btn:hover{background:rgba(255,255,255,.04)}.ms-sidebar-btn-active{background:rgba(19,127,236,.1);color:#137fec}.ms-sidebar-btn .material-symbols-outlined{font-size:20px}.ms-badge{margin-left:auto;padding:2px 8px;border-radius:10px;background:#137fec;color:#fff;font-size:10px;font-weight:700}.ms-sidebar-divider{height:1px;background:rgba(255,255,255,.06);margin:0 16px}.ms-filter-tabs{display:flex;gap:4px}.ms-filter-tab{flex:1;padding:6px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:transparent;color:#64748b;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}.ms-filter-tab:hover{background:rgba(255,255,255,.04)}.ms-filter-tab.active{background:rgba(19,127,236,.15);border-color:#137fec4d;color:#93c5fd}.ms-filter-tab[data-source=mt].active{background:rgba(59,130,246,.15);border-color:#3b82f64d;color:#93c5fd}.ms-filter-tab[data-source=vf].active{background:rgba(16,185,129,.15);border-color:#10b9814d;color:#6ee7b7}.ms-vessel-list{flex:1;overflow-y:auto;padding:4px 8px}.ms-vessel-list::-webkit-scrollbar{width:4px}.ms-vessel-list::-webkit-scrollbar-thumb{background:#1e293b;border-radius:4px}.ms-vessel-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:all .15s;margin:1px 0}.ms-vessel-item:hover{background:rgba(255,255,255,.04)}.ms-vessel-item.selected{background:rgba(19,127,236,.12)}.ms-vessel-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.ms-vessel-status-dot.moving{background:#22c55e;box-shadow:0 0 6px #22c55e80}.ms-vessel-status-dot.anchor{background:#eab308}.ms-vessel-status-dot.idle{background:#64748b}.ms-vessel-info{flex:1;min-width:0}.ms-vessel-name{font-size:13px;font-weight:600;color:#f1f5f9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ms-vessel-meta{font-size:11px;color:#475569;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ms-vessel-sources{display:flex;gap:3px;flex-shrink:0}.ms-src-tag{width:18px;height:18px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff}.ms-src-tag.mt{background:#3B82F6}.ms-src-tag.vf{background:#10B981}.ms-status-box{margin:auto 12px 12px;padding:12px;border-radius:10px;background:rgba(19,127,236,.05);border:1px solid rgba(19,127,236,.1)}.ms-status-header{display:flex;align-items:center;gap:6px;color:#137fec;margin-bottom:6px}.ms-status-icon{font-size:16px}.ms-status-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px}.ms-status-text{font-size:11px;color:#475569;line-height:1.4}.ms-status-indicator{display:flex;align-items:center;gap:6px;margin-top:8px}.ms-status-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:msPulse 2s ease infinite}@keyframes msPulse{0%,to{opacity:1}50%{opacity:.4}}.ms-status-time{font-size:9px;font-weight:700;color:#475569;letter-spacing:.5px}.ms-map-section{flex:1;position:relative;overflow:hidden}.ms-map{position:absolute;top:0;right:0;bottom:0;left:0}.ms-style-bar{position:absolute;bottom:16px;left:50%;transform:translate(-50%);z-index:10;display:inline-flex;background:rgba(16,25,34,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;box-shadow:0 4px 20px #0000004d;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.ms-style-btn{font-size:12px;padding:6px 14px;border:none;background:transparent;color:#64748b;cursor:pointer;font-weight:500;transition:all .15s;border-right:1px solid rgba(255,255,255,.06)}.ms-style-btn:last-child{border-right:none}.ms-style-btn:hover{background:rgba(255,255,255,.05)}.ms-style-btn.active{background:#137fec;color:#fff}.ms-legend{position:absolute;top:16px;left:16px;z-index:10;padding:12px 16px;background:rgba(16,25,34,.9);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;border:1px solid rgba(255,255,255,.08);box-shadow:0 4px 16px #0000004d}.ms-legend-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.ms-legend-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:#64748b}.ms-pulse-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:msPulse 2s ease infinite}.ms-legend-items{display:flex;flex-direction:column;gap:4px}.ms-legend-item{display:flex;align-items:center;gap:8px;font-size:11px;color:#94a3b8;font-weight:500}.ms-legend-swatch{width:10px;height:10px;border-radius:3px}.ms-coords{position:absolute;bottom:16px;right:16px;z-index:10;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#94a3b8;padding:4px 12px;border-radius:8px;font-size:11px;pointer-events:none}.ms-detail{width:0;min-width:0;overflow:hidden;background:#0d1520;border-left:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;transition:width .3s ease,min-width .3s ease}.ms-detail.open{width:320px;min-width:320px}.ms-detail-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;background:#0d1520;z-index:2}.ms-detail-name{font-size:18px;font-weight:700;color:#f1f5f9}.ms-detail-sub{font-size:12px;color:#64748b;margin-top:2px}.ms-detail-close{background:none;border:none;color:#64748b;cursor:pointer;padding:4px;border-radius:6px;transition:all .15s}.ms-detail-close:hover{background:rgba(255,255,255,.06);color:#e2e8f0}.ms-detail-photo-wrap{overflow:hidden}.ms-detail-photo{width:100%;height:180px;object-fit:cover;display:none;background:#1e293b}.ms-detail-tabs{display:flex;padding:4px;margin:8px 12px;background:rgba(255,255,255,.04);border-radius:8px}.ms-detail-tab{flex:1;padding:6px 8px;border:none;border-radius:6px;background:transparent;color:#64748b;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:4px}.ms-detail-tab .material-symbols-outlined{font-size:16px}.ms-detail-tab.active{background:rgba(255,255,255,.08);color:#f1f5f9}.ms-detail-body{flex:1;overflow-y:auto;padding:12px 16px}.ms-detail-body::-webkit-scrollbar{width:4px}.ms-detail-body::-webkit-scrollbar-thumb{background:#1e293b;border-radius:4px}.ms-detail-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:8px;color:#475569;font-size:13px}.ms-detail-badges{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}.ms-badge-src{padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.ms-badge-src.mt{background:rgba(59,130,246,.2);color:#93c5fd}.ms-badge-src.vf{background:rgba(16,185,129,.2);color:#6ee7b7}.ms-badge-status{padding:3px 10px;border-radius:6px;font-size:10px;font-weight:700;background:rgba(234,179,8,.2);color:#fde68a}.ms-detail-section{margin-bottom:16px}.ms-detail-section-title{font-size:10px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;padding-bottom:4px;border-bottom:1px solid rgba(255,255,255,.06)}.ms-detail-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px;border-bottom:1px solid rgba(255,255,255,.03)}.ms-row-label{color:#475569}.ms-row-value{color:#e2e8f0;font-weight:500;text-align:right;max-width:60%}.ms-compare{width:100%;border-collapse:collapse;font-size:12px}.ms-compare th{font-size:10px;color:#475569;text-transform:uppercase;padding:4px 6px;text-align:center}.ms-compare td{padding:4px 6px;text-align:center;border-top:1px solid rgba(255,255,255,.04);color:#94a3b8}.ms-compare td:first-child{text-align:left;color:#475569;font-size:11px}.ms-compare .mt{color:#93c5fd}.ms-compare .vf{color:#6ee7b7}.ms-root .mapboxgl-popup-content{border-radius:10px!important;padding:0!important;box-shadow:0 8px 30px #0006!important;background:rgba(16,25,34,.95)!important}.ms-root .mapboxgl-popup-tip{border-top-color:#101922f2!important}.ms-theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:rgba(255,255,255,.06);color:#94a3b8;cursor:pointer;transition:all .15s;position:relative}.ms-theme-toggle:hover{background:rgba(255,255,255,.1);color:#e2e8f0}.ms-theme-icon-light,.ms-theme-icon-dark{font-size:20px;position:absolute;transition:opacity .2s,transform .2s}.ms-theme-icon-light{opacity:0;transform:rotate(-30deg)}.ms-theme-icon-dark{opacity:1;transform:rotate(0)}.ms-root.light .ms-theme-toggle{background:rgba(0,0,0,.06);color:#475569}.ms-root.light .ms-theme-toggle:hover{background:rgba(0,0,0,.1);color:#1e293b}.ms-root.light .ms-theme-icon-light{opacity:1;transform:rotate(0)}.ms-root.light .ms-theme-icon-dark{opacity:0;transform:rotate(30deg)}.ms-root.light{background:#f8fafc;color:#1e293b}.ms-root.light .ms-loading{background:rgba(248,250,252,.95)}.ms-root.light .ms-loading-text{color:#64748b}.ms-root.light .ms-spinner{border-color:#00000014;border-top-color:#0284c7}.ms-root.light .ms-header{background:#ffffff;border-bottom-color:#e2e8f0;box-shadow:0 1px 3px #0000000d}.ms-root.light .ms-logo{color:#0284c7}.ms-root.light .ms-logo-text{color:#0f172a}.ms-root.light .ms-nav-link{color:#64748b}.ms-root.light .ms-nav-link:hover{color:#0284c7}.ms-root.light .ms-nav-link.active{color:#0284c7;border-bottom-color:#0284c7}.ms-root.light .ms-search{background:#f1f5f9;color:#1e293b;border:1px solid #e2e8f0}.ms-root.light .ms-search::placeholder{color:#94a3b8}.ms-root.light .ms-search:focus{background:#fff;border-color:#0284c7;box-shadow:0 0 0 2px #0284c726}.ms-root.light .ms-search-icon{color:#94a3b8}.ms-root.light .ms-header-count{color:#64748b}.ms-root.light .ms-sidebar{background:#ffffff;border-right-color:#e2e8f0}.ms-root.light .ms-section-label{color:#94a3b8}.ms-root.light .ms-sidebar-btn{color:#64748b}.ms-root.light .ms-sidebar-btn:hover{background:rgba(0,0,0,.03)}.ms-root.light .ms-sidebar-btn-active{background:rgba(2,132,199,.08);color:#0284c7}.ms-root.light .ms-badge{background:#0284c7}.ms-root.light .ms-sidebar-divider{background:#e2e8f0}.ms-root.light .ms-filter-tab{border-color:#e2e8f0;color:#64748b}.ms-root.light .ms-filter-tab:hover{background:rgba(0,0,0,.02)}.ms-root.light .ms-filter-tab.active{background:rgba(2,132,199,.08);border-color:#0284c74d;color:#0284c7}.ms-root.light .ms-filter-tab[data-source=mt].active{background:rgba(59,130,246,.08);border-color:#3b82f64d;color:#2563eb}.ms-root.light .ms-filter-tab[data-source=vf].active{background:rgba(16,185,129,.08);border-color:#10b9814d;color:#059669}.ms-root.light .ms-vessel-list::-webkit-scrollbar-thumb{background:#cbd5e1}.ms-root.light .ms-vessel-item:hover{background:rgba(0,0,0,.03)}.ms-root.light .ms-vessel-item.selected{background:rgba(2,132,199,.08)}.ms-root.light .ms-vessel-name{color:#0f172a}.ms-root.light .ms-vessel-meta{color:#94a3b8}.ms-root.light .ms-status-box{background:rgba(2,132,199,.04);border-color:#0284c71f}.ms-root.light .ms-status-header{color:#0284c7}.ms-root.light .ms-status-text,.ms-root.light .ms-status-time{color:#64748b}.ms-root.light .ms-style-bar{background:rgba(255,255,255,.92);border-color:#e2e8f0;box-shadow:0 2px 12px #00000014}.ms-root.light .ms-style-btn{color:#64748b;border-right-color:#e2e8f0}.ms-root.light .ms-style-btn:hover{background:rgba(0,0,0,.04)}.ms-root.light .ms-style-btn.active{background:#0284c7;color:#fff}.ms-root.light .ms-legend{background:rgba(255,255,255,.92);border-color:#e2e8f0;box-shadow:0 2px 12px #00000014}.ms-root.light .ms-legend-title{color:#64748b}.ms-root.light .ms-legend-item{color:#475569}.ms-root.light .ms-coords{background:rgba(255,255,255,.8);color:#475569}.ms-root.light .ms-detail{background:#ffffff;border-left-color:#e2e8f0}.ms-root.light .ms-detail-header{background:#ffffff;border-bottom-color:#e2e8f0}.ms-root.light .ms-detail-name{color:#0f172a}.ms-root.light .ms-detail-sub{color:#64748b}.ms-root.light .ms-detail-close{color:#94a3b8}.ms-root.light .ms-detail-close:hover{background:rgba(0,0,0,.04);color:#1e293b}.ms-root.light .ms-detail-photo,.ms-root.light .ms-detail-tabs{background:#f1f5f9}.ms-root.light .ms-detail-tab{color:#64748b}.ms-root.light .ms-detail-tab.active{background:#fff;color:#0f172a;box-shadow:0 1px 3px #0000000f}.ms-root.light .ms-detail-body::-webkit-scrollbar-thumb{background:#cbd5e1}.ms-root.light .ms-detail-empty{color:#94a3b8}.ms-root.light .ms-badge-src.mt{background:rgba(59,130,246,.1);color:#2563eb}.ms-root.light .ms-badge-src.vf{background:rgba(16,185,129,.1);color:#059669}.ms-root.light .ms-badge-status{background:rgba(234,179,8,.1);color:#a16207}.ms-root.light .ms-detail-section-title{color:#94a3b8;border-bottom-color:#e2e8f0}.ms-root.light .ms-detail-row{border-bottom-color:#f1f5f9}.ms-root.light .ms-row-label{color:#64748b}.ms-root.light .ms-row-value{color:#1e293b}.ms-root.light .ms-compare th{color:#94a3b8}.ms-root.light .ms-compare td{border-top-color:#f1f5f9;color:#475569}.ms-root.light .ms-compare td:first-child{color:#64748b}.ms-root.light .ms-compare .mt{color:#2563eb}.ms-root.light .ms-compare .vf{color:#059669}.ms-root.light .mapboxgl-popup-content{background:rgba(255,255,255,.95)!important;box-shadow:0 4px 20px #0000001a!important}.ms-root.light .mapboxgl-popup-tip{border-top-color:#fffffff2!important}@media (max-width: 1024px){.ms-sidebar{display:none}.ms-detail.open{width:320px;min-width:320px}.ms-nav{display:none}}@media (max-width: 768px){.ms-detail.open{position:absolute;right:0;top:0;bottom:0;z-index:30;width:100%;min-width:100%}.ms-header{padding:0 12px}.ms-search{width:160px}}.wx-print-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid transparent;border-radius:6px;background:transparent;color:#cbd5e1;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;font-family:IBM Plex Sans,system-ui,sans-serif}.wx-print-btn:hover{background:#F1F5F9;border-color:#e2e8f0;color:#0c4a6e}.wx-print-btn:active{transform:translateY(1px)}.fav-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(500px,1fr));gap:16px;padding:8px 0}.fav-grid .rpt-card-body,.fav-grid .vd-chart-container{height:300px}.fav-grid .port-card canvas{height:300px}.fav-item{cursor:grab;transition:opacity .2s,transform .15s;height:420px;overflow:hidden}.fav-item>.vd-card,.fav-item>.port-card,.fav-item>.rpt-card{height:100%;display:flex;flex-direction:column}.fav-item>.vd-card>.vd-chart-container,.fav-item>.port-card>div:last-child,.fav-item>.rpt-card>.rpt-card-body{flex:1;min-height:0}.fav-item img[src^="data:"]{width:100%;height:100%;object-fit:contain}.fav-item:active{cursor:grabbing}.fav-item.dragging{opacity:.4}.fav-btn.fav-active svg{filter:drop-shadow(0 0 2px rgba(202,138,4,.3))}.fav-remove-btn{position:absolute;top:8px;right:8px;z-index:5;background:#fff;border:1px solid #E2E8F0;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;box-shadow:0 1px 3px #0000001a}.fav-remove-btn:hover{background:#FEF3C7;border-color:#ca8a04}.fav-item{position:relative}.port-card{background:var(--bg-card, #fff);border:1px solid #E2E8F0;border-radius:12px;padding:20px;box-shadow:0 1px 2px #0f172a0d;transition:box-shadow .2s ease;margin-bottom:16px}.port-card:hover{box-shadow:0 4px 6px -1px #0f172a12}.port-card-hdr{font-size:13px;font-weight:600;color:#0f172a;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between}.port-card-hdr .port-card-meta{font-size:11px;color:#94a3b8;font-weight:400}.port-table{width:100%;border-collapse:collapse;font-size:13px;font-family:IBM Plex Sans,system-ui,sans-serif}.port-table thead th{text-align:left;padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#94a3b8;background:#F8FAFC;border-bottom:2px solid #E2E8F0;white-space:nowrap}.port-table thead th.text-right{text-align:right}.port-table tbody td{padding:10px 14px;color:#0f172a;border-bottom:1px solid #E2E8F0;vertical-align:middle}.port-table tbody tr:last-child td{border-bottom:none}.port-table tbody tr:hover td{background:#F8FAFC}.port-table tbody tr.port-row-clickable{cursor:pointer;transition:background .15s}.port-table tbody tr.port-row-clickable:hover td{background:#F0F9FF}.port-table .mono{font-family:IBM Plex Mono,monospace;font-variant-numeric:tabular-nums;font-size:13px;color:#334155}.port-table .text-right{text-align:right}.port-table .text-muted{color:#64748b}.port-table .text-warn{color:#ca8a04}.port-table .text-danger{color:#dc2626}.port-detail-bg .port-table{font-size:13px;margin:0}.port-detail-bg .port-table thead th{font-size:11px;padding:8px 12px;background:#F1F5F9}.port-detail-bg .port-table tbody td{padding:8px 12px;border-bottom-color:#e2e8f0}.port-detail-bg .port-table tbody tr:last-child td{border-bottom:none}.port-detail-bg .port-cat-strip{margin-bottom:10px}.port-detail-bg p{margin:6px 0 0}.port-kpi{background:var(--bg-card, #fff);border:1px solid #E2E8F0;border-radius:12px;padding:20px;text-align:center;box-shadow:0 1px 2px #0f172a0d}.port-kpi-value{font-size:28px;font-weight:700;font-family:IBM Plex Mono,monospace;font-variant-numeric:tabular-nums;letter-spacing:-.5px}.port-kpi-label{font-size:11px;color:#94a3b8;font-weight:500;margin-top:4px;text-transform:capitalize}.port-badge{display:inline-block;padding:3px 10px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}.port-cat-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;background:rgba(0,0,0,.05);margin-left:6px}.port-detail-bg{background:#F8FAFC;padding:12px 20px 16px;border-top:1px solid #E2E8F0;border-bottom:2px solid #E2E8F0}.port-cat-strip{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin:0 0 12px;padding:10px 16px;background:#fff;border:1px solid #E2E8F0;border-radius:8px}.port-cat-item{display:flex;align-items:center;gap:6px}.port-cat-dot{display:inline-block;width:10px;height:10px;border-radius:50%}.port-cat-label{font-size:12px;color:#475569;font-weight:500}.port-cat-value{font-size:13px;font-weight:700;font-family:IBM Plex Mono,monospace}.port-cat-total{margin-left:auto;font-size:14px;font-weight:700;font-family:IBM Plex Mono,monospace;color:#0f172a}.voy-inline-summary{display:block;font-size:11px;font-weight:500;font-family:IBM Plex Mono,monospace;font-variant-numeric:tabular-nums;margin-top:3px;white-space:nowrap;line-height:1.4}.voy-expand-icon{transition:transform .15s ease}#wx-print-overlay{display:none}#wx-print-overlay .wx-pdf-header{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:2px solid #0C4A6E;margin-bottom:12px}#wx-print-overlay .wx-pdf-title{font-size:20px;font-weight:700;color:#0f172a;font-family:IBM Plex Sans,sans-serif}#wx-print-overlay .wx-pdf-meta{font-size:12px;color:#475569;margin-top:3px;font-family:IBM Plex Sans,sans-serif}#wx-print-overlay .wx-pdf-brand{font-size:10px;color:#94a3b8;font-family:IBM Plex Mono,monospace}@media print{body>*:not(#wx-print-overlay){display:none!important}#wx-print-overlay{display:block!important;position:static;width:100%;padding:8px}#wx-print-overlay .mfc-card{box-shadow:none!important;border:1px solid #E2E8F0!important;margin-bottom:8px}#wx-print-overlay .mfc-scroll{overflow:visible!important}#wx-print-overlay .mfc-table{font-size:9px!important}#wx-print-overlay .mfc-table td,#wx-print-overlay .mfc-table th{padding:2px 3px!important}body{margin:0;padding:0;background:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}@page{margin:8mm}}
