.driver-shell {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
  max-width: 480px;
  margin: 0 auto;
}

/* Login screen */
.login-page {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100dvh;
  padding: var(--s8) var(--s6);
  gap: var(--s8);
}

.login-logo {
  text-align: center;
}
.login-logo .wordmark {
  font-family: var(--font-display);
  font-size: 64px;
  line-height: 1;
  color: var(--accent);
  letter-spacing: 0.04em;
}
.login-logo .tagline {
  font-family: var(--font-label);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-top: var(--s2);
}

.login-form {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--s4);
}

.login-form .btn-primary {
  width: 100%;
  padding: var(--s4);
  font-size: 16px;
  margin-top: var(--s2);
  border-radius: var(--r2);
}

/* Tracking screen */
.track-header {
  background: var(--surface);
  padding: var(--s4) var(--s4) var(--s3);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid var(--border-dim);
}

.track-id {
  font-family: var(--font-display);
  font-size: 42px;
  line-height: 1;
  color: var(--text);
  letter-spacing: 0.02em;
}

.login-divider {
  height: 1px;
  background: var(--border-dim);
  margin: var(--s2) 0;
}

.track-mobile {
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: 0.06em;
  color: var(--text-faint);
  margin-top: 1px;
}

.track-officer {
  font-family: var(--font-label);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-top: 2px;
}

/* Status indicator */
.status-band {
  padding: var(--s3) var(--s4);
  background: var(--surface);
  display: flex;
  align-items: center;
  gap: var(--s3);
}

.pulse-ring {
  position: relative;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}
.pulse-ring .dot {
  position: absolute;
  inset: 50%;
  transform: translate(-50%, -50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--online);
}
.pulse-ring .ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid var(--online);
  animation: pulse 2s ease-out infinite;
  opacity: 0;
}
.pulse-ring.inactive .dot { background: var(--text-faint); }
.pulse-ring.inactive .ring { border-color: var(--text-faint); animation: none; }
.pulse-ring.error .dot   { background: var(--offline); }
.pulse-ring.error .ring  { border-color: var(--offline); }

@keyframes pulse {
  0%   { transform: scale(0.6); opacity: 0.8; }
  100% { transform: scale(1.8); opacity: 0; }
}

.status-text .label {
  font-family: var(--font-label);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.status-text .label.online  { color: var(--online); }
.status-text .label.idle    { color: var(--text-faint); }
.status-text .label.error   { color: var(--offline); }

.status-text .sublabel {
  font-size: 12px;
  color: var(--text-faint);
  margin-top: 1px;
}

/* Ping countdown */
.ping-bar {
  padding: var(--s3) var(--s4);
  background: var(--bg);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--font-label);
  font-size: 11px;
  letter-spacing: 0.06em;
  color: var(--text-faint);
}
.ping-bar .countdown {
  font-size: 18px;
  font-family: var(--font-display);
  color: var(--text-dim);
}

/* Checkpoints section */
.checkpoints-section {
  flex: 1;
  padding: var(--s4);
  overflow-y: auto;
}

.section-title {
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-faint);
  margin-bottom: var(--s3);
}

.checkpoint-item {
  background: var(--surface);
  border-radius: var(--r2);
  padding: var(--s3) var(--s4);
  margin-bottom: var(--s2);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s3);
}

.checkpoint-item.nearby {
  background: var(--accent-dim);
  border: 1px solid var(--accent);
}

.checkpoint-item.confirmed {
  background: var(--online-bg);
  border: 1px solid var(--online);
}
.checkpoint-item.confirmed .cp-dist {
  color: var(--online);
}

.cp-confirmed-badge {
  font-family: var(--font-label);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--online);
  white-space: nowrap;
  flex-shrink: 0;
}

.cp-info .cp-name {
  font-family: var(--font-label);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.cp-info .cp-dist {
  font-size: 11px;
  color: var(--text-faint);
  margin-top: 2px;
}
.checkpoint-item.nearby .cp-info .cp-dist {
  color: var(--accent-hi);
}

.btn-confirm {
  font-family: var(--font-label);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--accent);
  color: var(--bg);
  border: none;
  border-radius: var(--r1);
  padding: var(--s2) var(--s3);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
}
.btn-confirm:hover { background: var(--accent-hi); }

.empty-checkpoints {
  text-align: center;
  padding: var(--s12) var(--s4);
  color: var(--text-faint);
  font-size: 13px;
}

/* Footer actions */
.track-footer {
  padding: var(--s4);
  border-top: 1px solid var(--border-dim);
  background: var(--surface);
}

.track-footer .btn-danger {
  width: 100%;
  padding: var(--s3);
  font-size: 13px;
  border-radius: var(--r1);
}

/* GPS blocked notice */
.gps-notice {
  background: var(--warn-bg);
  color: var(--warn);
  font-family: var(--font-label);
  font-size: 12px;
  letter-spacing: 0.04em;
  padding: var(--s2) var(--s4);
  text-align: center;
}

/* Background / screen-off warning banner */
.bg-banner {
  background: var(--warn-bg);
  color: var(--warn);
  font-family: var(--font-label);
  font-size: 11px;
  letter-spacing: 0.05em;
  text-align: center;
  padding: var(--s2) var(--s4);
  border-bottom: 1px solid var(--warn);
}

/* Wake lock indicator */
.wakelock-indicator {
  font-family: var(--font-label);
  font-size: 9px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.wakelock-indicator.wl-on  { color: var(--online); }
.wakelock-indicator.wl-off { color: var(--text-faint); }

/* PWA install button */
.btn-install {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-label);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background: var(--accent-dim);
  color: var(--accent-hi);
  border: none;
  border-radius: var(--r1);
  padding: 3px var(--s2);
  cursor: pointer;
  white-space: nowrap;
}
.btn-install:hover { background: var(--accent); color: var(--bg); }

/* Offline queue badge */
.queue-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--s1);
  background: var(--warn-bg);
  color: var(--warn);
  font-family: var(--font-label);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 2px var(--s2);
  border-radius: 10px;
}
