:root {
  --primary: #386193;
  --primary-light: #4a7ab5;
  --accent: #2ecc71;
  --danger: #e74c3c;
  --warning: #f39c12;
  --bg: #f8f9fa;
  --card: #ffffff;
  --text: #333;
  --text-light: #666;
  --border: #ddd;
  --radius: 8px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.5;
}

/* Header - matches NeneForms */
#mast { background: #386193; padding: 10px 20px; display: flex; justify-content: space-between; align-items: center; box-shadow: 0 2px 4px rgba(0,0,0,.1); flex-shrink: 0; }
#mast img { max-width: 100%; height: 60px; }
.user-bar { display: flex; align-items: center; gap: 12px; margin-left: auto; }
.user-email { color: rgba(255,255,255,0.85); font-size: 0.85em; }
.logout-btn { background: rgba(255,255,255,0.15); border: 1px solid rgba(255,255,255,0.4); color: #fff; padding: 5px 14px; border-radius: 20px; cursor: pointer; font-size: 0.8em; transition: all 0.2s ease; }
.logout-btn:hover { background: rgba(255,255,255,0.3); border-color: rgba(255,255,255,0.7); }
.theme-toggle { background: none; border: none; cursor: pointer; font-size: 1.2em; padding: 0 4px; line-height: 1; }
.theme-toggle:hover { opacity: 0.7; }

main { max-width: 800px; margin: 32px auto; padding: 0 24px; }

.step { display: none; background: var(--card); border-radius: var(--radius); padding: 32px; box-shadow: 0 1px 4px rgba(0,0,0,0.08); }
.step.active { display: block; }

h2 { color: var(--primary); margin-bottom: 8px; }
.subtitle { color: var(--text-light); margin-bottom: 20px; }

.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-weight: 600; margin-bottom: 4px; font-size: 0.9rem; }
.form-group input, .form-group textarea, .form-group select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.95rem;
  font-family: inherit;
}
.form-group textarea { resize: vertical; }
.form-group input:focus, .form-group textarea:focus { outline: none; border-color: var(--primary-light); box-shadow: 0 0 0 2px rgba(56,97,147,0.15); }

.btn-primary {
  background: var(--primary);
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: var(--radius);
  font-size: 1rem;
  cursor: pointer;
  font-weight: 600;
}
.btn-primary:hover { background: var(--primary-light); }
.btn-primary:disabled { background: #aaa; cursor: not-allowed; }

.btn-secondary {
  background: white;
  color: var(--primary);
  border: 2px solid var(--primary);
  padding: 10px 22px;
  border-radius: var(--radius);
  font-size: 1rem;
  cursor: pointer;
  font-weight: 600;
}
.btn-secondary:hover { background: #f0f4f8; }

/* Consent */
.consent-box { background: #f0f7ff; border: 1px solid #b8d4f0; border-radius: var(--radius); padding: 20px; margin: 16px 0; }
.consent-box p { margin-bottom: 8px; }
.consent-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 16px; }

/* Recording */
.recording-controls { text-align: center; padding: 24px 0; }
#recording-status { font-size: 1.1rem; font-weight: 600; margin-bottom: 8px; }
#recording-timer { font-size: 2.5rem; font-weight: 700; font-family: 'Courier New', monospace; margin: 16px 0; }
.status-idle { color: var(--text-light); }
.status-recording { color: var(--danger); }
.status-paused { color: var(--warning); }
.controls { display: flex; gap: 12px; justify-content: center; margin: 20px 0; }
.btn-record { background: var(--danger); color: white; border: none; padding: 12px 24px; border-radius: var(--radius); font-size: 1rem; cursor: pointer; font-weight: 600; }
.btn-pause { background: var(--warning); color: white; border: none; padding: 12px 24px; border-radius: var(--radius); font-size: 1rem; cursor: pointer; font-weight: 600; }
.btn-stop { background: #555; color: white; border: none; padding: 12px 24px; border-radius: var(--radius); font-size: 1rem; cursor: pointer; font-weight: 600; }
.btn-record:disabled, .btn-pause:disabled, .btn-stop:disabled { opacity: 0.4; cursor: not-allowed; }
.recording-hint { color: var(--text-light); font-size: 0.85rem; margin-top: 12px; }

/* Processing */
.processing-status { text-align: center; padding: 40px 0; }
.spinner { width: 48px; height: 48px; border: 4px solid var(--border); border-top-color: var(--primary); border-radius: 50%; animation: spin 1s linear infinite; margin: 0 auto 16px; }
@keyframes spin { to { transform: rotate(360deg); } }
.progress-steps { display: flex; justify-content: center; gap: 8px; margin-top: 20px; }
.ps-step { padding: 6px 12px; border-radius: 4px; background: #eee; font-size: 0.8rem; }
.ps-step.active { background: var(--primary); color: white; }
.ps-step.done { background: var(--accent); color: white; }

/* Review */
.confirm-box { background: #f0f7ff; border: 1px solid #b8d4f0; border-radius: var(--radius); padding: 16px; margin: 20px 0; }
.checkbox-label { display: flex; align-items: center; gap: 8px; cursor: pointer; font-weight: 600; }
.checkbox-label input { width: 18px; height: 18px; }

/* Done */
.done-box { text-align: center; padding: 24px 0; }
.done-box p { font-size: 1.1rem; margin-bottom: 20px; color: var(--accent); font-weight: 600; }
.done-box button { margin: 0 8px; }

/* Previous sessions */
#previous-sessions { margin-top: 32px; border-top: 1px solid var(--border); padding-top: 20px; }
#previous-sessions h3 { margin-bottom: 12px; }
.session-item { display: flex; justify-content: space-between; align-items: center; padding: 12px; border: 1px solid var(--border); border-radius: var(--radius); margin-bottom: 8px; cursor: pointer; }
.session-item:hover { background: #f0f4f8; }
.session-item .name { font-weight: 600; }
.session-item .date { color: var(--text-light); font-size: 0.85rem; }
.session-item .status-badge { font-size: 0.75rem; padding: 2px 8px; border-radius: 10px; font-weight: 600; }
.status-finalised { background: #d4edda; color: #155724; }
.status-review { background: #fff3cd; color: #856404; }
.status-created { background: #e2e3e5; color: #383d41; }


/* Dark Mode */
[data-theme="dark"] { color-scheme: dark; }
[data-theme="dark"] body, [data-theme="dark"] html { background: #0d1117; color: #e6edf3; }
[data-theme="dark"] .step { background: #161b22; border-color: #30363d; box-shadow: 0 1px 4px rgba(0,0,0,0.3); }
[data-theme="dark"] h2 { color: #58a6ff; }
[data-theme="dark"] .subtitle { color: #8b949e; }
[data-theme="dark"] .form-group label { color: #e6edf3; }
[data-theme="dark"] .form-group input,
[data-theme="dark"] .form-group textarea,
[data-theme="dark"] .form-group select { background: #0d1117; border-color: #30363d; color: #e6edf3; }
[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group textarea:focus { border-color: #58a6ff; box-shadow: 0 0 0 2px rgba(88,166,255,0.15); }
[data-theme="dark"] .btn-primary { background: #238636; }
[data-theme="dark"] .btn-primary:hover { background: #2ea043; }
[data-theme="dark"] .btn-secondary { background: #161b22; color: #58a6ff; border-color: #30363d; }
[data-theme="dark"] .btn-secondary:hover { background: #1c2128; border-color: #58a6ff; }
[data-theme="dark"] .consent-box { background: #1c2128; border-color: #30363d; }
[data-theme="dark"] .confirm-box { background: #1c2128; border-color: #30363d; }
[data-theme="dark"] .recording-hint { color: #8b949e; }
[data-theme="dark"] #recording-timer { color: #e6edf3; }
[data-theme="dark"] .ps-step { background: #21262d; color: #8b949e; }
[data-theme="dark"] .session-item { border-color: #30363d; color: #e6edf3; }
[data-theme="dark"] .session-item:hover { border-color: #58a6ff; background: #1c2128; }
[data-theme="dark"] .session-item .date { color: #8b949e; }
[data-theme="dark"] #previous-sessions { border-color: #30363d; }
[data-theme="dark"] .done-box p { color: #3fb950; }
