/* Port Activity / Expected Vessels — shared across port.html (runtime) and static port hubs */
.vessels-section{max-width:1160px;margin:0 auto;padding:32px 40px 36px;}
.vessels-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;gap:16px;flex-wrap:wrap;}
.vessels-title{font-family:'Fraunces',serif;font-size:22px;font-weight:300;color:var(--text-primary);}
.vessels-count{font-size:12px;color:var(--text-muted);margin-left:6px;}
.vessel-filter-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px;flex-wrap:wrap;}
.vessel-filter-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-muted);white-space:nowrap;}
.vessel-filter-pills{display:flex;gap:5px;flex-wrap:wrap;}
.vessel-pill{background:var(--white);border:1px solid var(--border);color:var(--text-secondary);padding:4px 10px;border-radius:20px;font-size:12px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all 0.15s;white-space:nowrap;}
.vessel-pill:hover{border-color:var(--accent);color:var(--accent);}
.vessel-pill.active{background:var(--navy);border-color:var(--navy);color:var(--white);}
.vessel-filter-sep{width:1px;height:20px;background:var(--border);flex-shrink:0;}
.vessel-filter-select{padding:4px 8px;border:1px solid var(--border);border-radius:6px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--text-secondary);background:var(--white);cursor:pointer;outline:none;}
.vessel-filter-select:focus{border-color:var(--accent);}
.vessel-table{width:100%;border-collapse:collapse;background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden;font-size:13px;}
.vessel-table thead tr{background:var(--silver);border-bottom:1px solid var(--border);}
.vessel-table th{padding:9px 14px;text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;color:var(--text-muted);white-space:nowrap;cursor:pointer;user-select:none;}
.vessel-table th:hover{color:var(--accent);}
.vessel-table th.sort-active{color:var(--accent);}
.vessel-table td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:top;color:var(--text-secondary);}
.vessel-table tr:last-child td{border-bottom:none;}
.vessel-table tbody tr:hover{background:var(--silver);}
.vessel-name{font-weight:500;color:var(--text-primary);font-size:13px;}
.vessel-type{font-size:11px;color:var(--text-muted);margin-top:2px;}
.vessel-flag{display:inline-flex;align-items:center;gap:4px;font-size:12px;}
.vessel-eta{font-size:12px;color:var(--text-primary);font-weight:500;}
.vessel-eta-label{font-size:11px;color:var(--text-muted);}
.vessel-org{font-size:12px;color:var(--text-secondary);}
.vessel-org-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.4px;}
.vessel-contact{font-size:11px;color:var(--accent);text-decoration:none;}
.vessel-contact:hover{text-decoration:underline;}
.vessel-status-badge{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:20px;white-space:nowrap;letter-spacing:0.3px;}
.vessel-scroll-wrap{max-height:360px;overflow-y:auto;border:1px solid var(--border);border-radius:10px;}
.vessel-scroll-wrap .vessel-table{border:none;border-radius:0;}
.vessel-scroll-wrap thead tr{position:sticky;top:0;z-index:1;}
.vessels-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;gap:14px;background:var(--white);border:1px solid var(--border);border-radius:10px;}
.vessels-spinner{width:42px;height:42px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:pv-vessels-spin 0.8s linear infinite;}
@keyframes pv-vessels-spin{to{transform:rotate(360deg);}}
.vessels-loading-eyebrow{font-size:10px;font-weight:600;letter-spacing:0.6px;text-transform:uppercase;color:var(--accent);}
.vessels-loading-msg{font-size:13px;color:var(--text-secondary);text-align:center;max-width:380px;line-height:1.55;}
.vessel-no-results{text-align:center;padding:32px;color:var(--text-muted);font-size:13px;}
@media(max-width:768px){
  .vessels-section{padding:24px 16px 28px;}
  .vessel-filter-bar{gap:8px;}
  .vessel-table th:nth-child(2),.vessel-table td:nth-child(2),
  .vessel-table th:nth-child(5),.vessel-table td:nth-child(5){display:none;}
  .vessel-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .vessel-table{min-width:560px;}
}

/* Port hero image (static hub) */
.port-hero-image{display:block;width:100%;max-height:340px;object-fit:cover;}
.port-hero-image-wrap{position:relative;margin:-1px 0 0;line-height:0;background:#0B1E3D;}
.port-hero-image-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 60%,rgba(11,30,61,0.45) 100%);pointer-events:none;}
