/* Styles for screens5.jsx — Command palette + Registration */

/* ===== Command palette (Cmd+K) ===== */
.cmdk-backdrop {
  position:fixed; inset:0; background:rgba(15,23,42,0.45); backdrop-filter:blur(4px);
  display:grid; place-items:flex-start center; padding-top:10vh; z-index:1000;
  animation:cmdk-bg-in .18s ease-out;
}
@keyframes cmdk-bg-in { from { opacity:0; } to { opacity:1; } }
.cmdk-panel {
  width:min(640px, 92vw); background:#fff; border-radius:14px; overflow:hidden;
  box-shadow:0 25px 60px rgba(15,23,42,0.35), 0 0 0 1px rgba(0,0,0,0.06);
  animation:cmdk-in .2s ease-out;
}
@keyframes cmdk-in { from { transform:translateY(-8px) scale(0.98); opacity:0; } to { transform:none; opacity:1; } }
.cmdk-input-row { display:flex; align-items:center; gap:10px; padding:14px 18px; border-bottom:1px solid var(--border); }
.cmdk-input-row .ico { color:var(--muted); display:grid; place-items:center; }
.cmdk-input-row .input { flex:1; border:0; outline:none; font-size:16px; background:transparent; color:var(--ink); }
.cmdk-kbd {
  display:inline-block; padding:3px 7px; border-radius:5px; background:var(--surface-mute); border:1px solid var(--border);
  font-family:ui-monospace, monospace; font-size:11px; font-weight:600; color:var(--muted);
}
.cmdk-body { max-height:50vh; overflow-y:auto; padding:8px 0; }
.cmdk-section-label { padding:10px 18px 4px; font-size:10px; font-weight:700; color:var(--muted); text-transform:uppercase; letter-spacing:0.08em; }
.cmdk-item { display:flex; gap:12px; align-items:center; padding:10px 18px; cursor:pointer; }
.cmdk-item:hover, .cmdk-item.active { background:var(--primary-soft); }
.cmdk-item .icn { width:32px; height:32px; border-radius:8px; background:var(--surface-mute); display:grid; place-items:center; font-size:16px; flex-shrink:0; }
.cmdk-item .body { flex:1; }
.cmdk-item .body .t { font-weight:600; font-size:13px; }
.cmdk-item .body .d { font-size:12px; color:var(--muted); }
.cmdk-item .hn { font-family:ui-monospace, monospace; font-size:11px; color:var(--muted); background:var(--surface-mute); padding:2px 6px; border-radius:4px; }
.cmdk-item .arr { color:var(--muted); }
.cmdk-empty { text-align:center; padding:40px 20px; }
.cmdk-empty .emoji { font-size:40px; }
.cmdk-empty .t { font-weight:700; margin-top:8px; }
.cmdk-empty .d { font-size:12px; color:var(--muted); margin-top:4px; }
.cmdk-foot {
  display:flex; justify-content:space-between; padding:10px 18px; border-top:1px solid var(--border);
  font-size:11px; color:var(--muted); background:var(--surface-mute);
}
.cmdk-foot .k { display:flex; gap:4px; align-items:center; }

/* ===== Registration page ===== */
.reg-wrap { max-width:1400px; margin:0 auto; padding:16px 0; }
.reg-mode-toggle { display:flex; background:var(--surface-mute); border-radius:10px; padding:4px; gap:4px; }
.reg-mode-toggle button {
  padding:8px 16px; border:0; background:transparent; cursor:pointer; font:inherit; font-size:13px; font-weight:600;
  color:var(--muted); border-radius:7px; transition:all .15s;
}
.reg-mode-toggle button.active { background:#fff; color:var(--primary); box-shadow:0 1px 3px rgba(0,0,0,0.1); }

.reg-grid { display:grid; grid-template-columns:1fr 340px; gap:16px; }
@media (max-width:1100px) { .reg-grid { grid-template-columns:1fr; } }

.reg-section {
  background:#fff; border:1px solid var(--border); border-radius:12px; margin-bottom:12px; overflow:hidden;
}
.reg-section-head {
  display:flex; align-items:center; gap:12px; padding:14px 18px; border-bottom:1px solid var(--border);
  background:var(--surface-mute);
}
.reg-section-head .num {
  width:26px; height:26px; border-radius:50%; background:var(--primary); color:#fff;
  display:grid; place-items:center; font-weight:700; font-size:12px;
}
.reg-section-head h3 { margin:0; font-size:14px; flex:1; }
.reg-section-head .status { font-size:12px; color:var(--muted); font-weight:600; }
.reg-section-head .status.done { color:var(--green); }
.reg-section-body { padding:18px; }

.id-scanner {
  border:2px dashed var(--border); border-radius:12px; padding:24px; text-align:center; background:var(--surface-mute);
  transition:all .25s;
}
.id-scanner .ill { font-size:48px; margin-bottom:10px; }
.id-scanner .ill::before { content:"💳"; }
.id-scanner.scanning { border-color:var(--primary); background:var(--primary-soft); animation:pulse-bg 1.5s infinite; }
.id-scanner.scanning .ill::before { content:"📖"; }
.id-scanner.done { border-color:var(--green); background:var(--green-soft); border-style:solid; }
.id-scanner.done .ill::before { content:"✓"; }
@keyframes pulse-bg { 0%,100% { opacity:1; } 50% { opacity:0.7; } }

.form-grid { display:grid; gap:14px; }
.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }

.field { display:flex; flex-direction:column; gap:4px; }
.field label { font-size:12px; font-weight:600; color:var(--muted); }
.field .input, .field select, .field textarea {
  border:1px solid var(--border); border-radius:8px; padding:9px 11px; font:inherit; font-size:13px;
  background:#fff; color:var(--ink);
}
.field .input:focus, .field select:focus, .field textarea:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-soft); }
.field.autofilled .input { background:var(--green-soft); border-color:var(--green); }
.field.autofilled::after { content:"auto"; font-size:10px; color:var(--green); margin-left:auto; }

.reg-summary {
  background:#fff; border:1px solid var(--border); border-radius:12px; padding:18px;
  position:sticky; top:12px; height:fit-content;
}
.reg-summary h4 { margin:0 0 12px; font-size:13px; text-transform:uppercase; letter-spacing:0.06em; color:var(--muted); }
.portrait-lg {
  width:90px; height:90px; border-radius:16px; background:var(--primary-soft); display:grid; place-items:center;
  font-size:48px; margin:0 auto 14px;
}

.chip.danger { background:var(--rose-soft); color:var(--rose); }
.chip { display:inline-flex; padding:3px 8px; border-radius:999px; background:var(--surface-mute); color:var(--ink);
  font-size:11px; font-weight:600; align-items:center; gap:4px; }
