/* Driver view — 2-column layout, dense info */
body.driver { background: var(--surface); padding: 0; }
body.driver main { max-width: 1400px; margin: 0 auto; padding: var(--space-4); }

.driver-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--space-3) var(--space-4);
  background: var(--surface-2);
  border-radius: var(--radius-sm);
  margin-bottom: var(--space-4);
  border: 1px solid var(--line);
}
.driver-title { font-family: var(--font-mono); font-size: 0.9rem; color: var(--coral); }
.timer-display {
  font-family: var(--font-mono); font-size: 2.5rem; font-weight: 700;
  font-variant-numeric: tabular-nums;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-sm);
  background: var(--surface-3);
  transition: background 0.3s, color 0.3s;
}
.timer-display.green  { color: var(--success); }
.timer-display.yellow { color: var(--amber); }
.timer-display.red    { color: var(--critical); animation: pulse 1s infinite; }
.timer-display.over   { color: var(--critical); background: #FFF5F8; }
@keyframes pulse { 50% { opacity: 0.6; } }

.timer-label {
  font-size: 1.1rem; color: var(--ink-dim);
  margin-right: var(--space-6);
}

.net-indicator {
  display: inline-block; width: 10px; height: 10px; border-radius: 50%;
  background: var(--ink-mute); margin-left: var(--space-3);
}
.net-indicator.ok  { background: var(--success); }
.net-indicator.bad { background: var(--critical); animation: pulse 1s infinite; }

.driver-grid {
  display: grid; grid-template-columns: 320px 1fr 320px;
  gap: var(--space-4);
}
@media (max-width: 1100px) {
  .driver-grid { grid-template-columns: 1fr; }
}

.driver-col { background: var(--surface-2); border: 1px solid var(--line); border-radius: var(--radius-sm); padding: var(--space-4); }
.driver-col h3 { margin-top: 0; font-size: 0.85rem; color: var(--coral); text-transform: uppercase; letter-spacing: 0.1em; }

#steps-list { list-style: none; }
#steps-list li {
  padding: var(--space-2) 0; border-bottom: 1px solid var(--line-soft);
  display: flex; align-items: center; gap: var(--space-2);
  font-size: 0.9rem;
}
#steps-list li.active { color: var(--coral); font-weight: 600; }
#steps-list li.done { color: var(--ink-mute); }
#steps-list li.done .icon { color: var(--success); }
#steps-list .icon { width: 18px; text-align: center; }
#steps-list .dur { margin-left: auto; font-family: var(--font-mono); color: var(--ink-mute); font-size: 0.75rem; }

.prompt-card {
  background: var(--surface-3); border: 1px solid var(--line);
  border-radius: var(--radius-sm); padding: var(--space-3);
  margin-bottom: var(--space-3);
}
.prompt-card .head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: var(--space-2);
}
.prompt-card .head strong { font-family: var(--font-mono); font-size: 0.8rem; color: var(--coral); }
.prompt-card pre { margin: 0; font-size: 0.8rem; white-space: pre-wrap; }

.copy-btn, .fallback-btn {
  padding: 4px 10px; font-size: 0.75rem; border-radius: 3px;
  background: var(--coral); color: #FFFFFF; border: none; cursor: pointer;
}
.copy-btn.flash { background: var(--success); color: #FFFFFF; }
.fallback-btn { background: var(--amber); color: #FFFFFF; margin-right: var(--space-1); }
.fallback-btn.critical { background: var(--critical); color: #FFFFFF; }

.driver-controls {
  display: flex; gap: var(--space-2); margin-top: var(--space-4);
  flex-wrap: wrap;
}
.driver-controls button {
  flex: 1; min-width: 80px;
  padding: var(--space-2) var(--space-3);
  background: var(--surface-3); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  cursor: pointer; font-size: 0.9rem;
}
.driver-controls button:hover { border-color: var(--coral); }

#session-notes {
  width: 100%; min-height: 120px;
  background: var(--surface-3); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: var(--space-2); font-family: var(--font-sans); font-size: 0.9rem;
  resize: vertical;
}
