/* Fleet reporting layout system: shared visual layer for dashboard pages. */
:root {
  --fleet-bg: #eef3f8;
  --fleet-panel: #ffffff;
  --fleet-panel-soft: #f7f9fc;
  --fleet-line: #cfd9e6;
  --fleet-line-strong: #aebed0;
  --fleet-navy: #08294d;
  --fleet-navy-2: #0f3b69;
  --fleet-accent: #1d6fb5;
  --fleet-accent-bg: #e8f3ff;
  --fleet-ok: #15803d;
  --fleet-ok-bg: #dcfce7;
  --fleet-warn: #b45309;
  --fleet-warn-bg: #fef3c7;
  --fleet-danger: #dc2626;
  --fleet-danger-bg: #fee2e2;
  --fleet-text: #142033;
  --fleet-muted: #63758c;
}

html { background: var(--fleet-bg); }
body {
  background: var(--bg, var(--fleet-bg));
  color: var(--text, var(--fleet-text));
  font-family: "Segoe UI", Arial, sans-serif;
}

/* Header is for identity, navigation, and status only. Page actions live in bottom bars. */
.topbar {
  min-height: 52px !important;
  background: var(--navy, var(--fleet-navy)) !important;
  border-bottom: 2px solid var(--navy2, var(--fleet-navy-2)) !important;
  box-shadow: 0 1px 0 rgba(8, 41, 77, .18);
}
.topbar .brand {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}
.topbar .brand > div:last-child {
  min-width: 0 !important;
}
.topbar .title,
.topbar .sub {
  display: block !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}
.topbar .top-actions {
  margin-left: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
  min-width: max-content !important;
}
.topbar .top-actions .top-btn {
  flex: 0 0 auto !important;
}
.topbar .t-right .tbtn,
.topbar .actions .tbtn,
.topbar .topbar-right .tbtn {
  display: none !important;
}
.topbar .t-right button[data-action],
.topbar .actions button[data-action],
.topbar .topbar-right button[data-action] {
  display: none !important;
}
.topbar .t-right,
.topbar .actions,
.topbar .topbar-right {
  margin-left: auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
.t-title, .topbar .title, .topbar h1 {
  letter-spacing: 0 !important;
}
.t-sub, .topbar p {
  color: rgba(255,255,255,.58) !important;
}

/* Form header rhythm: Header -> Vessel/Month/CE -> KPI -> Table -> Bottom actions. */
.vessel-hdr,
.controls,
.form-header,
.report-controls {
  background: var(--panel, var(--fleet-panel)) !important;
  border-bottom: 1px solid var(--border, var(--fleet-line)) !important;
  padding: 10px 18px !important;
  gap: 12px !important;
  align-items: flex-end !important;
}
.vf label,
.field label,
.report-controls label {
  color: var(--muted, var(--fleet-muted)) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: .05em !important;
  text-transform: uppercase !important;
}
.vf select, .vf input,
.field select, .field input,
.field textarea,
.report-controls select,
.report-controls input {
  min-height: 32px !important;
  border: 1px solid var(--border2, var(--fleet-line-strong)) !important;
  border-radius: 7px !important;
  padding: 6px 10px !important;
  font-size: 12px !important;
  font-weight: 650 !important;
  color: var(--text, var(--fleet-text)) !important;
  background: #fff !important;
}

/* KPI cards */
.kpi-row,
.kpis {
  gap: 8px !important;
  padding: 10px 18px !important;
  background: transparent !important;
  border-bottom: 1px solid var(--border, var(--fleet-line)) !important;
}
.kpi {
  border: 1px solid var(--border, var(--fleet-line)) !important;
  border-radius: 8px !important;
  background: var(--panel, var(--fleet-panel)) !important;
  padding: 10px 13px !important;
}
.kpi-label {
  font-size: 10px !important;
  font-weight: 800 !important;
  color: var(--muted, var(--fleet-muted)) !important;
}
.kpi-val {
  font-size: 22px !important;
  line-height: 1.1 !important;
}

/* Operational tables: denser, predictable numeric columns. */
.tbl-wrap,
.table-wrap,
.main {
  scrollbar-width: thin;
}
table.lot {
  width: 100% !important;
  min-width: 820px !important;
  table-layout: fixed !important;
  border-collapse: collapse !important;
}
.lot thead th {
  padding: 6px 8px !important;
  font-size: 9.5px !important;
  line-height: 1.2 !important;
  letter-spacing: .04em !important;
}
.lot tbody td {
  vertical-align: middle !important;
}
.c-text,
.lot tbody td > div,
.lot tbody td > span {
  padding: 5px 8px !important;
  line-height: 1.25 !important;
}
.ni,
.supplier-select,
.lot input,
.lot select {
  min-height: 28px !important;
  padding: 5px 7px !important;
  font-size: 11.5px !important;
}
.c-calc {
  padding: 5px 8px !important;
  font-size: 11.5px !important;
}
.hm th,
.hm td {
  padding-top: 5px !important;
  padding-bottom: 5px !important;
}
.hm .cell {
  min-height: 36px !important;
  height: 36px !important;
}

/* Bottom action bar: primary action surface. */
.bottom-bar,
.submit-bar,
.action-bar,
.form-actions {
  background: var(--panel, var(--fleet-panel)) !important;
  border-top: 1px solid var(--border2, var(--fleet-line-strong)) !important;
  padding: 10px 18px !important;
  display: flex !important;
  align-items: center !important;
  gap: 9px !important;
  flex-wrap: wrap !important;
}
.bb-right,
.action-group,
.form-actions .right {
  margin-left: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  flex-wrap: wrap !important;
}

/* Buttons: text is clean; icons are controlled here. */
.btn,
.top-btn,
.tbtn,
.hbtn,
button.btn,
a.btn {
  min-height: 32px !important;
  border: 1px solid var(--border2, var(--fleet-line-strong)) !important;
  border-radius: 7px !important;
  background: #fff !important;
  color: var(--navy, var(--fleet-navy)) !important;
  padding: 0 12px !important;
  font-size: 12px !important;
  font-weight: 750 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  line-height: 1 !important;
  text-decoration: none !important;
  cursor: pointer !important;
  white-space: nowrap !important;
}
.btn:hover,
.top-btn:hover,
.hbtn:hover {
  background: var(--fleet-accent-bg) !important;
  border-color: #9dc7ee !important;
}
.topbar .btn.ghost,
.topbar button.btn.ghost,
.topbar .actions .btn.ghost,
.topbar .topbar-right .btn.ghost {
  min-width: 64px !important;
  background: rgba(255,255,255,.08) !important;
  border-color: rgba(255,255,255,.28) !important;
  color: #fff !important;
  opacity: 1 !important;
  font-size: 12px !important;
}
.topbar .btn.ghost:hover,
.topbar button.btn.ghost:hover {
  background: rgba(255,255,255,.18) !important;
  color: #fff !important;
}

/* Submit belongs to the bottom action bar, not the header. */
.topbar [data-action="submit"],
.topbar .hbtn-sp,
.topbar .btn.sp,
.topbar .btn.ok,
.topbar button[onclick*="submitForm"],
.topbar button[onclick*="submitToSP"],
.vessel-hdr > .submit-btn {
  display: none !important;
}
.btn.ok,
.btn.primary,
.btn.sp,
.tbtn.ok,
.hbtn-sp {
  background: var(--ok, var(--fleet-ok)) !important;
  border-color: var(--ok, var(--fleet-ok)) !important;
  color: #fff !important;
}
.btn.ok:hover,
.btn.primary:hover,
.btn.sp:hover,
.tbtn.ok:hover,
.hbtn-sp:hover {
  background: #126b34 !important;
  border-color: #126b34 !important;
}
.btn::before,
.top-btn::before,
.hbtn::before {
  display: inline-flex;
  width: 14px;
  height: 14px;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  opacity: .9;
}
[data-action="upload"]::before { content: "UP"; font-size: 8px; }
[data-action="download"]::before,
[data-action="export"]::before { content: "DN"; font-size: 8px; }
[data-action="pdf"]::before { content: "PDF"; font-size: 8px; width: 20px; }
[data-action="submit"]::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
[data-action="next"]::before { content: "+"; font-size: 14px; }
[data-action="folder"]::before { content: "OD"; font-size: 8px; width: 18px; }
[data-action="back"]::before { content: "<"; font-size: 12px; }
[data-action="print"]::before { content: "PR"; font-size: 8px; }
[data-action="save"]::before { content: "SV"; font-size: 8px; }

/* Do not duplicate button labels with generated text badges. */
.btn::before,
.top-btn::before,
.hbtn::before,
.tbtn::before {
  display: none !important;
  content: none !important;
}

/* Modals */
.modal,
.dialog,
[role="dialog"] {
  border-radius: 12px !important;
}
.modal-h,
.modal-header {
  background: var(--navy, var(--fleet-navy)) !important;
}

/* Print: reports only, no app chrome. */
@media print {
  .topbar,
  .breadcrumb,
  .tabs-bar,
  .bottom-bar,
  .submit-bar,
  .action-bar,
  .info-note,
  .kpi-row,
  .kpis,
  .success-banner,
  .vessel-hdr,
  .controls {
    display: none !important;
  }
  body {
    background: #fff !important;
  }
}

@media (max-width: 900px) {
  .vessel-hdr,
  .controls,
  .form-header,
  .bottom-bar,
  .submit-bar {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
  .bb-right,
  .action-group {
    width: 100% !important;
    justify-content: flex-start !important;
  }
  .btn,
  .top-btn {
    min-height: 34px !important;
  }
}

#topLogo {
  color: transparent !important;
  font-size: 0 !important;
  background: #08294d url("favicon.svg") center / 32px 32px no-repeat !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  border-radius: 8px !important;
}
