/* ═══════════════════════════════════════════
   components.css — FleetOS v4
═══════════════════════════════════════════ */

/* ── BUTTONS ─────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  padding:9px 18px; border-radius:var(--radius-sm); border:none;
  font-family:var(--font-sans); font-size:13px; font-weight:500;
  cursor:pointer; transition:all var(--transition); white-space:nowrap;
}
.btn:disabled { opacity:0.42; cursor:not-allowed; }
.btn-primary {
  background:linear-gradient(135deg, var(--primary), var(--primary-d));
  color:#fff; font-weight:600;
}
.btn-primary:hover:not(:disabled) {
  transform:translateY(-1px);
  box-shadow:0 6px 20px rgba(99,102,241,0.35);
}
.btn-secondary {
  background:var(--glass); border:1px solid var(--border); color:var(--text-2);
}
.btn-secondary:hover:not(:disabled) { background:var(--glass-h); color:var(--text); border-color:var(--border-m); }
.btn-danger { background:var(--danger-bg); border:1px solid var(--danger-bd); color:var(--danger); }
.btn-danger:hover:not(:disabled) { background:rgba(239,68,68,0.2); }
.btn-ghost { background:transparent; color:var(--muted); padding:6px 10px; }
.btn-ghost:hover { color:var(--text); background:var(--glass); }
.btn-icon {
  width:34px; height:34px; padding:0; border-radius:var(--radius-sm);
  background:var(--glass); border:1px solid var(--border); color:var(--text-2);
  font-size:15px; display:inline-flex; align-items:center; justify-content:center;
}
.btn-icon:hover { background:var(--glass-h); color:var(--primary); border-color:var(--border-m); }
.btn-full { width:100%; }
.btn-sm { padding:6px 12px; font-size:12px; }
.btn-lg { padding:12px 24px; font-size:15px; font-weight:600; }

/* ── FIELD ───────────────────────────── */
.field { margin-bottom:14px; }
.field-row { display:grid; gap:14px; }
.field-row.cols-2 { grid-template-columns:1fr 1fr; }
.field-row.cols-3 { grid-template-columns:1fr 1fr 1fr; }
.field-hint { font-size:11px; color:var(--muted); margin-top:4px; }

/* ── CARD ────────────────────────────── */
.card {
  background:var(--bg2);
  border:1px solid var(--border-s);
  border-radius:var(--radius-lg);
}
.card-sm { border-radius:var(--radius); }
.card-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:15px 20px; border-bottom:1px solid var(--border-s);
}
.card-title { font-family:var(--font-display); font-size:13.5px; font-weight:600; color:var(--text); }
.card-body { padding:18px 20px; }

/* ── PAGE HEADER ─────────────────────── */
.page-header {
  display:flex; align-items:center; gap:12px;
  padding:20px 24px 16px;
  border-bottom:1px solid var(--border-s);
  flex-shrink:0; background:var(--bg);
}
.page-title { font-family:var(--font-display); font-size:18px; font-weight:600; letter-spacing:-0.2px; color:var(--text); }
.page-sub { font-size:12px; color:var(--muted); margin-top:3px; }
.page-actions { margin-left:auto; display:flex; gap:8px; align-items:center; }

/* ── SEARCH BOX ──────────────────────── */
.search-wrap { position:relative; }
.search-wrap input { padding-left:34px; }
.search-wrap .search-icon {
  position:absolute; left:11px; top:50%; transform:translateY(-50%);
  color:var(--muted); font-size:14px; pointer-events:none;
}

/* ── TABLE ───────────────────────────── */
.table-wrap { overflow-x:auto; }
table.data-table { width:100%; border-collapse:collapse; }
.data-table thead th {
  padding:10px 16px; text-align:left;
  font-size:10px; letter-spacing:1.4px; text-transform:uppercase;
  color:var(--muted); font-weight:600;
  background:var(--bg3);
  border-bottom:1px solid var(--border-s);
  white-space:nowrap;
}
.data-table tbody td {
  padding:13px 16px; font-size:13.5px;
  border-bottom:1px solid var(--border-s);
  vertical-align:middle; color:var(--text);
}
.data-table tbody tr:last-child td { border-bottom:none; }
.data-table tbody tr:hover td { background:var(--bg-hover); }
.data-table .td-mono { font-family:var(--font-mono); font-size:12px; color:var(--text-2); }
.data-table .td-actions { display:flex; gap:6px; justify-content:flex-end; }

/* ── BADGE / STATUS ──────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px; border-radius:20px;
  font-size:11.5px; font-weight:500; white-space:nowrap;
}
.badge-online  { background:var(--success-bg); color:var(--online);  border:1px solid var(--success-bd); }
.badge-idle    { background:var(--warn-bg);    color:var(--idle);    border:1px solid var(--warn-bd); }
.badge-offline { background:var(--danger-bg);  color:var(--offline); border:1px solid var(--danger-bd); }
.badge-admin   { background:var(--primary-l);  color:var(--primary); border:1px solid var(--primary-bd); }
.badge-user    { background:var(--glass);      color:var(--muted);   border:1px solid var(--border); }
.badge-active  { background:var(--success-bg); color:var(--success); }
.badge-dot::before { content:''; width:6px; height:6px; border-radius:50%; background:currentColor; }

/* ── STATUS DOT ──────────────────────── */
.status-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.status-dot.online  { background:var(--online);  box-shadow:0 0 6px var(--online); }
.status-dot.idle    { background:var(--idle);    box-shadow:0 0 6px var(--idle); }
.status-dot.offline { background:var(--offline); }

/* ── MODAL ───────────────────────────── */
.modal-overlay {
  position:fixed; inset:0; z-index:8000;
  background:rgba(0,0,0,0.55); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity 0.2s;
}
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal-box {
  background:var(--bg2); border:1px solid var(--border-m);
  border-radius:var(--radius-xl); width:520px; max-width:calc(100vw - 32px);
  max-height:90vh; display:flex; flex-direction:column;
  transform:translateY(16px) scale(0.98); transition:transform 0.22s cubic-bezier(0.2,0,0,1);
  box-shadow:var(--shadow);
}
.modal-overlay.open .modal-box { transform:translateY(0) scale(1); }
.modal-box.modal-lg { width:840px; }
.modal-box.modal-sm { width:380px; }
.modal-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 24px 16px; border-bottom:1px solid var(--border-s); flex-shrink:0;
}
.modal-title { font-family:var(--font-display); font-size:15px; font-weight:600; }
.modal-close {
  width:28px; height:28px; border-radius:var(--radius-sm);
  background:var(--glass); border:1px solid var(--border); color:var(--muted);
  font-size:18px; cursor:pointer; transition:all var(--transition);
  display:flex; align-items:center; justify-content:center; line-height:1;
}
.modal-close:hover { background:var(--danger-bg); color:var(--danger); border-color:var(--danger-bd); }
.modal-body { padding:20px 24px; overflow-y:auto; flex:1; }
.modal-footer { padding:14px 24px; border-top:1px solid var(--border-s); display:flex; justify-content:flex-end; gap:8px; flex-shrink:0; }

/* ── TOAST ───────────────────────────── */
#toast-wrap {
  position:fixed; bottom:24px; left:50%;
  transform:translateX(-50%); z-index:9999;
  display:flex; flex-direction:column; gap:8px; align-items:center;
}
.toast {
  background:var(--bg3); border:1px solid var(--border-m);
  border-radius:var(--radius); padding:11px 20px;
  font-size:13px; display:flex; align-items:center; gap:10px;
  box-shadow:var(--shadow-s); white-space:nowrap;
  animation:toastIn 0.22s cubic-bezier(0.2,0,0,1);
  min-width:260px;
}
.toast.toast-success { border-color:var(--success-bd); }
.toast.toast-error   { border-color:var(--danger-bd); }
.toast.toast-warn    { border-color:var(--warn-bd); }
@keyframes toastIn {
  from { opacity:0; transform:translateY(10px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── STAT CARD ───────────────────────── */
.stat-card {
  background:var(--bg2); border:1px solid var(--border-s);
  border-radius:var(--radius-lg); padding:18px 20px;
  transition:border-color var(--transition);
}
.stat-card:hover { border-color:var(--border-m); }
.stat-label { font-size:10px; letter-spacing:1.3px; text-transform:uppercase; color:var(--muted); }
.stat-value { font-family:var(--font-display); font-size:24px; font-weight:600; line-height:1.2; margin-top:4px; }
.stat-sub   { font-size:11px; color:var(--muted); margin-top:3px; }

/* KPI card — minimal, number-forward */
.kpi-card-v {
  background:var(--bg2); border:1px solid var(--border-s);
  border-radius:var(--radius); padding:14px 18px;
  display:flex; flex-direction:column; gap:2px;
  transition:border-color var(--transition);
  position:relative; overflow:hidden;
}
.kpi-card-v:hover { border-color:var(--border-m); }

/* Thin left accent bar, colored per status */
.kpi-card-v::before {
  content:''; position:absolute; left:0; top:14%; bottom:14%;
  width:3px; border-radius:0 2px 2px 0;
  background:var(--border-s); transition:background var(--transition);
}
.kpi-card-v:hover::before { background:var(--primary); }
.kpi-card-v.kpi-online::before  { background:var(--success); }
.kpi-card-v.kpi-idle::before    { background:var(--warn); }
.kpi-card-v.kpi-offline::before { background:var(--danger); }
.kpi-card-v.kpi-total::before   { background:var(--primary); }

.kpi-card-top {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:6px;
}
.kpi-card-label {
  font-size:10.5px; font-weight:500; letter-spacing:0.3px;
  color:var(--muted); text-transform:uppercase;
}
.kpi-card-trend {
  display:flex; align-items:center; gap:3px;
  font-size:11px; font-weight:500; font-family:var(--font-mono);
  color:var(--muted);
}
.kpi-card-trend.up   { color:var(--success); }
.kpi-card-trend.down { color:var(--danger); }
.kpi-card-value {
  font-size:28px; font-weight:600; line-height:1;
  letter-spacing:-0.5px; color:var(--text);
  font-variant-numeric:tabular-nums;
}

/* ── NOTE BOX ────────────────────────── */
.note {
  display:flex; gap:10px; align-items:flex-start;
  padding:11px 14px; border-radius:var(--radius-sm); font-size:13px;
  background:var(--info-bg); border:1px solid var(--info-bd); color:var(--text-2);
}
.note-icon { flex-shrink:0; font-size:15px; margin-top:1px; }
.note.note-warn    { background:var(--warn-bg);    border-color:var(--warn-bd); }
.note.note-success { background:var(--success-bg); border-color:var(--success-bd); }
.note.note-danger  { background:var(--danger-bg);  border-color:var(--danger-bd); }

/* ── PROGRESS BAR ────────────────────── */
.progress-bar-row { margin-bottom:10px; }
.progress-label-row { display:flex; justify-content:space-between; font-size:11px; color:var(--muted); margin-bottom:5px; }
.progress-track { height:5px; background:var(--glass-h); border-radius:4px; overflow:hidden; }
.progress-fill {
  height:100%; border-radius:4px;
  background:linear-gradient(90deg, var(--primary), #818cf8);
  transition:width 0.5s ease;
}

/* ── TABS ────────────────────────────── */
.tab-bar {
  display:flex; gap:2px;
  padding:4px; background:var(--bg3);
  border-radius:var(--radius-sm); border:1px solid var(--border-s);
  width:fit-content;
}
.tab-btn {
  padding:6px 16px; border-radius:6px; border:none;
  background:transparent; color:var(--muted); font-size:12.5px;
  cursor:pointer; transition:all var(--transition); font-family:var(--font-sans);
}
.tab-btn.active { background:var(--bg2); color:var(--text); font-weight:500; box-shadow:var(--shadow-s); }
.tab-btn:hover:not(.active) { color:var(--text-2); }

/* ── EMPTY STATE ─────────────────────── */
.empty-state {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:12px; padding:60px 24px;
  color:var(--muted); text-align:center;
}
.empty-state .empty-icon { font-size:48px; opacity:0.3; }
.empty-state .empty-title { font-size:15px; font-weight:500; color:var(--text-2); }
.empty-state .empty-sub   { font-size:13px; max-width:320px; line-height:1.6; }

/* ── CONFIRM DIALOG ──────────────────── */
.confirm-text { font-size:14px; color:var(--muted); line-height:1.65; margin-bottom:4px; }

/* ── COLOR SWATCH ────────────────────── */
.color-swatch { width:22px; height:22px; border-radius:6px; border:2px solid var(--border-m); display:inline-block; flex-shrink:0; }

/* ── TOGGLE ──────────────────────────── */
.toggle-wrap { display:flex; align-items:center; gap:10px; }
.toggle {
  width:40px; height:22px; background:var(--glass-h);
  border-radius:11px; cursor:pointer; position:relative; transition:background 0.2s;
  border:1px solid var(--border); flex-shrink:0;
}
.toggle.on { background:var(--primary); border-color:var(--primary); }
.toggle::after {
  content:''; position:absolute; top:2px; left:2px;
  width:16px; height:16px; background:#fff; border-radius:50%;
  transition:left 0.2s; box-shadow:0 1px 4px rgba(0,0,0,0.3);
}
.toggle.on::after { left:20px; }

/* ── LEAFLET OVERRIDES ───────────────── */
.leaflet-container { background:var(--bg3) !important; }
.leaflet-tooltip {
  background:var(--bg3) !important; border:1px solid var(--border-m) !important;
  color:var(--text) !important; border-radius:var(--radius-sm) !important;
  font-family:var(--font-sans) !important; font-size:12px !important;
  padding:6px 10px !important; box-shadow:var(--shadow-s) !important;
}
.leaflet-popup-content-wrapper {
  background:var(--bg2) !important; border:1px solid var(--border-m) !important;
  border-radius:var(--radius) !important; color:var(--text) !important;
  box-shadow:var(--shadow) !important;
}
.leaflet-popup-tip { background:var(--bg2) !important; }
.leaflet-control-zoom a {
  background:var(--bg2) !important; color:var(--text-2) !important;
  border-color:var(--border-m) !important;
}
.leaflet-control-zoom a:hover { color:var(--primary) !important; background:var(--bg3) !important; }

/* ── MULTI-SELECT DROPDOWN ──────────────── */
.multiselect-dropdown {
  position: relative;
  width: 100%;
}
.multiselect-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 13px;
  color: var(--text);
  min-height: 38px;
  user-select: none;
  transition: border-color var(--transition);
}
.multiselect-header:hover {
  border-color: var(--border-m);
}
.multiselect-header::after {
  content: '▼';
  font-size: 9px;
  color: var(--muted);
  transition: transform var(--transition);
}
.multiselect-dropdown.open .multiselect-header::after {
  transform: rotate(180deg);
}
.multiselect-body {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 8500;
  background: var(--bg2);
  border: 1px solid var(--border-m);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 8px;
  max-height: 320px;
  flex-direction: column;
  gap: 8px;
}
.multiselect-dropdown.open .multiselect-body {
  display: flex;
}
.multiselect-search-wrap {
  position: relative;
}
.multiselect-search {
  width: 100%;
  padding: 8px 12px;
  font-size: 12.5px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg3);
  color: var(--text);
}
.multiselect-search:focus {
  border-color: var(--primary);
  outline: none;
}
.multiselect-list {
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 2px;
}
.multiselect-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: 13.5px;
  color: var(--text);
  transition: background var(--transition);
  user-select: none;
}
.multiselect-item:hover {
  background: var(--bg-hover);
}
.multiselect-item input[type="checkbox"] {
  width: auto;
  margin: 0;
  cursor: pointer;
}

/* ── MULTISELECT DROPDOWN (permissions modal) ── */
.multiselect-dropdown {
  position: relative;
  width: 100%;
}
.multiselect-header {
  padding: 9px 12px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  user-select: none;
  transition: border-color var(--transition);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.multiselect-header:hover { border-color: var(--border-m); }
.multiselect-dropdown.open .multiselect-header {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-l);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}
.multiselect-body {
  display: none;
  position: absolute;
  top: 100%; left: 0; right: 0;
  background: var(--bg2);
  border: 1px solid var(--primary);
  border-top: none;
  border-radius: 0 0 var(--radius-sm) var(--radius-sm);
  box-shadow: var(--shadow);
  z-index: 500;
  max-height: 220px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.multiselect-dropdown:not(.open) .multiselect-body { display: none !important; }
.multiselect-dropdown.open .multiselect-body { display: flex; }
.multiselect-search-wrap { padding: 7px 8px; border-bottom: 1px solid var(--border-s); flex-shrink: 0; }
.multiselect-search {
  width: 100%; padding: 6px 10px; font-size: 12px;
  background: var(--bg3); border: 1px solid var(--border-s);
  border-radius: 5px; color: var(--text);
}
.multiselect-list { overflow-y: auto; flex: 1; }
.multiselect-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; cursor: pointer; font-size: 13px; color: var(--text);
  transition: background var(--transition);
}
.multiselect-item:hover { background: var(--bg-hover); }
.multiselect-item input[type="checkbox"] { width: auto; flex-shrink: 0; accent-color: var(--primary); }

/* ── DRIVERS LIST ─────────────────────── */
.drivers-list { display: flex; flex-direction: column; gap: 2px; }
.driver-row {
  display: flex; align-items: center; gap: 14px;
  padding: 13px 16px; cursor: pointer;
  border-bottom: 1px solid var(--border-s);
  transition: background var(--transition);
}
.driver-row:hover { background: var(--bg-hover); }
.driver-avatar {
  width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 700; color: #fff;
}
.driver-info { flex: 1; min-width: 0; }
.driver-name { font-size: 13.5px; font-weight: 500; color: var(--text); }
.driver-meta { font-size: 11px; color: var(--muted); margin-top: 2px; }
.driver-score-wrap { text-align: right; flex-shrink: 0; }
.driver-score { font-size: 22px; font-weight: 700; line-height: 1; }
.driver-score-lbl { font-size: 9.5px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.8px; margin-top: 2px; }
.score-bar { width: 60px; height: 4px; background: var(--muted3, var(--glass-h)); border-radius: 3px; overflow: hidden; margin-top: 5px; }
.score-fill { height: 100%; border-radius: 3px; transition: width 0.4s ease; }

/* ── SETTINGS SECTION HEADER (was settings-section-title) ── */
.settings-section-header {
  padding: 14px 20px;
  border-bottom: 1px solid var(--border-s);
  font-family: var(--font-display);
  font-size: 13.5px; font-weight: 600;
  display: flex; align-items: center; gap: 9px;
  color: var(--text);
}
