/* Driver web app — single-column mobile page, no shell */
@layer screens {
  .driver-app { background: var(--bg); }
  .driver-main { max-width: 560px; margin: 0 auto; padding: 12px 12px 40px; }

  .drv-head {
    display: flex; justify-content: space-between; align-items: flex-start; gap: 10px;
    background: var(--rail); color: #fff;
    margin: -12px -12px 12px; padding: 14px 14px 12px;
  }
  .drv-title { font-size: 16px; font-weight: 700; }
  .drv-sub { font-size: 12px; opacity: 0.85; margin-top: 2px; }

  .drv-stop {
    background: var(--surface); border: 1px solid var(--line);
    border-radius: var(--r-lg); padding: 12px; margin-bottom: 10px;
    box-shadow: var(--shadow-card);
  }
  .drv-stop.current { border-color: var(--primary); border-width: 2px; }
  .drv-stop.stage-done, .drv-stop.stage-failed { opacity: 0.65; }
  .drv-stop-head { display: flex; justify-content: space-between; gap: 8px; align-items: baseline; }
  .drv-stop-meta { font-size: 12.5px; color: var(--text-2); margin: 4px 0 8px; }
  .drv-actions { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
  .drv-pod-form { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; }
  .drv-pod-form input[type="file"] { max-width: 200px; font-size: 12px; }
  .drv-fail-form { display: flex; gap: 6px; align-items: center; }
  .drv-fail-form input[type="text"] { width: 150px; }
  .drv-chips { display: flex; flex-wrap: wrap; gap: 5px; width: 100%; }
  .drv-foot { text-align: center; color: var(--muted); font-size: 12px; margin-top: 18px; }
}

/* Driver route progress + all-done banner */
@layer screens {
  .drv-progress { display: flex; align-items: center; gap: 10px; margin: -4px 0 12px; }
  .drv-progress-bar { flex: 1; height: 8px; border-radius: 999px; background: var(--surface-3); overflow: hidden; }
  .drv-progress-fill { height: 100%; background: var(--ok); transition: width .25s; }
  .drv-progress-label { font-size: 12px; font-weight: 700; color: var(--text-2); white-space: nowrap; }
  .drv-alldone { background: var(--ok-bg); color: var(--ok-fg); border-radius: var(--r-md); padding: 12px; text-align: center; font-weight: 700; margin-bottom: 12px; }
}
