/* Page background / spacing */
body,
.t-Body-main,
.t-Body-content,
.t-Body-contentInner {
  background: #061726 !important;
}

.t-Body-contentInner {
  padding: 0.75rem !important;
}

/* Make native APEX region chrome disappear for report regions */
.t-Region,
.t-Region-body,
.t-Region-header {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}


.t-Region-body {
  padding: 0 !important;
}


.nv-section-heading,
.nv-passage-intelligence-title,
.nv-passage-intelligence > h2,
.passage-intelligence > h2 {
  color: #43adff !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.035em !important;
  margin: 0 0 10px 0 !important;
}

.nv-passage-intelligence,
.passage-intelligence,
section:has(.nv-intel-card) {
  margin: 0 0 1rem 0 !important;
}

.nv-intel-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  align-items: stretch !important;
}

.nv-passage-intelligence:not(:has(.nv-intel-grid)) {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.nv-passage-intelligence:not(:has(.nv-intel-grid)) > h2,
.nv-passage-intelligence:not(:has(.nv-intel-grid)) > .nv-passage-intelligence-title {
  grid-column: 1 / -1 !important;
}

.nv-intel-grid .nv-card,
.nv-intel-grid .nv-intel-card,
.nv-passage-intelligence .nv-intel-card,
.passage-intelligence .nv-intel-card {
  position: relative !important;
  background:
    radial-gradient(circle at 20% 0%, rgba(67, 173, 255, 0.10), transparent 38%),
    rgba(3, 27, 45, 0.92) !important;
  color: #ffffff !important;
  border: 1px solid rgba(86, 169, 226, 0.28) !important;
  border-radius: 12px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
  padding: 14px !important;
  min-height: 300px !important;
  overflow: hidden !important;
}

.nv-intel-grid .nv-intel-card h3,
.nv-intel-grid .nv-intel-card h2,
.nv-passage-intelligence .nv-intel-card h3,
.nv-passage-intelligence .nv-intel-card h2,
.passage-intelligence .nv-intel-card h3,
.passage-intelligence .nv-intel-card h2 {
  color: #ffffff !important;
  font-size: 16px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  margin: 0 34px 4px 0 !important;
}

.nv-intel-grid .nv-intel-card__kicker,
.nv-intel-grid .nv-intel-card .nv-kicker,
.nv-intel-grid .nv-intel-card small,
.nv-passage-intelligence .nv-intel-card__kicker,
.passage-intelligence .nv-intel-card__kicker {
  display: block !important;
  color: #a8bfce !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin: 0 0 10px 0 !important;
}

.nv-intel-grid .nv-intel-card__value,
.nv-intel-grid .nv-intel-card .nv-value,
.nv-intel-grid .nv-intel-card > strong,
.nv-passage-intelligence .nv-intel-card__value,
.passage-intelligence .nv-intel-card__value {
  display: block !important;
  margin: 8px 0 10px !important;
  color: #43adff !important;
  font-size: 22px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
}

.nv-intel-grid .nv-intel-card p,
.nv-passage-intelligence .nv-intel-card p,
.passage-intelligence .nv-intel-card p {
  color: #d9e7f0 !important;
  font-size: 13px !important;
  line-height: 1.42 !important;
  margin: 8px 0 10px !important;
}

.nv-intel-grid .nv-status-green,
.nv-intel-grid .green,
.nv-intel-grid .GREEN {
  color: #5bd889 !important;
}

.nv-intel-grid .nv-status-yellow,
.nv-intel-grid .yellow,
.nv-intel-grid .YELLOW {
  color: #ffc42e !important;
}

.nv-intel-grid .nv-status-red,
.nv-intel-grid .red,
.nv-intel-grid .RED {
  color: #ff6b5f !important;
}

.nv-intel-grid .nv-status-blue,
.nv-intel-grid .nv-status-info,
.nv-intel-grid .info,
.nv-intel-grid .INFO {
  color: #43adff !important;
}

.nv-intel-grid .nv-card-status,
.nv-intel-grid .nv-status-icon,
.nv-intel-grid .nv-intel-card__status-icon {
  position: absolute !important;
  top: 14px !important;
  right: 14px !important;
  width: 24px !important;
  height: 24px !important;
  border-radius: 999px !important;
  display: grid !important;
  place-items: center !important;
  color: #ffffff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  border: 1px solid rgba(255,255,255,0.28) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.22) !important;
}

.nv-intel-grid .nv-card-status-green,
.nv-intel-grid .nv-status-icon.green,
.nv-intel-grid .nv-status-icon.nv-green,
.nv-intel-grid .nv-status-icon.GREEN {
  background: #24965b !important;
}

.nv-intel-grid .nv-card-status-yellow,
.nv-intel-grid .nv-status-icon.yellow,
.nv-intel-grid .nv-status-icon.nv-yellow,
.nv-intel-grid .nv-status-icon.YELLOW {
  background: #ffc42e !important;
  color: #3a2a00 !important;
}

.nv-intel-grid .nv-card-status-red,
.nv-intel-grid .nv-status-icon.red,
.nv-intel-grid .nv-status-icon.nv-red,
.nv-intel-grid .nv-status-icon.RED {
  background: #d63b34 !important;
}

.nv-intel-grid .nv-card-status-blue,
.nv-intel-grid .nv-status-icon.info,
.nv-intel-grid .nv-status-icon.nv-info,
.nv-intel-grid .nv-status-icon.INFO {
  background: #155f86 !important;
}

.nv-intel-grid .nv-mini-table,
.nv-intel-grid .nv-intel-card table,
.nv-passage-intelligence .nv-intel-card table,
.passage-intelligence .nv-intel-card table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin-top: 10px !important;
  font-size: 12px !important;
  background: rgba(255,255,255,0.025) !important;
  border: 1px solid rgba(120, 200, 255, 0.14) !important;
  border-radius: 9px !important;
  overflow: hidden !important;
}

.nv-intel-grid .nv-mini-table th,
.nv-intel-grid .nv-mini-table td,
.nv-intel-grid .nv-intel-card table th,
.nv-intel-grid .nv-intel-card table td,
.nv-passage-intelligence .nv-intel-card table th,
.nv-passage-intelligence .nv-intel-card table td,
.passage-intelligence .nv-intel-card table th,
.passage-intelligence .nv-intel-card table td {
  border-bottom: 1px solid rgba(120, 200, 255, 0.14) !important;
  padding: 6px 7px !important;
  vertical-align: top !important;
  line-height: 1.25 !important;
}

.nv-intel-grid .nv-mini-table tr:last-child th,
.nv-intel-grid .nv-mini-table tr:last-child td,
.nv-intel-grid .nv-intel-card table tr:last-child th,
.nv-intel-grid .nv-intel-card table tr:last-child td {
  border-bottom: 0 !important;
}

.nv-intel-grid .nv-mini-table th,
.nv-intel-grid .nv-intel-card table th,
.nv-passage-intelligence .nv-intel-card table th,
.passage-intelligence .nv-intel-card table th {
  width: 38% !important;
  color: #8ed1ff !important;
  font-size: 10px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  font-weight: 900 !important;
}

.nv-intel-grid .nv-mini-table td,
.nv-intel-grid .nv-intel-card table td,
.nv-passage-intelligence .nv-intel-card table td,
.passage-intelligence .nv-intel-card table td {
  color: #ffffff !important;
  font-size: 12px !important;
  font-weight: 700 !important;
}

.nv-intel-grid .nv-report-note,
.nv-intel-grid .nv-captain-note,
.nv-intel-grid .nv-intel-note,
.nv-intel-grid .nv-intel-card .note,
.nv-intel-grid .nv-intel-card .warning {
  margin-top: 12px !important;
  padding: 10px !important;
  border-radius: 9px !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
}

.nv-intel-grid .nv-report-note {
  background: rgba(255, 196, 46, 0.08) !important;
  border: 1px solid rgba(255, 196, 46, 0.35) !important;
  color: #ffc42e !important;
}

.nv-intel-grid .nv-captain-note {
  background: rgba(67, 173, 255, 0.08) !important;
  border: 1px solid rgba(67, 173, 255, 0.28) !important;
  color: #bfe5ff !important;
}

.nv-intel-grid .nv-intel-card ul {
  margin: 10px 0 0 18px !important;
  padding: 0 !important;
}

.nv-intel-grid .nv-intel-card li {
  color: #d9e7f0 !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
  margin-bottom: 6px !important;
}

/* ============================================================
   PASSAGE BRIEF
   ============================================================ */

.nv-passage-brief {
  background: #ffffff !important;
  border: 1px solid rgba(6, 78, 110, 0.18) !important;
  border-radius: 14px !important;
  box-shadow: 0 8px 20px rgba(3, 24, 38, 0.12) !important;
  padding: 1.15rem 1.25rem !important;
  margin: 1rem 0 !important;
  color: #052235 !important;
}

.nv-passage-brief h2 {
  font-size: 1.25rem !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  color: #052235 !important;
  margin: 0 0 0.25rem 0 !important;
}

.nv-passage-brief .nv-intel-card__kicker,
.nv-passage-brief .nv-kicker {
  color: #5e7482 !important;
  font-size: 0.76rem !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  margin-bottom: 0.55rem !important;
}

.nv-passage-brief h3 {
  font-size: 1.1rem !important;
  line-height: 1.2 !important;
  color: #052235 !important;
  font-weight: 900 !important;
  margin: 0.5rem 0 0.35rem !important;
}

.nv-passage-brief h4 {
  font-size: 0.95rem !important;
  line-height: 1.2 !important;
  color: #052235 !important;
  font-weight: 900 !important;
  margin: 1rem 0 0.35rem !important;
}

.nv-passage-brief .nv-intel-card__value {
  font-size: 1.35rem !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  margin: 0.45rem 0 0.65rem !important;
}

.nv-passage-brief p {
  font-size: 0.9rem !important;
  line-height: 1.5 !important;
  margin: 0 0 0.65rem !important;
  color: #052235 !important;
}

.nv-passage-brief ul {
  margin: 0.5rem 0 0 1.25rem !important;
  padding: 0 !important;
}

.nv-passage-brief li {
  font-size: 0.88rem !important;
  line-height: 1.45 !important;
  margin-bottom: 0.35rem !important;
}

/* ============================================================
   EVENT TIMELINE — DARK NAVOPLAN STYLE
   ============================================================ */

.nv-event-timeline,
.nv-timeline {
  background:
    radial-gradient(circle at 20% 0%, rgba(67, 173, 255, 0.10), transparent 38%),
    rgba(3, 27, 45, 0.92) !important;
  border: 1px solid rgba(86, 169, 226, 0.28) !important;
  border-radius: 12px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
  padding: 14px !important;
  margin: 14px 0 0 !important;
  color: #ffffff !important;
}

.nv-event-timeline h2,
.nv-event-timeline h3,
.nv-event-timeline-title,
.nv-timeline h2,
.nv-timeline h3 {
  color: #43adff !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.035em !important;
  margin: 0 0 10px 0 !important;
}

.nv-event-row,
.nv-timeline-row {
  display: grid !important;
  grid-template-columns: 150px minmax(0, 1fr) !important;
  gap: 14px !important;
  padding: 10px 0 !important;
  border-bottom: 1px solid rgba(120, 200, 255, 0.14) !important;
}

.nv-event-row:last-child,
.nv-timeline-row:last-child {
  border-bottom: 0 !important;
}

.nv-event-time,
.nv-timeline-row > strong {
  color: #8ed1ff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}

.nv-event-title,
.nv-timeline-row b {
  color: #ffffff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.25 !important;
}

.nv-event-summary,
.nv-timeline-row div {
  color: #d9e7f0 !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

/* ============================================================
   PASSAGE PHASE HERO
   ============================================================ */

.nv-phase-hero {
  display: block !important;
  background:
    radial-gradient(circle at top left, rgba(38, 135, 203, 0.28), transparent 38%),
    linear-gradient(135deg, #03101d 0%, #061928 55%, #071b2e 100%) !important;
  color: #f4fbff !important;
  border: 1px solid rgba(91, 183, 255, 0.25) !important;
  border-radius: 18px !important;
  padding: 18px !important;
  box-shadow: 0 18px 45px rgba(0,0,0,0.35) !important;
  margin: 0 0 1rem 0 !important;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;
}

.nv-phase-hero,
.nv-phase-hero * {
  box-sizing: border-box !important;
}

.nv-phase-hero__top {
  display: grid !important;
  grid-template-columns: minmax(0, 1.08fr) minmax(390px, 0.92fr) !important;
  gap: 18px !important;
  align-items: stretch !important;
}

.nv-phase-hero__identity,
.nv-port-media-panel {
  background: linear-gradient(180deg, rgba(8,35,58,0.96), rgba(5,24,40,0.96)) !important;
  border: 1px solid rgba(91,183,255,0.25) !important;
  border-radius: 14px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05) !important;
}

.nv-phase-hero__identity {
  padding: 24px !important;
  min-width: 0 !important;
}

.nv-phase-hero__kicker,
.nv-mini-kicker {
  display: block !important;
  color: #8ed1ff !important;
  text-transform: uppercase !important;
  letter-spacing: 0.055em !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  margin: 0 0 4px 0 !important;
}





/* Hide old CSS/emoji flag experiments if still cached in HTML */
.nv-phase-hero .nv-flag,
.nv-phase-hero .nv-flag-ca,
.nv-phase-hero .nv-flag-us,
.nv-phase-hero .nv-country-flag-emoji {
  display: none !important;
}

.nv-phase-hero__subtitle {
  display: block !important;
  color: #d5e7f2 !important;
  font-size: 19px !important;
  line-height: 1.35 !important;
  margin-top: 2px !important;
}

.nv-phase-hero__subtitle span {
  display: inline !important;
  color: rgba(255,255,255,0.45) !important;
  margin: 0 8px !important;
}

/* Embedded lower area inside Departure Port card */
.nv-departure-port-lower {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 260px !important;
  gap: 18px !important;
  align-items: stretch !important;
  margin-top: 16px !important;
  padding-top: 16px !important;
  border-top: 1px solid rgba(120, 200, 255, 0.22) !important;
}

.nv-departure-windows-compact {
  min-width: 0 !important;
}

.nv-window-rows--compact {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  margin-top: 8px !important;
}

/* Departure window row: time + comment only; rank number hidden below */
.nv-window-row--compact {
  display: grid !important;
  grid-template-columns: 170px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 8px !important;
  min-height: 36px !important;
  padding: 6px 8px !important;
  border-radius: 8px !important;
  background: rgba(255, 255, 255, 0.045) !important;
  border: 1px solid rgba(120, 200, 255, 0.15) !important;
}

/* Rank is still emitted by PL/SQL for now, but no longer displayed */
.nv-window-row__rank {
  display: none !important;
}

.nv-window-row__time {
  color: #ffffff !important;
  font-weight: 900 !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  white-space: nowrap !important;
  margin: 0 !important;
}

.nv-window-row__comment {
  color: rgba(255, 255, 255, 0.82) !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  margin: 0 !important;
  max-width: none !important;
}



.nv-baseline-row {
  display: block !important;
}





/* Right image/data panel */
.nv-port-media-panel {
  position: relative !important;
  min-height: 330px !important;
  overflow: hidden !important;
}

.nv-port-media-panel__image {
  position: absolute !important;
  inset: 0 !important;
  background-size: cover !important;
  background-position: center center !important;
  filter: saturate(1.08) contrast(1.02) !important;
}

.nv-port-media-panel__image::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.05), rgba(0,0,0,0.42)),
    linear-gradient(90deg, rgba(3,16,29,0.15), rgba(3,16,29,0.35)) !important;
}

.nv-port-media-panel__image--fallback {
  display: grid !important;
  place-items: center !important;
  background:
    radial-gradient(circle at 35% 20%, rgba(67,173,255,0.28), transparent 36%),
    linear-gradient(135deg, #08233a, #061928) !important;
}

.nv-port-media-panel__image--fallback div {
  position: relative !important;
  z-index: 1 !important;
  text-align: center !important;
}

.nv-port-media-panel__image--fallback strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 26px !important;
  font-weight: 900 !important;
}

.nv-port-media-panel__image--fallback span {
  display: block !important;
  margin-top: 4px !important;
  color: #a8bfce !important;
  font-size: 14px !important;
}

.nv-port-media-panel__overlay {
  position: absolute !important;
  left: 16px !important;
  right: 16px !important;
  bottom: 16px !important;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  background: rgba(5, 24, 40, 0.86) !important;
  border: 1px solid rgba(91,183,255,0.22) !important;
  border-radius: 12px !important;
  backdrop-filter: blur(5px) !important;
  overflow: hidden !important;
}

.nv-port-fact {
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) !important;
  gap: 8px !important;
  align-items: center !important;
  padding: 13px 12px !important;
  border-right: 1px solid rgba(120,200,255,0.18) !important;
  min-width: 0 !important;
}

.nv-port-fact:last-child {
  border-right: 0 !important;
}

.nv-port-fact__icon {
  color: #43adff !important;
  font-size: 30px !important;
  line-height: 1 !important;
  text-align: center !important;
}

.nv-port-fact span {
  display: block !important;
  color: #a8bfce !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.045em !important;
}

.nv-port-fact strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 15px !important;
  line-height: 1.2 !important;
  margin-top: 2px !important;
  font-weight: 800 !important;
}

.nv-port-fact small {
  display: block !important;
  color: #a8bfce !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  margin-top: 2px !important;
}

.nv-port-media-panel__credit {
  position: absolute !important;
  right: 12px !important;
  top: 10px !important;
  z-index: 2 !important;
  color: rgba(255,255,255,0.72) !important;
  font-size: 11px !important;
  background: rgba(0,0,0,0.35) !important;
  padding: 3px 7px !important;
  border-radius: 999px !important;
}

/* Hide old hero elements if stale HTML is still present */
.nv-phase-hero > .nv-window-panel,
.nv-phase-hero__bottom,
.nv-window-panel__status,
.nv-window-row__status,
.nv-window-status-go,
.nv-window-status-review,
.nv-window-status-hold,
.nv-pill,
.nv-window-rating {
  display: none !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1200px) {
  .nv-intel-grid,
  .nv-passage-intelligence:not(:has(.nv-intel-grid)) {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 1100px) {
  .nv-phase-hero__top {
    grid-template-columns: 1fr !important;
  }

  .nv-port-media-panel {
    min-height: 300px !important;
  }
}

@media (max-width: 860px) {
  .nv-departure-port-lower {
    grid-template-columns: 1fr !important;
  }

  .nv-departure-baseline {
    padding-left: 0 !important;
    padding-top: 30px !important;
    border-left: 0 !important;
    border-top: 1px solid rgba(120, 200, 255, 0.22) !important;
  }
}

@media (max-width: 760px) {
  .nv-intel-grid,
  .nv-passage-intelligence:not(:has(.nv-intel-grid)) {
    grid-template-columns: 1fr !important;
  }

  .nv-intel-card {
    min-height: auto !important;
  }

  .nv-event-row {
    grid-template-columns: 1fr !important;
  }

  .nv-passage-brief,
  .nv-event-timeline,
  .nv-intel-card {
    padding: 0.9rem !important;
  }

  .nv-port-media-panel__overlay {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .nv-port-fact:nth-child(2) {
    border-right: 0 !important;
  }

  .nv-port-fact:nth-child(1),
  .nv-port-fact:nth-child(2) {
    border-bottom: 1px solid rgba(120,200,255,0.18) !important;
  }
}

@media (max-width: 680px) {
  .nv-phase-hero {
    padding: 12px !important;
  }

  .nv-phase-hero__identity {
    padding: 15px !important;
  }

  .nv-phase-hero__title {
    font-size: 36px !important;
  }

  .nv-phase-hero__subtitle {
    font-size: 15px !important;
  }

  .nv-window-row--compact {
    grid-template-columns: 1fr !important;
  }
  .nv-window-row__comment {
    grid-column: auto !important;
  }

  .nv-window-row__time {
    white-space: normal !important;
  }
}

/* Past-departure warning color */
.nv-port-fact--late .nv-port-fact__icon,
.nv-port-fact--late span,
.nv-port-fact--late strong {
  color: #ffc42e !important;
}

.nv-port-fact--late {
  background: rgba(255, 196, 46, 0.08) !important;
}

/* Hero title: less heavy */
.nv-phase-hero__title {
  display: block !important;
  margin: 4px 0 4px 0 !important;
  color: #ffffff !important;
  font-size: clamp(34px, 4vw, 46px) !important;
  line-height: 0.98 !important;
  letter-spacing: -0.035em !important;
  font-weight: 600 !important;
}

/* Real country flag image */
.nv-phase-hero .nv-country-flag-img {
  display: inline-block !important;
  width: 80px !important;
  height: auto !important;
  margin-left: 12px !important;
  vertical-align: middle !important;
  transform: translateY(-4px) !important;
  border-radius: 2px !important;
  box-shadow: 0 0 0 1px rgba(255,255,255,0.35) !important;
}

/* Keep old icon fallback harmless */
.nv-phase-hero .nv-country-flag {
  font-size: 1.1em !important;
  margin-left: 0.45rem !important;
  vertical-align: 0.02em !important;
  color: #8ed1ff !important;
}

/* Departure baseline panel with icons */
.nv-departure-baseline {
  padding-left: 18px !important;
  border-left: 1px solid rgba(120, 200, 255, 0.22) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
  gap: 14px !important;
  padding-top: 2px !important;
}

.nv-baseline-row--with-icon {
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) !important;
  gap: 10px !important;
  align-items: start !important;
}

.nv-baseline-icon {
  width: 34px !important;
  height: 34px !important;
  display: grid !important;
  place-items: center !important;
  color: #43adff !important;
  font-size: 50px !important;
  line-height: 1 !important;
}

.nv-baseline-row strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}

.nv-baseline-row span {
  display: block !important;
  color: #a8bfce !important;
  font-size: 30px !important;
  margin-top: 2px !important;
}

.nv-departure-baseline .nv-baseline-row span {
  display: block !important;
  color: #a8bfce !important;
  font-size: 28px !important;
  line-height: 1.25 !important;
  margin-top: 3px !important;
  font-weight: 500 !important;
}

.nv-departure-baseline .nv-baseline-row strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}

.nv-departure-baseline .nv-baseline-row .nv-mini-kicker {
  font-size: 12px !important;
  line-height: 1.1 !important;
  letter-spacing: 0.04em !important;
}

/* Right panel facts: keep Tide / Daylight / Moon in NAVOPLAN blue */
.nv-port-media-panel__overlay .nv-port-fact:not(.nv-port-fact--late) .nv-port-fact__icon,
.nv-port-media-panel__overlay .nv-port-fact:not(.nv-port-fact--late) span {
  color: #43adff !important;
}

.nv-port-media-panel__overlay .nv-port-fact:not(.nv-port-fact--late) strong {
  color: #ffffff !important;
}

.nv-port-media-panel__overlay .nv-port-fact:not(.nv-port-fact--late) small {
  color: #b9c9d6 !important;
}

/* =========================================================
   PASSAGE PHASE SUPPORT ROW
   One region / three panels
   ========================================================= */

.nv-phase-support-row {
  display: grid !important;
  grid-template-columns: 1.08fr 0.95fr 0.95fr !important;
  gap: 14px !important;
  margin-top: 14px !important;
}

.nv-support-panel {
  border: 1px solid rgba(86, 169, 226, 0.28) !important;
  border-radius: 12px !important;
  background:
    radial-gradient(circle at 20% 0%, rgba(67, 173, 255, 0.10), transparent 38%),
    rgba(3, 27, 45, 0.92) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
  padding: 14px !important;
  color: #ffffff !important;
  min-height: 240px !important;
}

.nv-support-panel__head {
  margin-bottom: 12px !important;
}

.nv-support-panel__head h2 {
  margin: 0 !important;
  color: #43adff !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
  font-weight: 800 !important;
}

.nv-support-panel__head h2 span {
  color: #a8bfce !important;
  font-size: 13px !important;
  text-transform: none !important;
}

.nv-support-panel__head p {
  margin: 4px 0 0 0 !important;
  color: #a8bfce !important;
  font-size: 13px !important;
}

/* Weather now */

.nv-weather-tile-grid {
  display: grid !important;
  grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  border: 1px solid rgba(120, 200, 255, 0.14) !important;
  border-radius: 9px !important;
  overflow: hidden !important;
  background: rgba(255,255,255,0.03) !important;
}

.nv-weather-tile {
  padding: 10px 8px !important;
  text-align: center !important;
  border-right: 1px solid rgba(120, 200, 255, 0.14) !important;
}

.nv-weather-tile:last-child {
  border-right: none !important;
}

.nv-weather-label {
  color: #8ed1ff !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
}

.nv-weather-icon {
  color: #43adff !important;
  font-size: 28px !important;
  line-height: 1 !important;
  margin-bottom: 7px !important;
}

.nv-weather-tile strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 15px !important;
  line-height: 1.15 !important;
}

.nv-weather-tile small {
  display: block !important;
  color: #b9c9d6 !important;
  font-size: 12px !important;
  margin-top: 4px !important;
}

/* Next 12 */

.nv-outlook-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 6px !important;
  padding: 8px !important;
  border-radius: 9px !important;
  background: rgba(255,255,255,0.035) !important;
}

.nv-outlook-card {
  text-align: center !important;
  padding: 8px 6px !important;
  border-left: 1px solid rgba(120, 200, 255, 0.12) !important;
}

.nv-outlook-card:first-child {
  border-left: none !important;
}

.nv-outlook-card div {
  color: #a8bfce !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  margin-bottom: 6px !important;
}

.nv-outlook-card span {
  display: block !important;
  color: #43adff !important;
  font-size: 26px !important;
  line-height: 1 !important;
  margin-bottom: 8px !important;
}

.nv-outlook-card strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
}

.nv-outlook-card small {
  display: block !important;
  color: #b9c9d6 !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  margin-top: 3px !important;
}

/* Callouts */

.nv-support-callout {
  display: grid !important;
  grid-template-columns: 28px minmax(0,1fr) !important;
  gap: 8px !important;
  align-items: start !important;
  margin-top: 12px !important;
  padding: 10px !important;
  border-radius: 9px !important;
}

.nv-support-callout span {
  font-size: 20px !important;
}

.nv-support-callout strong {
  font-size: 14px !important;
}

.nv-support-callout small {
  color: #b9c9d6 !important;
  font-size: 13px !important;
}

.nv-support-callout--review {
  background: rgba(67, 173, 255, 0.08) !important;
  color: #8ed1ff !important;
}

.nv-support-callout--trend {
  background: rgba(255, 196, 46, 0.08) !important;
  color: #ffc42e !important;
}

/* Harbor logistics */

.nv-logistics-list {
  border: 1px solid rgba(120, 200, 255, 0.14) !important;
  border-radius: 9px !important;
  overflow: hidden !important;
  background: rgba(255,255,255,0.03) !important;
}

.nv-logistics-row {
  display: grid !important;
  grid-template-columns: 34px 120px minmax(0,1fr) !important;
  gap: 10px !important;
  align-items: start !important;
  padding: 9px 10px !important;
  border-bottom: 1px solid rgba(120, 200, 255, 0.14) !important;
}

.nv-logistics-row:last-child {
  border-bottom: none !important;
}

.nv-logistics-icon {
  color: #43adff !important;
  font-size: 20px !important;
  text-align: center !important;
}

.nv-logistics-row strong {
  color: #ffffff !important;
  font-size: 14px !important;
}

.nv-logistics-row em {
  color: #d9e7f0 !important;
  font-style: normal !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
}

/* Mobile */

@media (max-width: 900px) {
  .nv-phase-support-row {
    grid-template-columns: 1fr !important;
  }

  .nv-weather-tile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .nv-weather-tile {
    border-bottom: 1px solid rgba(120, 200, 255, 0.14) !important;
  }

  .nv-outlook-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .nv-logistics-row {
    grid-template-columns: 30px 100px minmax(0,1fr) !important;
  }
}

.nv-logistics-source-note {
  margin-top: 8px !important;
  color: #ffc42e !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  font-weight: 700 !important;
}

.nv-phase-support-row--two-panel {
  display: grid !important;
  grid-template-columns: minmax(320px, 1fr) minmax(620px, 2fr) !important;
  gap: 14px !important;
  align-items: stretch !important;
}

.nv-support-weather-combined,
.nv-support-logistics--wide {
  min-width: 0 !important;
}

.nv-weather-head-combined {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
}

.nv-support-callout--compact {
  margin: 0 !important;
  padding: 8px 10px !important;
  max-width: 250px !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
}

.nv-support-callout--compact strong {
  font-size: 12px !important;
  line-height: 1.25 !important;
}

.nv-weather-subhead {
  margin: 10px 0 6px !important;
  color: #7fc7ff !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

.nv-weather-tile-grid--combined {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

.nv-weather-tile-grid--combined .nv-weather-tile,
.nv-outlook-grid--combined .nv-outlook-card {
  min-height: 78px !important;
  padding: 8px 6px !important;
}

.nv-outlook-grid--combined {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 8px !important;
}

.nv-outlook-grid--combined .nv-outlook-card {
  padding: 8px !important;
}

.nv-logistics-list--wide {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px 14px !important;
}

.nv-logistics-list--wide .nv-logistics-row {
  min-height: 58px !important;
}

.nv-logistics-list--wide .nv-logistics-row em {
  line-height: 1.25 !important;
}

@media (max-width: 980px) {
  .nv-phase-support-row--two-panel {
    grid-template-columns: 1fr !important;
  }

  .nv-weather-head-combined {
    flex-direction: column !important;
  }

  .nv-support-callout--compact {
    max-width: none !important;
    width: 100% !important;
  }

  .nv-logistics-list--wide {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 640px) {
  .nv-weather-tile-grid--combined {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .nv-outlook-grid--combined {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}


    /* ============================================================
   PASSAGE BRIEF — DARK NAVOPLAN STYLE
   ============================================================ */

   /* Hide spinner only for this APEX Map region */
#PASSAGE_MAP .u-Processing,
#PASSAGE_MAP .u-Processing-spinner,
#PASSAGE_MAP .a-MapRegion-loader,
#PASSAGE_MAP .a-MapRegion-spinner {
  display: none !important;
}



.nv-passage-brief {
  position: relative !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(67, 173, 255, 0.12), transparent 36%),
    rgba(3, 27, 45, 0.92) !important;
  color: #ffffff !important;
  border: 1px solid rgba(86, 169, 226, 0.28) !important;
  border-radius: 12px !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
  padding: 18px !important;
  margin: 14px 0 0 !important;
  overflow: hidden !important;
}

.nv-passage-brief h2 {
  margin: 0 !important;
  color: #43adff !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.035em !important;
  font-weight: 900 !important;
}

.nv-passage-brief .nv-intel-card__kicker,
.nv-passage-brief .nv-kicker {
  display: block !important;
  color: #a8bfce !important;
  font-size: 13px !important;
  line-height: 1.25 !important;
  font-weight: 500 !important;
  margin: 4px 0 12px !important;
}

.nv-passage-brief h3 {
  margin: 0 0 8px !important;
  color: #ffffff !important;
  font-size: 24px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
}

.nv-passage-brief .nv-intel-card__value {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 0 14px !important;
  padding: 5px 10px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
}

.nv-passage-brief .nv-status-green {
  color: #ffffff !important;
  background: rgba(36, 150, 91, 0.88) !important;
}

.nv-passage-brief .nv-status-yellow {
  color: #3a2a00 !important;
  background: rgba(255, 196, 46, 0.95) !important;
}

.nv-passage-brief .nv-status-red {
  color: #ffffff !important;
  background: rgba(214, 59, 52, 0.92) !important;
}

.nv-passage-brief .nv-status-info {
  color: #ffffff !important;
  background: rgba(21, 95, 134, 0.95) !important;
}

.nv-passage-brief h4 {
  margin: 16px 0 6px !important;
  color: #8ed1ff !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.055em !important;
}

.nv-passage-brief p {
  color: #d9e7f0 !important;
  font-size: 14px !important;
  line-height: 1.48 !important;
  margin: 0 0 10px !important;
  max-width: 1120px !important;
}

.nv-passage-brief ul {
  margin: 8px 0 0 20px !important;
  padding: 0 !important;
  max-width: 1120px !important;
}

.nv-passage-brief li {
  color: #d9e7f0 !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
  margin-bottom: 7px !important;
  padding-left: 2px !important;
}

.nv-passage-brief li::marker {
  color: #43adff !important;
}

.nv-passage-brief .nv-report-note {
  margin-top: 16px !important;
  padding: 10px 12px !important;
  border-radius: 9px !important;
  background: rgba(255, 196, 46, 0.08) !important;
  border: 1px solid rgba(255, 196, 46, 0.35) !important;
  color: #ffc42e !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-weight: 700 !important;
}

/* Optional: make the brief read like a narrative panel rather than a card wall */
.nv-passage-brief h4 + p {
  padding-left: 12px !important;
  border-left: 2px solid rgba(67, 173, 255, 0.28) !important;
}

/* Mobile */
@media (max-width: 760px) {
  .nv-passage-brief {
    padding: 14px !important;
  }

  .nv-passage-brief h3 {
    font-size: 20px !important;
  }

  .nv-passage-brief p,
  .nv-passage-brief li {
    font-size: 13px !important;
  }
}

/* ============================================================
   PASSAGE GATES
   ============================================================ */

.nv-passage-gates {
  margin-top: 14px !important;
}

.nv-passage-gates-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 14px !important;
}

.nv-passage-gates-head h2 {
  margin: 0 !important;
}

.nv-passage-gates-head p {
  margin: 4px 0 0 !important;
  color: #d9e7f0 !important;
  font-size: 14px !important;
}

.nv-gate-legend {
  display: flex !important;
  gap: 14px !important;
  align-items: center !important;
  color: #d9e7f0 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
}

.nv-gate-legend span::before {
  content: "" !important;
  display: inline-block !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 999px !important;
  margin-right: 6px !important;
}

.nv-gate-legend-past::before {
  border: 2px solid #5bd889 !important;
}

.nv-gate-legend-current::before {
  border: 2px solid #ffc42e !important;
}

.nv-gate-legend-future::before {
  border: 2px solid #43adff !important;
}

.nv-passage-gates-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.nv-gate-card {
  display: grid !important;
  grid-template-columns: 48px minmax(0, 1fr) !important;
  gap: 10px !important;
  align-items: center !important;
  min-width: 0 !important;
  border-radius: 12px !important;
  padding: 12px !important;
  border: 1px solid rgba(120, 200, 255, 0.18) !important;
  background: rgba(255,255,255,0.035) !important;
}

.nv-gate-card__icon {
  width: 36px !important;
  height: 36px !important;
  border-radius: 999px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 20px !important;
  font-weight: 900 !important;
}

.nv-gate-card__seq {
  color: #8ed1ff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .04em !important;
}

.nv-gate-card__name {
  color: #ffffff !important;
  font-size: 17px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  margin-top: 2px !important;
}

.nv-gate-card__note,
.nv-gate-card__range {
  color: #d9e7f0 !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  margin-top: 3px !important;
}

/* Past */
.nv-gate-card--past {
  border-color: rgba(91, 216, 137, .75) !important;
  background: linear-gradient(90deg, rgba(37, 115, 70, .38), rgba(3, 27, 45, .88)) !important;
}

.nv-gate-card--past .nv-gate-card__icon {
  color: #ffffff !important;
  background: rgba(36, 150, 91, .65) !important;
  border: 2px solid #5bd889 !important;
}

/* Current */
.nv-gate-card--current {
  border-color: rgba(255, 196, 46, .9) !important;
  background: linear-gradient(90deg, rgba(116, 91, 8, .46), rgba(3, 27, 45, .88)) !important;
}

.nv-gate-card--current .nv-gate-card__icon {
  color: #ffc42e !important;
  background: rgba(255, 196, 46, .12) !important;
  border: 2px solid #ffc42e !important;
}

/* Future */
.nv-gate-card--future {
  border-color: rgba(67, 173, 255, .72) !important;
  background: linear-gradient(90deg, rgba(18, 82, 132, .34), rgba(3, 27, 45, .88)) !important;
}

.nv-gate-card--future .nv-gate-card__icon {
  color: #8ed1ff !important;
  background: rgba(67, 173, 255, .12) !important;
  border: 2px solid #43adff !important;
}

@media (max-width: 1100px) {
  .nv-passage-gates-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px) {
  .nv-passage-gates-head {
    flex-direction: column !important;
  }

  .nv-passage-gates-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 768px) {
  .np-page-rail {
    display: none;
  }

  .t-Body-main {
    margin-left: 0;
  }
}

/* ============================================================
   PATCH 2026-06-06 — PRE-PLANNING HERO POLISH
   Purpose:
   1) Make the hero kicker match the support-panel heading style.
   2) Brighten the right-side port image while preserving overlay readability.
   Place this block after the existing passage CSS so it wins the cascade.
   ============================================================ */

/* Match "PRE-PLANNING · DEPARTURE PORT" to row-2 panel headings */
.nv-phase-hero .nv-phase-hero__kicker {
  display: block !important;
  color: #43adff !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.02em !important;
  margin: 0 0 8px 0 !important;
}

/* Brighten the hero image */
.nv-phase-hero .nv-port-media-panel__image {
  filter: brightness(1.16) saturate(1.12) contrast(1.03) !important;
}

/* Reduce the dark wash over the image */
.nv-phase-hero .nv-port-media-panel__image::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background:
    linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.24)),
    linear-gradient(90deg, rgba(3,16,29,0.05), rgba(3,16,29,0.18)) !important;
}

/* Keep the data strip readable on the brighter image */
.nv-phase-hero .nv-port-media-panel__overlay {
  background: rgba(5, 24, 40, 0.88) !important;
  backdrop-filter: blur(5px) !important;
}


/* ============================================================
   PASSAGE GATES / ACTIVE PASSAGE GATES
   Restores gate card layout, legend, and past/current/future styling
   ============================================================ */

.nv-passage-gates {
  position: relative !important;
  margin: 14px 0 0 !important;
  padding: 18px !important;
  border: 1px solid rgba(86, 169, 226, 0.28) !important;
  border-radius: 12px !important;
  background:
    radial-gradient(circle at 18% 0%, rgba(67, 173, 255, 0.12), transparent 36%),
    rgba(3, 27, 45, 0.92) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important;
  color: #ffffff !important;
  overflow: hidden !important;
}

.nv-passage-gates-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-bottom: 14px !important;
}

.nv-passage-gates-head h2,
.nv-passage-gates h2 {
  margin: 0 !important;
  color: #43adff !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.035em !important;
}

.nv-passage-gates-head p,
.nv-passage-gates p {
  margin: 6px 0 0 !important;
  color: #d9e7f0 !important;
  font-size: 14px !important;
  line-height: 1.35 !important;
}

.nv-gate-legend {
  display: flex !important;
  gap: 14px !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  color: #d9e7f0 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
}

.nv-gate-legend span {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.nv-gate-legend span::before {
  content: "" !important;
  display: inline-block !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 999px !important;
  flex: 0 0 auto !important;
}

.nv-gate-legend-past::before {
  border: 2px solid #5bd889 !important;
}

.nv-gate-legend-current::before {
  border: 2px solid #ffc42e !important;
}

.nv-gate-legend-future::before {
  border: 2px solid #43adff !important;
}

.nv-passage-gates-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.nv-gate-card {
  display: grid !important;
  grid-template-columns: 48px minmax(0, 1fr) !important;
  gap: 10px !important;
  align-items: center !important;
  min-width: 0 !important;
  border-radius: 12px !important;
  padding: 12px !important;
  border: 1px solid rgba(120, 200, 255, 0.18) !important;
  background: rgba(255,255,255,0.035) !important;
  color: #ffffff !important;
}

.nv-gate-card__icon {
  width: 36px !important;
  height: 36px !important;
  border-radius: 999px !important;
  display: grid !important;
  place-items: center !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
}

.nv-gate-card__seq {
  color: #8ed1ff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
}

.nv-gate-card__name {
  color: #ffffff !important;
  font-size: 17px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
  margin-top: 2px !important;
}

.nv-gate-card__note,
.nv-gate-card__range {
  color: #d9e7f0 !important;
  font-size: 12px !important;
  line-height: 1.25 !important;
  margin-top: 3px !important;
}

/* Past */
.nv-gate-card--past {
  border-color: rgba(91, 216, 137, 0.75) !important;
  background: linear-gradient(90deg, rgba(37, 115, 70, 0.38), rgba(3, 27, 45, 0.88)) !important;
}

.nv-gate-card--past .nv-gate-card__icon {
  color: #ffffff !important;
  background: rgba(36, 150, 91, 0.65) !important;
  border: 2px solid #5bd889 !important;
}

/* Current */
.nv-gate-card--current {
  border-color: rgba(255, 196, 46, 0.9) !important;
  background: linear-gradient(90deg, rgba(116, 91, 8, 0.46), rgba(3, 27, 45, 0.88)) !important;
}

.nv-gate-card--current .nv-gate-card__icon {
  color: #ffc42e !important;
  background: rgba(255, 196, 46, 0.12) !important;
  border: 2px solid #ffc42e !important;
}

/* Future */
.nv-gate-card--future {
  border-color: rgba(67, 173, 255, 0.72) !important;
  background: linear-gradient(90deg, rgba(18, 82, 132, 0.34), rgba(3, 27, 45, 0.88)) !important;
}

.nv-gate-card--future .nv-gate-card__icon {
  color: #8ed1ff !important;
  background: rgba(67, 173, 255, 0.12) !important;
  border: 2px solid #43adff !important;
}

/* Responsive */
@media (max-width: 1100px) {
  .nv-passage-gates-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px) {
  .nv-passage-gates-head {
    flex-direction: column !important;
  }

  .nv-passage-gates-grid {
    grid-template-columns: 1fr !important;
  }

  .nv-gate-legend {
    justify-content: flex-start !important;
  }
}