.form-shell .panel-body form label { display: block; font-size: 12px; font-weight: 600; color: var(--gray-400); margin: 14px 0 6px; }
.form-shell .panel-body form input,
.form-shell .panel-body form select,
.form-shell .panel-body form textarea {
  width: 100%; max-width: 520px; padding: 10px 12px; border-radius: var(--radius-sm);
  border: 1px solid var(--navy-border); background: var(--navy-card); color: var(--gray-200);
}
.wizard-steps { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.wizard-step { padding: 8px 14px; border-radius: var(--radius-sm); font-size: 12px; border: 1px solid var(--navy-border); color: var(--gray-500); }
.wizard-step.active { border-color: var(--teal); color: var(--teal); background: rgba(78,205,196,.08); }
.wizard-step.done { color: var(--gray-300); }
.route-leg-card { padding: 12px 14px; border: 1px solid var(--navy-border); border-radius: var(--radius-sm); margin-bottom: 10px; background: rgba(15,23,42,.35); }
.detail-tabs { display: flex; gap: 4px; flex-wrap: wrap; margin-bottom: 16px; border-bottom: 1px solid var(--navy-border); padding-bottom: 8px; }
.detail-tab { padding: 8px 14px; font-size: 13px; border: none; background: transparent; color: var(--gray-500); cursor: pointer; border-radius: var(--radius-sm) var(--radius-sm) 0 0; }
.detail-tab.active { color: var(--teal); border-bottom: 2px solid var(--teal); font-weight: 600; }
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; margin-bottom: 20px; }
.kpi-card { padding: 16px; border-radius: var(--radius); border: 1px solid var(--navy-border); background: var(--navy-card); }
.kpi-val { font-size: 26px; font-weight: 700; color: var(--gray-100); }
.kpi-lab { font-size: 11px; color: var(--gray-500); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.04em; }
.filter-bar { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 14px; align-items: flex-end; }
.filter-bar label { font-size: 11px; color: var(--gray-500); display: block; margin-bottom: 4px; }
.filter-bar select, .filter-bar input { padding: 8px 10px; border-radius: var(--radius-sm); border: 1px solid var(--navy-border); background: var(--navy-card); color: var(--gray-200); font-size: 12px; }

/* Structured wizard form layout */
#wizardBody { padding: 24px 28px; }
@media (max-width: 720px) { #wizardBody { padding: 18px 16px; } }

.vl-form-group { margin-bottom: 26px; }
.vl-form-group:last-child { margin-bottom: 6px; }
.vl-form-group-title {
  font-size: 12px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--teal); margin: 0 0 4px;
}
.vl-form-group-sub { font-size: 12px; color: var(--gray-500); margin: 0 0 16px; }
.vl-form-group-head {
  display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
  margin: 0 0 16px; padding-bottom: 8px; border-bottom: 1px solid var(--navy-border);
}
.vl-form-group-head .vl-form-group-title { margin: 0; }
.vl-form-group-head .vl-form-group-sub { margin: 0; }

.vl-grid { display: grid; gap: 16px 20px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.vl-grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 1100px) { .vl-grid, .vl-grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 720px) { .vl-grid, .vl-grid.cols-2 { grid-template-columns: 1fr; } }

.vl-field { display: flex; flex-direction: column; min-width: 0; }
.vl-field.span-2 { grid-column: span 2; }
.vl-field.span-full { grid-column: 1 / -1; }
@media (max-width: 720px) { .vl-field.span-2, .vl-field.span-full { grid-column: 1; } }
.vl-field label { font-size: 12px; font-weight: 600; color: var(--gray-400); margin: 0 0 6px; }
.vl-field input, .vl-field select, .vl-field textarea {
  width: 100%; padding: 10px 12px; border-radius: var(--radius-sm);
  border: 1px solid var(--navy-border); background: var(--navy-card); color: var(--gray-200);
  font-size: 13px; box-sizing: border-box;
}
.vl-field input:focus, .vl-field select:focus, .vl-field textarea:focus { outline: none; border-color: var(--teal); }

.vl-check-grid { display: grid; gap: 12px 20px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 720px) { .vl-check-grid { grid-template-columns: 1fr; } }
.vl-check {
  display: flex; align-items: center; gap: 10px; padding: 12px 14px;
  border: 1px solid var(--navy-border); border-radius: var(--radius-sm);
  background: rgba(15, 23, 42, 0.35); font-size: 13px; color: var(--gray-300); cursor: pointer;
}
.vl-check input { width: 16px; height: 16px; accent-color: var(--teal); cursor: pointer; }
